一、返回页面
步骤如下:
我们先要在static目录下创建我们的html文件。

html源码:
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>index</title>
</head>
<body>
hello,spring mvc,我是index⻚⾯.
</body>
</html>
- 在源码的类注解前面要使用@controller注解,返回的页面名要与创建的文件名一致,并且加上后缀,且必须加上反斜杠 /
源码:
@requestmapping("/response")
@controller
public class responsecontroller {
@requestmapping("/r1")
public string r1() {
return "/index.html";
}
}
浏览器访问结果:

二、@controller和@responsebody与restcontroller区别
springboot默认扫描路径是启动类所在路径(包),和子目录。
@restcontroller的作用就是告诉spring这个类需要扫描。
@restcontroller = @responsebody+@controller

在早期编程,前后端不分离时@controller就是负责返回视图的, @responsebody就是负责返回数据的。
- 当一个类中既要返回页面,又要返回数据的时候,就在类上加上@controller,在类中返回数据的方法上加@responsebody。
- 当一个类全部返回数据的时候,就在类上加上@controller + @responsebody,或者@restcontroller。
- 当一个页面只返回页面时,在类上加@controller。
三、返回html代码⽚段
直接跟写html代码一样,写就行了,注意这种算返回数据。
代码:
@requestmapping("/r2")
public string r2() {
return "<h2>我是二级标题</h2>";
}
访问结果:

如果这就是一个文本,只需要在@requestmapping的products中注明类型即可。
@requestmapping(value = "/r2", produces = "text/pain")
public string r2() {
return "<h2>我是二级标题</h2>";
}
四、返回json
后端⽅法返回结果为对象直接就是返回的json。
源码:
@requestmapping("/r3")
public person r3() {
person person = new person();
person.setid(1);
person.setname("zhangsan");
person.setpassword("123");
return person;
}
结果:

五、httpservletresponse设置状态码
spring mvc会根据我们⽅法的返回结果⾃动设置响应状态码, 程序员也可以⼿动指定状态码。
通过类httpservletresponse下的setstatue来设置。
源码:
@requestmapping("/r4")
public string r4(httpservletresponse response) {
response.setstatus(404);
return "设置状态码成功";
}
结果:

六、设置header
6.1 httpservletresponse设置
通过类httpservletresponse下的setheader来设置。
在方法中前一个参数是header的参数名,后一个是值。
源码:
@requestmapping("/r5")
public string r5(httpservletresponse response) {
response.setheader("myheader","444");
return "设置header成功";
}
结果:

6.2 @requestmapping设置
@requestmapping的组成如下:

我们通过设置 produces属性的值, 设置响应的报头content-type。
源码:
@requestmapping(value = "/r6",produces = "application/json")
public string r6() {
return "{\"success\":true}";
}
结果:

到此这篇关于springmvc返回http响应的实现的文章就介绍到这了,更多相关springmvc返回http响应内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论