SpringBoot中API接口参数获取方式小结

 更新时间:2024年06月26日 09:15:35   作者:是猛男啊  
在Spring Boot中,API接口参数可以通过多种方式获取,具体取决于你定义的API接口参数类型(如路径参数、查询参数、请求体参数、请求头等),本文给大家就介绍了一些常见的参数获取方式,需要的朋友可以参考下

引言

在Spring Boot中,API接口参数可以通过多种方式获取,具体取决于你定义的API接口参数类型(如路径参数、查询参数、请求体参数、请求头等)。以下是一些常见的参数获取方式以及对应的Java样例代码:

1.路径参数(Path Variable)

使用@PathVariable注解从URL路径中获取参数。

    @RestController
    @RequestMapping("/users")
    public class UserController {
 
        @GetMapping("/{id}")
        public ResponseEntity<String> getUserById(@PathVariable Long id) {
            // 处理逻辑
            return ResponseEntity.ok("User with ID: " + id);
        }
    }

2.查询参数(Query Parameter)

使用@RequestParam注解从URL查询字符串中获取参数。

    @RestController
    @RequestMapping("/users")
    public class UserController {
 
        @GetMapping("/search")
        public ResponseEntity<String> searchUsers(@RequestParam String name) {
            // 处理逻辑
            return ResponseEntity.ok("Searching for user with name: " + name);
        }
 
        // 也可以设置默认值
        @GetMapping("/searchWithDefault")
        public ResponseEntity<String> searchUsersWithDefault(@RequestParam(defaultValue = "John") String name) {
            // 处理逻辑
            return ResponseEntity.ok("Searching for user with name: " + name);
        }
    }

3.请求体参数(Request Body)

使用@RequestBody注解从HTTP请求体中获取参数,通常用于POST或PUT请求。

    @RestController
    @RequestMapping("/users")
    public class UserController {
 
        @PostMapping("/")
        public ResponseEntity<String> createUser(@RequestBody User user) {
            // 处理逻辑
            return ResponseEntity.ok("User created with name: " + user.getName());
        }
 
        // 假设User类如下
        static class User {
            private String name;
            // getters and setters
        }
    }

4.请求头参数(Request Header)

通常不直接使用注解来获取请求头参数,但可以通过HttpServletRequest对象或@RequestHeader注解来获取。

使用@RequestHeader注解:

    @RestController
    @RequestMapping("/users")
    public class UserController {
 
        @GetMapping("/")
        public ResponseEntity<String> getUsers(@RequestHeader("Authorization") String authToken) {
            // 处理逻辑
            return ResponseEntity.ok("Authorization token: " + authToken);
        }
    }

使用HttpServletRequest对象:

    @RestController
    @RequestMapping("/users")
    public class UserController {
 
        @GetMapping("/")
        public ResponseEntity<String> getUsers(HttpServletRequest request) {
            String authToken = request.getHeader("Authorization");
            // 处理逻辑
            return ResponseEntity.ok("Authorization token from HttpServletRequest: " + authToken);
        }
    }

5.@CookieValue

当我们需要与客户端保持有状态的交互时,就需要用到Cookie。此时,服务端读取Cookie数据的时候,就可以像下面这样用@CookieValue来读取Cookie中的SessionId数据。

@GetMapping("/user")
@ResponseBody()
public List<User> getUserList(@CookieValue(name = "SessionId") String sessionId) {
     return userRepo.findAll();
}

6.@MatrixVariable

这个我们用的并不是很多,但一些国外系统有提供这类API参数,这种API的参数通过;分割。

比如:这个请求/books/reviews;isbn=1234;topN=5; 就可以如下面这样,使用@MatrixVariable来加载URL中用;分割的参数。

@GetMapping("/books/reviews")
@ResponseBody()
public List<BookReview> getBookReviews( 
  @MatrixVariable String isbn,  @MatrixVariable Integer topN) {
  return bookReviewsLogic.getTopNReviewsByIsbn(isbn, topN);
}

