springboot中的注解demo

简介: springboot中的注解demo

公众号merlinsea


GetMapping:用于从客户端到服务端端请求


/**
 * @RestController:标识这个类是一个控制器,同时返回json数据
 */
@RestController
public class GetController {
    /**
     * @RequestMapping()标明url访问路径
     * @PathVariable() 标明把路径中的值映射到形参中
     * url: localhost:8080/22/33
     */
    @RequestMapping(path="/{city_id}/{user_id}",method = RequestMethod.GET)
    public Object getMethod1(@PathVariable("city_id") String cityId,@PathVariable("user_id") String userId){
        Map<String,Object> map = new HashMap<>();
        map.put("cityId",cityId);
        map.put("userId",userId);
        return map;
    }
    /**
     * @GetMapping() 标明访问路径
     * value的值的key必须和形参一致
     * url: localhost:8080/api/v1/get_method2?name=lianglin&age=22
     */
    @GetMapping("api/v1/get_method2")
    public Object getMethod2(String name,int age){
        Map<String,Object> map = new HashMap<>();
        map.put("name",name);
        map.put("age",age);
        return map;
    }
    /**
     * @RequestParam() 设置默认参数
     * url:localhost:8080/api/v1/get_method3?size=100
     */
    @GetMapping("api/v1/get_method3")
    public Object getMethod3(@RequestParam(defaultValue = "0") int from,int size){
        Map<String,Object> map = new HashMap<>();
        map.put("from",from);
        map.put("size",size);
        return map;
    }
    /**
     * @RequestBody 请求报文携带bean对象传递参数
     * 需要指定http请求头content-type:application/json
     * 在请求报文中的body中保存数据
     */
    @GetMapping("api/v1/get_method4")
    public Object getMenthod4(@RequestBody User user){
        Map<String,Object> map = new HashMap<>();
        map.put("user",user);
        return map;
    }
    /**
     * @RequestHeader 获取请求报文中的请求头信息
     * 请求头信息不会出现在url后面,通常存放用户token信息
     * url:localhost:8080/api/v1/get_method5?id=12
     */
    @GetMapping("api/v1/get_method5")
    public Object getMethod5(@RequestHeader("access_token") String token,int id){
        Map<String,Object> map = new HashMap<>();
        map.put("token",token);
        map.put("id",id);
        return map;
    }
    /**
     * 用户访问的请求会自动映射到HttpServletRequest
     * url:localhost:8080/api/v1/get_method6?id=11
     */
    @GetMapping("api/v1/get_method6")
    public Object getMethond6(HttpServletRequest request){
        Map<String,Object> map = new HashMap<>();
        String id = request.getParameter("id");
        map.put("id",id);
        return map;
    }
}


Post/Put/Delete方法,也是客户端到服务器端的请求


@RestController
public class OtherController {
    /**
     * @PostMapping 常用于表单提交
     * PostMapping的提交封装为请求报文body中的表单形式
     */
    @PostMapping("api/v1/login")
    public Object login(String id, String pwd){
        Map<String,Object> map = new HashMap<>();
        map.put("id",id);
        map.put("pwd",pwd);
        return  map;
    }
    /**
     * @RequestBody 从request body中取json数据
     * @param user
     * @return
     */
    @PostMapping("login")
    public Object login(@RequestBody User user){
        System.out.println(user.toString());
        return new String("okay");
    }
    /**
     * url:localhost:8080/api/v1/put?id=12
     */
    @PutMapping("api/v1/put")
    public Object put(String id){
        Map<String,Object> map = new HashMap<>();
        map.put("id",id);
        return map;
    }
    @DeleteMapping ("api/v1/del")
    public Object del(String id){
        Map<String,Object> map = new HashMap<>();
        map.put("id",id);
        return map;
    }
}


