SpringBoot系列教程web篇之返回文本、网页、图片的操作姿势

前面几篇博文介绍了如何获取get/post传参,既然是http请求,一般也都是有来有往,有请求参数传递,就会有数据返回。那么我们通过springboot搭建的web应用,可以怎样返回数据呢?

本篇将主要介绍以下几种数据格式的返回实例

  • 返回文本

  • 返回数组

  • 返回json串

  • 返回静态网页

  • 返回图片

I. 环境搭建

首先得搭建一个web应用才有可能继续后续的测试,借助SpringBoot搭建一个web应用属于比较简单的活;

创建一个maven项目,pom文件如下


   
   
  1. <parent>

  2. <groupId>org.springframework.boot</groupId>

  3. <artifactId>spring-boot-starter-parent</artifactId>

  4. <version>2.1.7</version>

  5. <relativePath/> <!-- lookup parent from update -->

  6. </parent>

  7. <properties>

  8. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>

  9. <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>

  10. <spring-cloud.version>Finchley.RELEASE</spring-cloud.version>

  11. <java.version>1.8</java.version>

  12. </properties>

  13. <dependencies>

  14. <dependency>

  15. <groupId>org.springframework.boot</groupId>

  16. <artifactId>spring-boot-starter-web</artifactId>

  17. </dependency>

  18. </dependencies>

  19. <build>

  20. <pluginManagement>

  21. <plugins>

  22. <plugin>

  23. <groupId>org.springframework.boot</groupId>

  24. <artifactId>spring-boot-maven-plugin</artifactId>

  25. </plugin>

  26. </plugins>

  27. </pluginManagement>

  28. </build>

  29. <repositories>

  30. <repository>

  31. <id>spring-milestones</id>

  32. <name>Spring Milestones</name>

  33. <url>https://repo.spring.io/milestone</url>

  34. <snapshots>

  35. <enabled>false</enabled>

  36. </snapshots>

  37. </repository>

  38. </repositories>

依然是一般的流程,pom依赖搞定之后,写一个程序入口


   
   
  1. /**

  2. * Created by @author yihui in 15:26 19/9/13.

  3. */

  4. @SpringBootApplication

  5. public class Application {

  6. public static void main(String[] args) {

  7. SpringApplication.run(Application.class);

  8. }

  9. }

II. 数据返回姿势实例

以下返回实例都放在同一个Controller中,具体定义如下


   
   
  1. @Controller

  2. @RequestMapping(path = "data")

  3. public class DataRespRest {

  4. }

1. 文本返回

这个属于基础功能了,发起请求,返回一串文本,在SpringMVC的体系中,要实现这种通常的写法通常是直接定义方法的返回为String;当然还有另外一种非常基础的写法,直接将返回的数据通过 HttpServletResponse写入到输出流中

下面给出这两种写法的实例


   
   
  1. @ResponseBody

  2. @GetMapping(path = "str")

  3. public String strRsp() {

  4. return "hello " + UUID.randomUUID().toString();

  5. }

  6. @ResponseBody

  7. @GetMapping(path = "str2")

  8. public void strRsp2(HttpServletResponse response) throws IOException {

  9. Map<String, String> ans = new HashMap<>(2);

  10. ans.put("a", "b");

  11. ans.put("b", "c");

  12. response.getOutputStream().write(JSON.toJSONString(ans).getBytes());

  13. response.getOutputStream().flush();

  14. }

注意上面的实现中,方法上面多了一个注解 @ResponseBody,这个表示返回数据,而不是视图(后面会详细说明)

strRsp2的输出借助了FastJson来实现将map序列化为json串,然后写入输出流

实例访问如下

从上面的输出也可以看出,第一种返回方式, ResponseHeadersContent-Type:text/html;charset=UTF-8;而第二种方式则没有这个响应头,需要我们自己主动设置(这里注意一下即可,在后面的返回图片中有实例)

2,返回数组

前面请求参数的博文中,我们看到请求参数允许传入数组,那么我们返回可以直接返回数组么?讲道理的话,应该没啥问题


   
   
  1. /**

  2. * 返回数组

  3. *

  4. * @return

  5. */

  6. @ResponseBody

  7. @GetMapping(path = "ary")

  8. public String[] aryRsp() {

  9. return new String[]{UUID.randomUUID().toString(), LocalDateTime.now().toString()};

  10. }

然后请求输出为

注意下响应头,为 application/json, 也就是说SpringMVC将数组当成json串进行返回了

3. Bean返回

在我们实际的业务开发中,这种应该属于非常常见的使用姿势了,直接返回一个POJO,调用者接收的是一个json串,可以很容易的反序列化为需要的对象


   
   
  1. /**

  2. * 返回POJO

  3. *

  4. * @return

  5. */

  6. @ResponseBody

  7. @GetMapping(path = "bean")

  8. public DemoRsp beanRsp() {

  9. return new DemoRsp(200, "success", UUID.randomUUID().toString() + "--->data");

  10. }


4. 网页返回

前面都是直接返回数据,但是我们平常在使用浏览器,更多的是发起一个请求,然后返回一个网页啊,难道说springmvc不能直接返回网页么?

