资料汇总--Ajax中Put和Delete请求传递参数无效的解决方法(Restful风格)【转】
2017-10-24 19:30
751 查看
开发环境:Tomcat9.0
在使用Ajax实现Restful的时候,有时候会出现无法Put、Delete请求参数无法传递到程序中的尴尬情况,此时我们可以有两种解决方案:1、使用地址重写的方法传递参数。2、配置web.xml项目环境。
测试的程序为:
一、使用地址重写的方法来实现put、delete请求的参数传递。
在js页面中(
二、使用配置文件修改来实现Put和Delete请求的参数传递
1、解决Put请求的参数传递,但是 无法解决 Delete 请求的传递
①、在项目中的web.xml文件中配置:
②在js文件中:
2、解决 Put和Delete 请求的参数传递。
①、在项目中的web.xml文件中配置:
②在js文件中:
在使用Ajax实现Restful的时候,有时候会出现无法Put、Delete请求参数无法传递到程序中的尴尬情况,此时我们可以有两种解决方案:1、使用地址重写的方法传递参数。2、配置web.xml项目环境。
测试的程序为:
@RequestMapping(value = "/member", method = RequestMethod.PUT, produces = "application/json;charset=UTF-8") public @ResponseBody Object edit(Member vo1) { log.info("【*** 修改用户信息 ***】" + vo1); JSONObject obj = new JSONObject(); obj.put("flag", true); return obj; }
一、使用地址重写的方法来实现put、delete请求的参数传递。
在js页面中(
$(editMember).on("click",function(){ $.ajax({ url : "member?empno=1009&ename=阿伦&sal=19777.77&hiredate=1969-10-10" , // 处理的请求路径 type : "put" , // 此处发送的是PUT请求(可变更为其他需要的请求) dataType : "json" , // 返回的数据类型为json类型 success : function(data) { $(showDiv).append("<p>修改处理结果:" + data.flag + "</p>") ; } , error : function(data) { $(showDiv).append("<p>对不起,出错啦!</p>") ; } }) ; }) ;
二、使用配置文件修改来实现Put和Delete请求的参数传递
1、解决Put请求的参数传递,但是 无法解决 Delete 请求的传递
①、在项目中的web.xml文件中配置:
<filter> <filter-name>HttpMethodFilter</filter-name> <filter-class>org.springframework.web.filter.HttpPutFormContentFilter</filter-class> </filter> <filter-mapping> <filter-name>HttpMethodFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
②在js文件中:
$(editBut).on("click",function(){ $.ajax({ url: "member", type : "put", // 此处发送的是PUT请求 data : { empno : 1170, ename : "SMITH", sal : 11.1, hiredate : "1991-11-11" }, success : function(data){ $(showDiv).append("<p> 数据更新成功:"+data.flag+"</p>"); console.log(1); }, dataType : "json", error : function(data){ $(showDiv).append("<p>对不起,出错啦!</p>"); } }) });
2、解决 Put和Delete 请求的参数传递。
①、在项目中的web.xml文件中配置:
<filter> <filter-name>HiddenHttpMethodFilter</filter-name> <filter-class>org.springframework.web.filter.HiddenHttpMethodFilter</filter-class> </filter> <filter-mapping> <filter-name>HiddenHttpMethodFilter</filter-name> <!-- 备注,这边的名称必须和配置'springmvc'的servlet名称一样 --> <servlet-name>springmvc</servlet-name> </filter-mapping>
②在js文件中:
$(editBut).on("click",function(){ $.ajax({ url: "member", type : "post", // 此处发送的是POST请求 data : { _method : "put", // 将请求转变为PUT请求 empno : 1170, ename : "SMITH", sal : 11.1, hiredate : "11111-11-11" }, success : function(data){ $(showDiv).append("<p> 数据更新成功:"+data.flag+"</p>"); console.log(1); }, dataType : "json", error : function(data){ $(showDiv).append("<p>对不起,出错啦!</p>"); } }) });
相关文章推荐
- Ajax中Put和Delete请求传递参数无效的解决方法(Restful风格
- Ajax中Put和Delete请求传递参数无效的解决方法(Restful风格)
- 解决Ajax中Restful风格PUT和DELETE请求传递参数无效
- springmvc restful put delete Ajax 请求参数取不到-已解决
- 让python bottle框架支持jquery ajax的RESTful风格的PUT和DELETE等请求(新方法)
- ajax参数传递之[HttpGet]/[HttpPost]/[HttpPut]/[HttpDelete]请求
- 1:HTML 中 onclick 触发函数 xxx(param) 要传递对象参数的解决方法 2:LocalStorage存储JSON对象的问题 3:ajax请求传送参数为对象问题
- 针对RestFul风格的PUT,DELETE请求在SpringMVC的Controller层无法接收参数的解决方案
- 解决ajax的delete、put方法接受不到参数的问题
- 解决ajax的delete、put方法接收不到参数的问题方法
- ajax参数传递之[HttpGet]/[HttpPost]/[HttpPut]/[HttpDelete]请求
- 解决AJAX发送PUT和DELETE请求,后台无法接收到参数
- get请求传递中文参数乱码解决方法
- 让python bottle框架支持jquery ajax的RESTful风格的PUT和DELETE等请求
- 实现RestFul风格的delete和Put方法的注意点
- Thinkphp 5.0.5 ajax中put和delete请求方法的解决方案
- python bottle框架支持jquery ajax的RESTful风格的PUT和DELETE方法
- springMVC使用PUT、DELETE方法传递参数解决方案
- JSF拦截ajax请求并传递参数方法
- JQuery.ajax传递中文参数的解决方法