PostMan接口测试和相关注解的理解

一、@RequestParam注解

1、@RequestParam的参数:

(1)value、name 属性都标识请求参数名(必须配置);

(2)@required:参数是否必传,默认为 true,可以设置为非必传 false;(如果设置了必传或默认,请求未传递参数,将会抛出异常);

(3)defaultValue:参数默认值,如果设置了该值,required 将会自动设置为 false;

2、@RequestParam获取的参数放在哪儿?

(1)Spring中的@RequestParam注解接收的参数大多数场景是来自requestHeaders中,即get请求头,也就是url中,格式为:

http://localhost:8080/optimus-prime/project/test?id=1&name=yc&age=23

由于 url 长度有限制,所以参数需要限制数量和值的长度

(2)get请求的 requestHeaders 中 content-type 这个字段,使用 form-data 表单形式携带参数请求

1)传入的参数是基本类型

对应的java代码是:

@RequestMapping(value = "/test", method = RequestMethod.GET)

    public void test(@RequestParam("id") Integer id,

                     @RequestParam("name") String name,

                     @RequestParam("age") Integer age) {

    }

2)传入的参数是集合类型

对应的java代码是:

@GetMapping(value = "/device/list/excel")
     public String queryDeviceListsExcel(@RequestParam("deviceNumList") List<String> deviceNumList){
        LOGGER.info("查询视频设备列表, params:{}" , deviceNumList);

        return  deviceService.queryDeviceListsExcel(deviceNumList);
    }

二、@RequestBody注解

1、@RequestBody的参数:

@RequestBody注解只拥有一个参数:required ,默认为 true,即对象中的属性必须有一个要传,否则会抛出异常:org.springframework.http.converter.HttpMessageNotReadableException: Required request body is missing。

2、@RequestBody获取的参数放在哪儿?

Spring中的@RequestBody注解是用来接收请求体中的参数数据,即requestBody请求体中,故不受参数数据长度的限制

 对应的java代码是:

@Data
@AllArgsConstructor
@NoArgsConstructor
public class User {
    private Integer id;
    private String name;
    private Integer age;
 
}
 
@RequestMapping(value = "/test", method = RequestMethod.POST)
    public void test(@RequestBody User user) {
       
    }

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Postman是一款流行的API测试工具,它允许你发送HTTP请求并检查响应。当你尝试访问一个Spring Security中带有`@PreAuthorize`注解的REST接口时,这个注解通常用于控制只有满足特定权限的用户才能访问的方法。 `@PreAuthorize`是Spring Security的一个表达式语言(Expression Language)注解,它会在方法执行前检查授权策略。如果你要在Postman中模拟这样的请求,你需要做以下步骤: 1. **设置基础URL**:首先,在Postman中输入你的应用服务器的基础URL,包括API路径。 2. **模拟登录**:对于需要认证的接口,你需要先模拟一个已授权的用户登录。这通常涉及到发送一个带有有效令牌(如JWT)的`Authorization`头,格式通常是 `Bearer <token>`。 3. **配置拦截器**:如果Postman支持自定义headers,你可以添加一个`Authorization`字段,并提供对应的凭证。如果没有内置支持,可能需要借助一些插件或者代理设置。 4. **测试接口**:现在可以发送GET、POST等请求到那个带有`@PreAuthorize`的接口Postman会自动带上你在第一步设置的认证信息。如果授权策略通过,接口将正常返回;如果不满足权限,则可能收到403 Forbidden错误。 5. **查看预授权失败**:在某些情况下,你可能想确认授权失败的情况,可以在Postman的预处理器(Pre-request Script)中编写检查逻辑来模拟不同的权限场景。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值