Idea使用httpclient调用接口
前言
Github:https://github.com/HealerJean
一、IDEA
1、Post
请求
1)@RequestBody
@requestbody
的含义是在当前对象获取整个http
请求的body
里面的所有数据,从@requestbody
设计上来说,只获取一次就可以拿到请求body
里面的所有数据,就不能够出现有多个@requestbody
出现在controller
的函数的形参列表当中,
a、required
不写的话,按照下面的正常调用就行了 但是如果写上了里面参数使用了required
=true,一定不能让DTO
对象为 null
,否则就会报错org.springframework.http.converter.HttpMessageNotReadableException: Required request body is missing
或者将它设置为 required
= false
如果使用了它,传递的必须为 json
@PostMapping("addData")
public String addData(@RequestBody(required = false) DataDTO dataDTO){
}
POST http://localhost.admin/addData
Accept: */*
Cache-Control: no-cache
Content-Type: application/json; charset=UTF-8
Cookie: JSESSIONID=e1fd90bf-1148-4368-9fe9-018dcaf1aa0d
#请求参数,注意这里要空一行,否则就不会调用成功,因为如果和上面的参数紧挨着,就会被认为是参数的一种
{"typeKey":"country","dataKey":"china","dataValue":"中国"}
2)非 @RequestBody
请求,正常表单
POST http://localhost.admin/api/sys/post?type=SingleLoan
Accept: */*
Cache-Control: no-cache
Cookie: scf-client_SID=24c0e5778aaf4902bc6b45c42b977f4a
Content-Type: multipart/form-data; boundary=WebAppBoundary
3)文件上传
public String upload(@RequestParam( required = false) MultipartFile file, SysFileDTO fileDTO )
# 4.1、文件上传
POST http://scf-client-web/api/sys/file/upload?type=SingleLoan
Accept: */*
Cache-Control: no-cache
Cookie: scf-client_SID=24c0e5778aaf4902bc6b45c42b977f4a
Content-Type: multipart/form-data; boundary=WebAppBoundary
# file 参数名,filename 文件名(我们可以自己取名字)
--WebAppBoundary
Content-Disposition: form-data; name="file"; filename="filename.jpg"
Content-Type: image/jpeg
< C:\Users\HealerJean\Desktop\微信图片_20190830164253.jpg
--WebAppBoundary--
文件路径选择,然后点击 ,进行复制路径
2、Get
请求
1) GetMapping
不支持 @RequestBody
但是我们
Get
请求如果使用了@RequestBody
这种方式,在使用下面Json
请求的方法也是可以调用成功的。但是前端正常的Get
请求使用地址调用则不会成功。所以Get
请求,直接写上对象就行了,不要写@RequestBody
,虽然能调通,但确实错误的代码
@GetMapping("getDatas")
public String getDatas( DataDTO dataDTO) {
}
GET http://localhost.admin/getDatas?typeKey=country&dataKey=1
Accept: */*
Cache-Control: no-cache
Content-Type: application/json; charset=UTF-8
Cookie: JSESSIONID=a6ad800b-15cf-4148-b659-a604e5a5f0fc
3、Delete
请求
@DeleteMapping( "deleteData/{id}")
public String deleteData(@PathVariable Long id){
}
DELETE http://localhost.admin/delete/1
Accept: */*
Cache-Control: no-cache
Content-Type: application/json; charset=UTF-8
Cookie: JSESSIONID=e1fd90bf-1148-4368-9fe9-018dcaf1aa0d
4、PUT
请求
@PutMapping("updateData/{id}")
public String updateData(@PathVariable Long id @RequestBody(required = false)DictionaryTypeDTO typeDTO){
}
PUT http://localhost.admin/api/sys/updateData/1
Accept: */*
Cache-Control: no-cache
Content-Type: application/json; charset=UTF-8
Cookie: JSESSIONID=e1fd90bf-1148-4368-9fe9-018dcaf1aa0d
#请求参数
{"typeKey":"country","typeDesc":"国际"}
5、规范
三个#号有效分隔
Http
请求,所以一般在注释上进行添加
############ 1、合同 #######################################
### 1.1、字典类型添加
POST http://localhost.admin/api/sys/dictType/add
Accept: */*
Cache-Control: no-cache
Content-Type: application/json; charset=UTF-8
Cookie: scf-manager_SID=e1fd90bf-1148-4368-9fe9-018dcaf1aa0d
{"typeKey":"sex","typeDesc":"性别"}
# 返回结果
#"{\"msg\":\"新增字典数据成功\",\"typeKey\":\"country\",\"typeDesc\":\"国家\",\"id\":null}"
### 1.2、字典类型删除
DELETE http://localhost.admin/api/sys/dictType/1
Accept: */*
Cache-Control: no-cache
Content-Type: application/json; charset=UTF-8
Cookie: scf-manager_SID=e1fd90bf-1148-4368-9fe9-018dcaf1aa0d
# 返回结果
# "{\"msg\":\"字典类型删除成功\"}"
二、PostMan
1、Cookie
文件上传测试
2、postman
配置环境变量
1)设置添加环境变量
2)配置环境变量的值
3)变量访问