mirror of
https://gitee.com/durcframework/SOP.git
synced 2025-08-11 21:57:56 +08:00
优化ApiArgumentResolver
This commit is contained in:
@@ -32,6 +32,43 @@ value就是接口名,对应客户端的`method`参数
|
||||
|
||||
- 重启story服务,这样接口就可以使用了。
|
||||
|
||||
## 绑定业务参数
|
||||
|
||||
网关校验通过后,请求参数会传递到微服务上来,完整的参数如下所示:
|
||||
|
||||
```
|
||||
请求参数:charset=utf-8&biz_content={"goods_remark":"iphone6"}&method=goods.add&format=json&app_id=2019032617262200001&sign_type=RSA2&version=1.0×tamp=2019-04-29 19:18:38
|
||||
```
|
||||
|
||||
其中biz_content部分是我们想要的,在方法上申明一个对象,对应biz_content中的内容即可完成参数绑定,并且对参数进行JSR-303校验。
|
||||
|
||||
```java
|
||||
@ApiMapping(value = "goods.add")
|
||||
public Object addGoods(GoodsParam param) {
|
||||
return param;
|
||||
}
|
||||
|
||||
@Data
|
||||
public class GoodsParam {
|
||||
|
||||
@NotEmpty(message = "不能为空") // 支持JSR-303校验
|
||||
private String goods_remark;
|
||||
|
||||
}
|
||||
```
|
||||
|
||||
一般情况下,只需要获取业务参数即可,如果想要获取更多的参数,可在后面跟一个`HttpServletRequest`对象。
|
||||
|
||||
```java
|
||||
@ApiMapping(value = "goods.add")
|
||||
public Object addGoods(GoodsParam param/* 业务参数必须放在第一位对应biz_content */, HttpServletRequest request) {
|
||||
System.out.println(request.getParameter("method"));
|
||||
return param;
|
||||
}
|
||||
```
|
||||
|
||||
**注意**:业务参数必须放在第一位
|
||||
|
||||
## 接口命名
|
||||
|
||||
接口命名没有做强制要求,但我们还是推荐按照下面的方式进行命名:
|
||||
|
Reference in New Issue
Block a user