相关文章
|
13天前
|
Java 开发者 Spring
【SpringBoot 异步魔法】@Async 注解:揭秘 SpringBoot 中异步方法的终极奥秘!
【8月更文挑战第25天】异步编程对于提升软件应用的性能至关重要,尤其是在高并发环境下。Spring Boot 通过 `@Async` 注解简化了异步方法的实现。本文详细介绍了 `@Async` 的基本用法及配置步骤,并提供了示例代码展示如何在 Spring Boot 项目中创建与管理异步任务,包括自定义线程池、使用 `CompletableFuture` 处理结果及异常情况,帮助开发者更好地理解和运用这一关键特性。
69 1
|
22天前
|
XML Java 测试技术
Spring5入门到实战------17、Spring5新功能 --Nullable注解和函数式注册对象。整合JUnit5单元测试框架
这篇文章介绍了Spring5框架的三个新特性:支持@Nullable注解以明确方法返回、参数和属性值可以为空;引入函数式风格的GenericApplicationContext进行对象注册和管理;以及如何整合JUnit5进行单元测试,同时讨论了JUnit4与JUnit5的整合方法,并提出了关于配置文件加载的疑问。
Spring5入门到实战------17、Spring5新功能 --Nullable注解和函数式注册对象。整合JUnit5单元测试框架
|
9天前
|
缓存 Java 数据库连接
Spring Boot奇迹时刻:@PostConstruct注解如何成为应用初始化的关键先生?
【8月更文挑战第29天】作为一名Java开发工程师,我一直对Spring Boot的便捷性和灵活性着迷。本文将深入探讨@PostConstruct注解在Spring Boot中的应用场景,展示其在资源加载、数据初始化及第三方库初始化等方面的作用。
34 0
|
22天前
|
Java 数据安全/隐私保护 Spring
揭秘Spring Boot自定义注解的魔法:三个实用场景让你的代码更加优雅高效
揭秘Spring Boot自定义注解的魔法:三个实用场景让你的代码更加优雅高效
|
22天前
|
XML Java 数据库
Spring5入门到实战------15、事务操作---概念--场景---声明式事务管理---事务参数--注解方式---xml方式
这篇文章是Spring5框架的实战教程,详细介绍了事务的概念、ACID特性、事务操作的场景,并通过实际的银行转账示例,演示了Spring框架中声明式事务管理的实现,包括使用注解和XML配置两种方式,以及如何配置事务参数来控制事务的行为。
Spring5入门到实战------15、事务操作---概念--场景---声明式事务管理---事务参数--注解方式---xml方式
|
22天前
|
XML 数据库 数据格式
Spring5入门到实战------14、完全注解开发形式 ----JdbcTemplate操作数据库(增删改查、批量增删改)。具体代码+讲解 【终结篇】
这篇文章是Spring5框架的实战教程的终结篇,介绍了如何使用注解而非XML配置文件来实现JdbcTemplate的数据库操作,包括增删改查和批量操作,通过创建配置类来注入数据库连接池和JdbcTemplate对象,并展示了完全注解开发形式的项目结构和代码实现。
Spring5入门到实战------14、完全注解开发形式 ----JdbcTemplate操作数据库(增删改查、批量增删改)。具体代码+讲解 【终结篇】
|
22天前
|
XML Java 数据格式
Spring5入门到实战------8、IOC容器-Bean管理注解方式
这篇文章详细介绍了Spring5框架中使用注解进行Bean管理的方法,包括创建Bean的注解、自动装配和属性注入的注解,以及如何用配置类替代XML配置文件实现完全注解开发。
Spring5入门到实战------8、IOC容器-Bean管理注解方式
|
23天前
|
XML JSON Java
使用IDEA+Maven搭建整合一个Struts2+Spring4+Hibernate4项目,混合使用传统Xml与@注解,返回JSP视图或JSON数据,快来给你的SSH老项目翻新一下吧
本文介绍了如何使用IntelliJ IDEA和Maven搭建一个整合了Struts2、Spring4、Hibernate4的J2EE项目,并配置了项目目录结构、web.xml、welcome.jsp以及多个JSP页面,用于刷新和学习传统的SSH框架。
29 0
使用IDEA+Maven搭建整合一个Struts2+Spring4+Hibernate4项目,混合使用传统Xml与@注解,返回JSP视图或JSON数据,快来给你的SSH老项目翻新一下吧
|
9天前
|
监控 安全 Java
【开发者必备】Spring Boot中自定义注解与处理器的神奇魔力:一键解锁代码新高度!
【8月更文挑战第29天】本文介绍如何在Spring Boot中利用自定义注解与处理器增强应用功能。通过定义如`@CustomProcessor`注解并结合`BeanPostProcessor`实现特定逻辑处理,如业务逻辑封装、配置管理及元数据分析等,从而提升代码整洁度与可维护性。文章详细展示了从注解定义、处理器编写到实际应用的具体步骤,并提供了实战案例,帮助开发者更好地理解和运用这一强大特性,以实现代码的高效组织与优化。
22 0
|
1月前
|
XML 前端开发 Java
Spring MVC接收param参数(直接接收、注解接收、集合接收、实体接收)
Spring MVC提供了灵活多样的参数接收方式,可以满足各种不同场景下的需求。了解并熟练运用这些基本的参数接收技巧,可以使得Web应用的开发更加方便、高效。同时,也是提高代码的可读性和维护性的关键所在。在实际开发过程中,根据具体需求选择最合适的参数接收方式,能够有效提升开发效率和应用性能。
66 3
下一篇
DDNS