遇一山,过一山,处处有风景;只要勇敢向前,一路尽是繁花盛开。 | (点击查看→)【测试干货】python/java自动化、持续集成、性能、测开、简历、笔试面试等

【转】传统的SpringMVC项目如何使用ajax发送PUT或DELETE请求?

原文:https://www.cnblogs.com/lveyHang/p/11790488.html

 

一、 方式一:将 POST 请求转化为相应的 PUT 和 DELETE  请求

1. 在 Web.xml 中添加如下配置:用于将 POST 请求转化为相应的 PUT 和 DELETE 请求。

1
2
3
4
5
6
7
8
<filter>
    <filter-name>hiddenHttpMethodFilter</filter-name>
    <filter-class>org.springframework.web.filter.HiddenHttpMethodFilter</filter-class>
</filter>
<filter-mapping>
    <filter-name>hiddenHttpMethodFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

  

2. 发送 Rest 风格的 Ajax 请求:

① 发送 PUT 请求:

1
2
3
4
5
6
7
8
$.ajax({
    url:"${pageContext.request.contextPath}/emp/" + id,
    type:"POST",
    data:$("#empModal form").serialize() + "&_method=PUT",
    success:function (result) {
        // 请求成功后的回调函数
    }
});

  

② 发送 DELETE 请求:只需将 “&_method” 的值改为 “DELETE” 即可。

1
2
3
4
5
6
7
8
$.ajax({
    url:"${pageContext.request.contextPath}/emp/" + id,
    type:"POST",
    data:$("#empModal form").serialize() + "&_method=DELETE",
    success:function (result) {
        // 请求成功后的回调函数
    }
});

 

二、方式二:直接发送 PUT 和 DELETE 请求:

1. 在 web.xml 中配置过滤器:

    添加该过滤器的原因,可参考:https://www.cnblogs.com/lveyHang/p/11791412.html

1
2
3
4
5
6
7
8
<filter>
    <filter-name>httpPutFormContentFilter</filter-name>
    <filter-class>org.springframework.web.filter.HttpPutFormContentFilter</filter-class>
</filter>
<filter-mapping>
    <filter-name>httpPutFormContentFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

  

2. 发送 Ajax 请求:

① 发送 PUT 请求:

1
2
3
4
5
6
7
8
$.ajax({
    url:"${pageContext.request.contextPath}/emp/" + id,
    type:"PUT",
    data:$("#empModal form").serialize(),
    success:function (result) {
        // 请求成功后的回调函数
    }
});

  

② 发送 DELETE 请求:

1
2
3
4
5
6
7
8
$.ajax({
    url:"${pageContext.request.contextPath}/emp/" + id,
    type:"DELETE",
    data:$("#empModal form").serialize(),
    success:function (result) {
        // 请求成功后的回调函数
    }
});

  

说明

springboot不需要配置过滤器,已经内置了过滤器,直接写put、delete发请求即可。

 

posted @   全栈测试笔记  阅读(45)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
历史上的今天:
2018-01-24 使用unittest单元测试框架对加法做单元测试
浏览器标题切换
浏览器标题切换end
点击右上角即可分享
微信分享提示