7.表单数据(Form Data)

对于POST请求中的表单数据,通常可以使用@ModelAttribute或@RequestParam来获取。但如果表单数据作为请求体发送(Content-Type: application/x-www-form-urlencoded),则可以直接使用@RequestParam。如果表单数据是JSON格式,则应使用@RequestBody。

8.Servlet API的其他部分

你还可以使用HttpServletResponse、HttpSession等Servlet API的其他部分来处理请求和响应。但在Spring Boot中,通常推荐使用Spring MVC提供的高级抽象来简化开发。

注:为了正确解析请求体中的JSON数据,需要在Spring Boot项目中添加适当的JSON库(如Jackson),并且确保请求的Content-Type设置为application/json。

以上就是SpringBoot中API接口参数获取方式小结的详细内容,更多关于SpringBoot API接口参数的资料请关注脚本之家其它相关文章!

相关文章

  • 如何解决IDEA git拉取代码后本地代码莫名消失的问题

    如何解决IDEA git拉取代码后本地代码莫名消失的问题

    这篇文章主要介绍了如何解决IDEA git拉取代码后本地代码莫名消失的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-07-07
  • Spring Boot场景启动器(Starters)从入门到精通

    Spring Boot场景启动器(Starters)从入门到精通

    本文给大家介绍Spring Boot场景启动器(Starters)完全指南:从入门到精通,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2025-10-10
  • SpringBoot实现列表数据导出为Excel文件

    SpringBoot实现列表数据导出为Excel文件

    这篇文章主要为大家详细介绍了在Spring Boot框架中如何将列表数据导出为Excel文件,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下
    2024-02-02
  • Java中的WeakHashMap详解

    Java中的WeakHashMap详解

    这篇文章主要介绍了Java中的WeakHashMap详解,WeakHashMap可能平时使用的频率并不高,但是你可能听过WeakHashMap会进行自动回收吧,下面就对其原理进行分析,需要的朋友可以参考下
    2023-09-09
  • SpringBoot2.7.14整合redis7的详细过程

    SpringBoot2.7.14整合redis7的详细过程

    这篇文章主要介绍了SpringBoot2.7.14整合redis7的详细过程,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2023-10-10
  • Java 实现文件批量重命名亲测可用(精简版)

    Java 实现文件批量重命名亲测可用(精简版)

    本文给大家分享一段自己写的java代码实现文件批量重命名,亲测试过没有任何问题,大家可以放心使用
    2016-11-11
  • SpringBoot Jpa分页查询配置方式解析

    SpringBoot Jpa分页查询配置方式解析

    这篇文章主要介绍了SpringBoot Jpa分页查询配置方式解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-02-02
  • Java Files和Paths的使用demo详解

    Java Files和Paths的使用demo详解

    Java Files和Paths是Java 7中引入的新API,用于处理文件和目录,Files类提供了许多有用的静态方法来操作文件和目录,而Path类则表示文件系统中的路径,这篇文章主要介绍了Java Files和Paths的使用详解,需要的朋友可以参考下
    2023-03-03
  • kotlin和Java的相互调用示例详解

    kotlin和Java的相互调用示例详解

    Kotlin 的设计过程中就考虑到了与 Java 的互操作性。在 Kotlin 中可以直接调用既有的 Java 代码, 反过来在 Java 中也可以很流畅地使用 Kotlin 代码,下面这篇文章主要给大家介绍了关于kotlin和Java的相互调用的相关资料,需要的朋友可以参考下。
    2018-02-02
  • Spring security中的授权

    Spring security中的授权

    本篇为大家带来Spring security的授权,首先要理解一些概念,有关于:权限、角色、安全上下文、访问控制表达式、方法级安全性、访问决策管理器,这篇文章主要介绍了Spring security中的授权,需要的朋友可以参考下
    2024-01-01

最新评论