欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 汽车 > 时评 > springboot常用的请求参数的接收方式详解

springboot常用的请求参数的接收方式详解

2025/7/3 17:17:02 来源:https://blog.csdn.net/weixin_50083448/article/details/144494247  浏览:    关键词:springboot常用的请求参数的接收方式详解

在Spring Boot中,接收请求参数的方式有多种,主要有以下几种方式:

1. 使用 @RequestParam 注解

@RequestParam 用于接收请求中的查询参数(query parameters)。它通常用于处理 URL 中的键值对,如 ?key=value

  • 示例:接收查询参数

    @GetMapping("/example")
    public String example(@RequestParam String name, @RequestParam int age) {return "Name: " + name + ", Age: " + age;
    }
    

    在这个例子中,如果 URL 是 /example?name=John&age=30nameage 的值会被传递给方法。

  • 参数类型转换:Spring 会自动进行参数类型的转换。如果类型不匹配(例如将字符串转为整数失败),会抛出异常。

  • 默认值:可以设置默认值,当请求中没有对应参数时会使用默认值。

    @GetMapping("/example")
    public String example(@RequestParam(defaultValue = "John") String name) {return "Name: " + name;
    }
    

2. 使用 @PathVariable 注解

@PathVariable 用于接收路径中的参数,通常用于 RESTful 风格的 URL。

  • 示例:接收 URL 中的路径参数
    @GetMapping("/user/{id}")
    public String getUser(@PathVariable String id) {return "User ID: " + id;
    }
    
    例如,当请求路径为 /user/123 时,id 参数会接收到 123

3. 使用 @RequestBody 注解

@RequestBody 用于接收请求体中的数据,通常用于 POST 请求或 PUT 请求。它可以将请求体的数据反序列化成指定的 Java 对象(如 JSON、XML 等)。

  • 示例:接收 JSON 格式的请求体
    @PostMapping("/createUser")
    public String createUser(@RequestBody User user) {return "User created: " + user.getName();
    }
    
    假设发送的请求体是:
    {"name": "John","age": 30
    }
    
    @RequestBody 会将请求体的 JSON 数据转换为 User 对象。

4. 使用 @ModelAttribute 注解

@ModelAttribute 用于将请求参数绑定到方法参数的 JavaBean 中。它常用于表单提交或使用 GET 请求传递的数据。

  • 示例:表单数据绑定到 Java 对象

    @PostMapping("/submitForm")
    public String submitForm(@ModelAttribute User user) {return "Form submitted by: " + user.getName();
    }
    

    假设 HTML 表单提交的数据为:

    <form action="/submitForm" method="post"><input type="text" name="name" /><input type="number" name="age" />
    </form>
    
  • 注意@ModelAttribute 会将请求中的所有参数与 Java 对象的字段进行匹配。

5. 使用 @RequestHeader 注解

@RequestHeader 用于获取请求头中的数据。可以通过此注解获取 HTTP 请求头的某些信息。

  • 示例:接收请求头
    @GetMapping("/header")
    public String getHeader(@RequestHeader("User-Agent") String userAgent) {return "User-Agent: " + userAgent;
    }
    
    假设请求头中包含 User-Agent 字段,@RequestHeader 会将其值传递给 userAgent 变量。

6. 使用 @CookieValue 注解

@CookieValue 用于获取请求中的 cookie 值。

  • 示例:接收请求中的 cookie
    @GetMapping("/cookie")
    public String getCookie(@CookieValue("JSESSIONID") String sessionId) {return "Session ID: " + sessionId;
    }
    
    假设请求中包含名为 JSESSIONID 的 cookie,@CookieValue 会将其值传递给 sessionId

7. 使用 @RequestParam 的集合类型

@RequestParam 也支持接收数组或集合类型的参数。

  • 示例:接收多个相同名称的参数
    @GetMapping("/items")
    public String getItems(@RequestParam List<String> items) {return "Items: " + items;
    }
    
    例如请求 /items?items=apple&items=banana&items=cherryitems 将接收到 ["apple", "banana", "cherry"]

8. 使用 @RequestPart 注解

@RequestPart 用于处理上传的文件或多部分表单数据(multipart/form-data)。它用于从请求中提取文件或其他部分的数据。

  • 示例:接收文件和其他表单字段
    @PostMapping("/upload")
    public String uploadFile(@RequestPart("file") MultipartFile file, @RequestPart("description") String description) {return "File uploaded: " + file.getOriginalFilename() + ", Description: " + description;
    }
    
    这里,file 是通过 @RequestPart 注解接收的文件,而 description 是接收到的其他字段。

9. 使用 @RequestMapping 注解的 params 属性

可以在 @RequestMapping 中使用 params 属性来限制方法仅在满足特定查询参数时才会被调用。

  • 示例:请求必须包含特定参数才能执行
    @RequestMapping(value = "/search", params = "query")
    public String search(@RequestParam String query) {return "Search query: " + query;
    }
    
    只有当请求路径为 /search?query=value 时,才会匹配到这个方法。

总结:

  • @RequestParam:用于查询参数。
  • @PathVariable:用于路径参数。
  • @RequestBody:用于请求体,常用于接收 JSON、XML 等格式的数据。
  • @ModelAttribute:用于将请求参数绑定到 JavaBean 中。
  • @RequestHeader:用于接收请求头数据。
  • @CookieValue:用于接收 Cookie 值。
  • @RequestPart:用于处理上传的文件和表单字段。
  • 集合类型的 @RequestParam:用于接收多个相同名称的参数。
  • @RequestMapping params 属性:用于限制特定查询参数的接收。

这些方式可以根据不同的需求选择使用,灵活地处理 Spring Boot 中的请求参数。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com