目录

Spring4响应相关

Spring(4)——响应相关

一、返回静态页面

1.1**@RestController @Controller**

想返回如下页面:

https://i-blog.csdnimg.cn/direct/b0e7b32612a047d2afe144344f913838.png

如果我们依旧使用原来的**@RestController**

https://i-blog.csdnimg.cn/direct/470c25be1d9944deb07f9a9a8de26cba.png

https://i-blog.csdnimg.cn/direct/97b4d7f054174ce891b2c98f741c9f02.png

可以看到的是仅仅返回了字符串。

此时将**@RestController 改为 @Controller**

https://i-blog.csdnimg.cn/direct/63907c6870414aa197d5d43212aa89a4.png

https://i-blog.csdnimg.cn/direct/24a3ccfbaf904ec79ae0aa2da9e08893.png

可以看到这次返回的是html页面。

那么**@RestController @Controller 有什么区别和联系呢,这就要从MVC架构说起了,最开始设计View是要返回视图的,但随着技术的发展,前后端分离程度越来越高,Java后端开始只关注于后端的事务,不在关注前端的呈现,MVC也就发生了变化,View不在返回视图,而是返回显示视图时所需要的数据。所以前面使用的 @RestController**其实返回的是数据。

@RestController

@Controller + @ResponseBody

@Controller :定义⼀个控制器,Spring框架启动时加载,把这个对象交给Spring管理。

@ResponseBody :定义返回的数据格式为⾮视图,返回⼀个text/html信息。

@ResponseBody 既可以作为类注解也可以作为方法注解,如果标记在类上,那么表示该类中的所有方法都返回的是数据,如果一个类中既有返回视图的方法也有返回注解的方法,那么只用把**@ResponseBody**标注到对应方法上即可。

所以在有**@Controller 注解的基础上添加 @ResponseBody 注解就等于直接标注 @RestController**。

@Controller
@RequestMapping("/response")
public class ResponseController {
    //返回视图
    @RequestMapping("/responseHelloPage")
    public String requestHelloPage(){
        return "/hello.html";
    }

    //返回数据
    @RequestMapping("/responseHelloPage2")
    @ResponseBody
    public String requestHelloPage2(){
        return "返回数据";
    }
}

https://i-blog.csdnimg.cn/direct/2cfa1074bbff44c7b7defd56823264f8.png

https://i-blog.csdnimg.cn/direct/04f02252961d4e0883c257e5235732ca.png

在标注了@Controller的类(表明该类中所有方法都返回视图)里,有一个需要返回数据的方法,但是该方法没有标注@ResponseBody,那么客户端在请求这个页面的时候会发生404错误:

@Controller
@RequestMapping("/response")
public class ResponseController {
    //返回视图
    @RequestMapping("/responseHelloPage")
    public String requestHelloPage(){
        return "/hello.html";
    }

    //返回数据
    @RequestMapping("/responseHelloPage2")
    //去掉@ResponseBody注解
    public String requestHelloPage2(){
        return "返回数据";
    }
}

https://i-blog.csdnimg.cn/direct/2f624d7f0f44449eaf09e744f0ef69c1.png

1.2 返回Html片段

@RequestMapping("/returnHtml")
    @ResponseBody
    public String returnHtml() {
        return "<h1>Hello,HTML~</h1>";
    }

https://i-blog.csdnimg.cn/direct/5250593b8c734ba8b82e583782c9ffb7.png

1.3 返回Json

@RequestMapping("/returnJson")
    @ResponseBody
    public HashMap<String, String> returnJson() {
        HashMap<String, String> map = new HashMap<>();
        map.put("Java", "Java Value");
        map.put("MySQL", "MySQL Value");
        map.put("Redis", "Redis Value");
        return map;
    }

https://i-blog.csdnimg.cn/direct/49b523cc16ef42f4b914750ae79b0293.png

通过Json返回一个对象:

@RequestMapping("/returnUser")
    @ResponseBody
    public User returnUser() {
       User user = new User("zhangsan",18,"未知");
        return user;
    }

https://i-blog.csdnimg.cn/direct/8ae696b8b6024bb6a039912fcef3cad0.png

1.4 设置状态码

SpringMVC会根据我们⽅法的返回结果⾃动设置响应状态码,程序员也可以⼿动指定状态码,通过SpringMVC的内置对象HttpServletResponse提供的⽅法来进⾏设置 。

@RequestMapping(value = "/setStatus")
    @ResponseBody
    public String setStatus(HttpServletResponse response) {
        response.setStatus(401);
        return "设置状态码成功";
    }

https://i-blog.csdnimg.cn/direct/9a7d434ac63a43e89205e4f94d72c510.png

https://i-blog.csdnimg.cn/direct/81b21909b56c4c2c98a7085cc42fa90e.png