当然返回网页怎么可能会不支持,(题外话:个人感觉在前后端分离逐渐流行之后,直接由后端返回网页的case不太多了,前端和后端作为独立的项目部署,两者之间通过json串进行交流;这里扯远了),我们下面看一下SpringMVC中如何返回网页

我们可以从上面直接返回字符串的case中,得到一个思路,如果我直接返回一个html文本,会怎样?既然返回 content-typetext/html,那浏览器应该可以解析为网页的,下面实测一下


   
   
  1. @ResponseBody

  2. @GetMapping(path = "html")

  3. public String strHtmlRsp() {

  4. return "<html>\n" + "<head>\n" + " <title>返回数据测试</title>\n" + "</head>\n" + "<body>\n" +

  5. "<h1>欢迎欢迎,热烈欢迎</h1>\n" + "</body>\n" + "</html>";

  6. }

测试如下

浏览器发起请求之后,将我们返回的html文本当做网页正常渲染了,所以我们如果想返回网页,就这么干,没毛病!

上面这种方式虽然说可以返回网页,然而在实际业务中,如果真要我们这么干,想想也是可怕,还干什么后端,分分钟全栈得了!!!

下面看一下更常规的写法,首先我们需要配置下返回视图的前缀、后缀, 在 application.yml配置文件中添加如下配置


   
   
  1. spring:

  2. mvc:

  3. view:

  4. prefix: /

  5. suffix: .html

然后我们的静态网页,放在资源文件的static目录下,下面是我们实际的项目截图,index.html为我们需要返回的静态网页

接下来就是我们的服务接口


   
   
  1. /**

  2. * 返回视图

  3. *

  4. * @return

  5. */

  6. @GetMapping(path = "view")

  7. public String viewRsp() {

  8. return "index";

  9. }

注意下上面的接口,没有 @ResponseBody注解,表示这个接口返回的是一个视图,会从static目录下寻找名为 index.html(前缀路径和后缀是上面的application.yml中定义)的网页返回

实测case如下

5. 图片返回

图片返回与前面的又不太一样了,上面介绍的几种case中,要么是返回文本,要么返回视图,而返回图片呢,更多的是返回图片的字符数组,然后告诉浏览器这是个图片,老哥你按照图片渲染

直接返回二进制流,上面在介绍文本返回的两种方式中,有个直接通过 HttpServletResponse向输出流中写数据的方式,我们这里是不是可以直接这么用呢?

下面给出一个从网络下载图片并返回二进制流的实际case


   
   
  1. /**

  2. * 返回图片

  3. */

  4. @GetMapping(path = "img")

  5. public void imgRsp(HttpServletResponse response) throws IOException {

  6. response.setContentType("image/png");

  7. ServletOutputStream outStream = response.getOutputStream();

  8. String path = "https://spring.hhui.top/spring-blog/imgs/info/info.png";

  9. URL uri = new URL(path);

  10. BufferedImage img = ImageIO.read(uri);

  11. ImageIO.write(img, "png", response.getOutputStream());

  12. System.out.println("--------");

  13. }

注意下上面的实例case,首先设置了返回的 ContentType,然后借助 ImateIO来下载图片(个人不太建议这种写法,很容易出现403;这里演示主要是为了简单...),并将图片写入到输出流

实例演示如下

III 小结

1. 返回数据小结

本篇博文主要介绍了几种常见数据格式的返回使用姿势,本文更多的是一种使用方式的实例case演示,并没有涉及到底层的支持原理,也没有过多的提及如何设置响应头,web交互中常见的cookies/session也没有说到,这些将作为下篇的内容引入,恳请关注

下面做一个简单的小结

返回纯数据

  • 添加 @ResponseBody注解,则表示我们返回的是数据,而不需要进行视图解析渲染;

  • 如果一个controller中全部都是返回数据,不会返回视图时,我们可以在添加 @RestController注解,然后这个类中的接口都不需要添加 @ResponseBody注解了

  • 返回视图时,我们会根据接口返回的字符串,结合定义的前缀,后缀,到资源路径的static目录下寻找对应的静态文件返回

  • 可以直接通过向 HttpServletResponse的输出流中写数据的方式来返回数据,如返回图片常用这种case

2. 更多web系列博文

IV. 其他

0. 项目

  • 工程:https://github.com/liuyueyi/spring-boot-demo

  • 项目: https://github.com/liuyueyi/spring-boot-demo/blob/master/spring-boot/207-web-response

1. 一灰灰Blog

尽信书则不如,以上内容,纯属一家之言,因个人能力有限,难免有疏漏和错误之处,如发现bug或者有更好的建议,欢迎批评指正,不吝感激

下面一灰灰的个人博客,记录所有学习和工作中的博文,欢迎大家前去逛逛

  • 一灰灰Blog个人博客 https://blog.hhui.top

  • 一灰灰Blog-Spring专题博客 http://spring.hhui.to

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

一灰灰blog

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

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

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

打赏作者

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

抵扣说明:

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

余额充值