SpringMVC的Ajax请求实现前后端分离

前后端分离实现

1.实现ajax查询所有数据返回前端

后端页面

/**
 * 将返回的数据放在响应体中;
 * 如果是对象,jackson包自动将对象转为json格式
 * @return
 */
@ResponseBody
@RequestMapping("/ajax")
public List<product> ajaxQuery(){
    List<product> query = productDAO.getQuery();
    return query;
}

前端页面


<%@ page import="java.util.Date" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>ajax</title>
</head>
<body>
<%
   pageContext.setAttribute("ctp", request.getContextPath());
%>
<script type="text/javascript" src="scripts/jquery-1.9.1.min.js"></script>
<body>
<%=new Date() %>
<a href="${ctp}/ajax" id="ajax">ajax获取所有员工</a><br/>
<div></div>
<%--ajax查询数据--%>
<script type="text/javascript">
    $("#ajax").click(function(){
        //1、发送ajax获取所有员工上
        $.ajax({
            url:"${ctp}/ajax",
            type:"GET",
            success:function(data){
                $("div").empty();
                $.each(data,function(){
                    var empInfo = this.name+"-->"+this.price+"--->"+this.cid+"--->"+this.date;
                    $("div").append(empInfo+"<br/>");
                });
            }
        });
        return false;
    });
</script>
</body>
</html>

2.通过ajax+json前端数据传到后端

<%@ page import="java.util.Date" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>ajax</title>
</head>
<body>
<%
   pageContext.setAttribute("ctp", request.getContextPath());
%>
<script type="text/javascript" src="scripts/jquery-1.9.1.min.js"></script>
<body>
<%=new Date() %>
<form action="${ctp}/test" method="post" enctype="multipart/form-data">
    <input name="name" value="tomcat" id="name"/>
    <input name="price" value="123456" id="price"/>
    <input type="file" name="file" id="file"/>
    <input type="submit" />
</form
<%--ajax查询数据--%>
<script type="text/javascript">
    $("#ajax").click(function(){
        //1、发送ajax获取所有员工上
        $.ajax({
            url:"${ctp}/ajax",
            type:"GET",
            success:function(data){
                $("div").empty();
                $.each(data,function(){
                    var empInfo = this.name+"-->"+this.price+"--->"+this.cid+"--->"+this.date;
                    $("div").append(empInfo+"<br/>");
                });
            }
        });
        return false;
    });
</script>
<%--前后端分离--%>
<%--ajax后端发送数据--%>
<script type="text/javascript">
    $("a:last").click(function() {
​
        //点击发送ajax请求,请求带的数据是json
        var emp = {
            name : "sdsd",
            price : 1,
            cid : 2
        };
        // alert(typeof emp);
        // JSON.parse() 把JSON字符串解析为JSON对象
        //JSON.stringify() 用于把JSON对象序列化为JSON字符串。
        var empStr = JSON.stringify(emp);
        // alert(typeof empStr);
        $.ajax({
            url : '${ctp}/testRequestBody',
            type : "POST",
            data : empStr,
            contentType : "application/json",
            success : function(data) {
                alert(data);
            }
        });
        return false;
    });
</script>
</body>
</html>

后端页面

/**
 * json+ajax前后端分离
 * 获取前端数据
 */
@RequestMapping(value = "/testRequestBody",method = RequestMethod.POST)
public String json(@RequestBody product product){
    System.out.println("请求体:"+product);
    return "suc";
}

 

3.其他用法

/**
     * 将返回数据放在响应体中
     * ResponseEntity<String>:响应体中内容的类型
     * @return
     */
    @RequestMapping("/test04")
public ResponseEntity<String> test04(){
//        创建一个头
    MultiValueMap<String, String> headers = new HttpHeaders();
//    实现body的html
    String body = "<h1>哈哈哈</h1>";
//    传入一个Cookie
    headers.add("Set-Cookie", "username=hahahaha");
//    设置编码格式
    headers.set("Content-Type","text/html;charset=UTF-8");
//    返回到页面
    return new ResponseEntity<String>(body , headers, HttpStatus.OK);
}
    /**
     如果参数位置写HttpEntity<String>  str;
     * 比@RequestBody更强,可以拿到请求头;
     *  @RequestHeader("")
     * @param
     * @return
     */
//    @ResponseBody
    @RequestMapping("/test03")
    public String test03(HttpEntity<String>  str){
        System.out.println(str);
        System.out.println(str.getHeaders().get("host"));
        System.out.println(str.getHeaders().get("cache-control"));

        return "suc";
    }
    /**
     * ResponseBody也可以直接传参数
     * @return
     */
    @ResponseBody
    @RequestMapping(value = "/test02", produces = "text/html;charset=UTF-8")
    public String test02(){
        return "<h1>哈哈哈<h1>";
    }
   

    /**
     *  @RequestBody:请求体;获取一个请求的请求体
     *  @RequestParam:
     *
     *  @ResponseBody:可以把对象转为json数据,返回给浏览器
     *
     *  @RequestBody:接受json数据,封装为对象
     * @return
     */
    @RequestMapping(value = "/test",method = RequestMethod.POST)
    public String testRequestBody(@RequestBody String product){
        System.out.println("请求体1:"+product);
        return "suc";
    }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

水果不是橙子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值