欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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

程序员文章站 2024-03-21 20:59:28
...

前后端分离实现

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";
    }