restlet
在开发web应用时,在对Spring中的controller进行测试时,需要发送各种get以及post请求进行测试,当然可以自己在浏览器里输入url或者对于测试而言使用Spring提供的MockMvc
编写代码进行测试,但是当我们想要测试诸如带Form表格提交(提交文件)的post等请求时,直接在浏览器里输入url或者使用MockMvc
(这个我还不知道怎么弄…)就不大好实现了,Restlet Client为我们提供了便利。
其地址为:https://restlet.com/modules/client/,可以安装Chrome浏览器插件,这样使用起来就更加方便,插件在浏览器界面如图所示:
主要有三个部分,request部分用来创建请求,response部分表示请求的回复,可以在
COMPLETE REQUEST headers部分查看自己发出的请求的完整请求头,接下来便创建请求
1. 创建普通get请求
发送get请求比较简单,直接输入url添加参数就可以了
2. 创建普通post请求
发送普通的post请求与1中的发送get请求类似,只是把METHOD改成post即可,再添加必要的参数
3. 创建post请求,模拟form提交表单
有时我们需要模拟form表单提交文件,此时对应controller代码可以如下获取
@RequestMAPPing("/proj")
@ResponseBody
public AjaxResult upload(String fileName, InputStream inputStream, HttpServletRequest request) {
MultipartHttpServletRequest multiRequest = (MultipartHttpServletRequest) request;
int fileCount = 0;
Iterator<String> iterator = multiRequest.getFileNames();
while (iterator.hasNext()) {
String formFileElementName = iterator.next();
fileCount++;
MultipartFile multipartFile = multiRequest.getFile(formFileElementName);
if (null == multipartFile) {
throw new Exception("文件不能为空");
}
}
}
当我们发送模拟form表单请求时,注意到request请求实际为MultipartHttpServletRequest
类型,Spring会自动填充inputStream参数,实际上他与request里的inputStream是同一个,在restlet可以如下模拟
有几个需要注意的地方:
BODY
选项里面选择Form
- 点击
Add form parameter
并选择类型为File
,同时注意一定要写文件名,不然Controller里的代码Iterator<String>
是获取不到文件名的iterator = multiRequest.getFileNames();
- 注意
content-Type
类型为multipart/form-data
我们查看下面的COMPLETE REQUEST HEADERS,可以发现我们的请求类型为 multi/form-data,同时Restlet Client会自动帮我们设置
boundary
头部4. 创建post请求,直接传输文件
除了模拟form表单提交文件,我们也可以直接在body里添加文件,这时controller对应的request就不是
MultipartHttpServletRequest
类型选择BODY中的File选项,并拖拽文件,此时Restlet Client会自动帮我们填入对应的Content-type类型
相关阅读
HttpClient简介HttpClient 是 Apache Jakarta Common 下的子项目,可以用来提供高效的、最新的、功能丰富的支持 HTTP 协议的客户端
JS中height、clientHeight、scrollHeight、offsetHeig
我们来实现test中的onclick事件 function justAtest() { var test= document.getElementById("test")
DELL开机出现CLIENT MAC ADDR:00 19 21 17 54 01 GUID
DELL开机出现CLIENT MAC ADDR:00 19 21 17 54 01 GUID:FFFFFFFF-FFFF-FFFF-FFFF-FFFFFFFF 和 DHCP有碰到此类问题的朋友可参考一
浏览器offsetWidth、clientWidth、scrollWith等总结
对象尺寸会涉及width和height,我们以width为例,height则是一样的道理。 1、clientWidth:对象可见的宽度,不包括滚动条等边线,会随窗口
图解事件坐标screenX、clientX、pageX, offsetX的区别
一、图解 如图所示,假设页面中灰色圆点是鼠标点击处,黄色区域是鼠标触发事件对象 二、概念 1、screenX 和screenY 参照点:电脑屏