首页 > 编程语言 >JavaWeb笔记_Response对象

JavaWeb笔记_Response对象

时间:2024-07-18 17:56:10浏览次数:23  
标签:浏览器 String void 笔记 Response 响应 response JavaWeb

一.Response对象

1.1 Response对象概述

a.专门负责给浏览器响应信息(响应行,响应头,响应体)的对象

b.我们主要使用的是跟HTTP协议相关的Response对象:HTTPServletResponse,继承了ServletResponse,扩展了ServletResponse接口,提供了更多的方法,例如可以操作响应头,cookie等

1.2 Response对象设置响应行

   /**
     * HttpServletResponse中的方法:
     * void setStatus(int sc)
     * 设置响应状态码
     *  注意:我们一般不会去改变响应状态码,响应状态码一般由Tomcat设置
     */
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		response.setStatus(404);
		response.setStatus(500);
}

1.3.Response对象设置响应头

 /*
  * HttpServletResponse中的方法:
  * public void addHeader(String name, String value):可以添加响应头,一个响应头的key可以对应多 
    个value
  * public void setHeader(String name, String value):*  用给定名称和值设置响应头。如果已经设置 
    了头,则新值将重写以前的值。
   void setDateHeader(String name, long date):设置一个日期的响应头
  */
 protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //添加响应头
        //add可以重复叠加
        response.addHeader("name","zs");  //Name:zs
        response.addHeader("name","ls");  //Name:ls

        //set或直接覆盖key相同的所有value
        response.setHeader("name","ww");  //Name:ww 将zs和ls全部覆盖
    }

1.4 Response对象设置响应体

1.4.1 Response对象操作字符流:写文本类型数据
/**
 * HttpServletResponse中的方法:
 *   getWriter():可以获取一个字符输出流
 */
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		PrintWriter writer = response.getWriter();
		writer.write("<font color='red'>ResponseDemo03</font>");
		writer.write("<br/>");
		writer.write("<font color='blue'>ResponseDemo03</font>");
	}

 

1.4.2 字符类乱码解决方案

        /**
         * HttpServletResponse中的方法:
         *   getCharacterEncoding():获取Response中字符流缓冲区使用的默认码表
         *    1.Response底层使用的默认码表是ISO-8859-1(latin1)
         *    2.通过Response的setCharacterEncoding修改默认码表为UTF-8
         *         当我们write("你好")的时候,会把"你好"进行"UTF-8"编码(假设:CA E3 F5 D3 E5 E7)
         *         而我们的浏览器默认使用的是系统码表:GBK(一个中文对应两个字节),因此在解析"你好"
         *         会将你好的字节进行每两个字节解码 (CA E3 F5 D3 E5 E7=> 浣犲ソ)
         *    3.通过设置内容类型(设置响应头)来告知浏览器使用指定的码表解析响应体内容
         *    4.最终解决方案
         *      response.setContentType("text/html;charset=UTF-8");
         *      1.会自动设置Response中字符流缓冲区使用的码表
         *      2.告知浏览器使用何种码表解析响应体中的内容
         */
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //解决字符类乱码问题

        //获取response中字符缓冲区使用的默认码表
        System.out.println(response.getCharacterEncoding()); //ISO-8859-1

        //通过setContentType()方法进行解决
        response.setContentType("text/html;charset=UTF-8");
        //response.setHeader("Content-Type","text/html;charset=UTF-8");
        System.out.println(response.getCharacterEncoding()); //UTF-8
        response.getWriter().write("设置后:你好");
    }

1.4.3 Response对象操作字节流:写多媒体类型数据
/**
 * HttpServletResponse中的方法
 *   getOutputStream():获取一个字节输出流
 * ServletContext中的方法
 *   getMimeType(String fileName):根据指定的名称返回对应的MIME类型
 */
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //获取字节输出流
        ServletOutputStream os = response.getOutputStream();
        BufferedOutputStream bos = new BufferedOutputStream(os);

        //获取响应内容的MIME类型
        String mimeType = getServletContext().getMimeType("1.jpg"); // image/jpeg
        //告知浏览器响应内容的MIME类型,让浏览器知道怎么处理
        response.setContentType(mimeType);

        //利用字节输入流获取本地文件
        InputStream ras = getServletContext().getResourceAsStream("/img/1.jpg"); //虚拟路径
        BufferedInputStream bis = new BufferedInputStream(ras);
        int x;

        //写入文件
        while((x=bis.read())!=-1){
            os.write(x);
        }
    }

1.5 利用Response重定向

/**
 * 需求:当浏览器请求ResponseDemo06的时候,让浏览器重定向到ResponseDemo07
 *   void sendRedirect(String location):指定一个路径
 * 底层会设置状态码为302,并且设置响应头Location:/day10_Response/demo07
 */
   protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //重定向:浏览器发出两次请求
        //需要加Application Context
        response.sendRedirect("/day10_Response/response04");
    }

 

二.MIME类型(大类型/小类型)

 1.媒体类型一种标准,用来表示文档,文件或字节流的性质和格式
  2.浏览器中通常使用MIME类型(而不是文件扩展名),硬盘上的文件的扩展名都对应的有MIME类型
    可以用来确定如何处理服务端响应给浏览器的资源

三.下载文件案例

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>下载</title>
</head>
<body>
    <a href="/day10_Response/response06?filename=1.jpg">1.jpg</a><br>
    <a href="/day10_Response/response06?filename=2.txt">2.txt</a><br>
    <a href="/day10_Response/response06?filename=3.pdf">3.pdf</a><br>
    <a href="/day10_Response/response06?filename=美女.jpg">美女.jpg</a><br>
</body>
</html>
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //获取filename参数以及MIME类型
        String filename = request.getParameter("filename");
        String mimeType = getServletContext().getMimeType(filename);

        //判断浏览器类型来解决不同的中文乱码问题
        String userAgent = request.getHeader("User-Agent");
        String newFileName = null;
        if (userAgent.contains("MSIE") || userAgent.contains("Edge") || userAgent.contains("Trident")) {
            //说明是Microsoft浏览器我们需要采用UTF-8编码
            newFileName = URLEncoder.encode(filename, "UTF-8");
        } else {
            //说明是其它浏览器(chrome,FireFox...)我们需要先获取文件名的UTF-8字节,然后在对这些字节进行ISO-8859-1解码
            newFileName = new String(filename.getBytes("UTF-8"), "ISO-8859-1");
        }

        //设置响应头
        response.setContentType(filename);
        response.setHeader("Content-Disposition","attachment;filename="+newFileName);// 将要保存的文件名

        //获取字节输出流
        ServletOutputStream os = response.getOutputStream();
        BufferedOutputStream bos = new BufferedOutputStream(os);

        //通过字节输入流读取文件
        InputStream ras = getServletContext().getResourceAsStream("/download/" + filename);
        BufferedInputStream bis = new BufferedInputStream(ras);
        int x;
        //写入文件
        while ((x= bis.read())!=-1){
            bos.write(x);
        }
    }

标签:浏览器,String,void,笔记,Response,响应,response,JavaWeb
From: https://blog.csdn.net/m0_65469669/article/details/140520688

相关文章

  • OI学习笔记(C++)
    笔记完整版链接参照oi.wiki整理了基础dp的一些笔记:学习笔记+模板(Adorable_hly)(自己结合网络和做题经验总结的,dalao勿喷)第一大板块:DP动态规划适用场景:1.最优化原理:若该问题所包含的子问题解是最优的,就称该问题具有最优子结构,满足最优化原理。2.无后效性:指某一阶段的状......
  • HP笔记本驱动安装教程
    HP电源管理器类型:软件-解决方法说明:HP电源管理器提供了基础的电源轻松管理软件,该软件支持本地或远程管理员管理峰值电源设置。该软件包适用于运行受支持的操作系统的受支持计算机系统。修复和增强:-更新了HPPowerManager软件。-提供了ICS检测与安装。-将Fusio......
  • [MAUI 项目实战] 笔记App:程序设计
    前言有人说现在记事类app这么多,市场这么卷,为什么还想做一个笔记类App?一来,去年小孩刚出生,需要一个可以记录喂奶时间的app,发现市面上没有一款app能够在两步内简单记录一个时间,可能iOS可以通过备忘录配合捷径做到快速记录,但是安卓上就没有类似的app。二是,自去年做的音乐播放器以来......
  • 设计模式之适配器模式(学习笔记)
    定义 适配器模式是一种结构型设计模式,它允许将一个类的接口转换为客户端希望的另一个接口。适配器使得原本由于接口不兼容而不能一起工作的类可以协同工作。通过创建适配器类,可以将现有类的接口转换成目标接口,从而使这些类能够在一起工作。为什么使用适配器模式兼容性适......
  • 吴恩达深度学习课程笔记Lesson03
    第三周:浅层神经网络(Shallowneuralnetworks)文章目录第三周:浅层神经网络(Shallowneuralnetworks)3.1神经网络概述(NeuralNetworkOverview)3.2神经网络的表示(NeuralNetworkRepresentation)3.3计算一个神经网络的输出(ComputingaNeuralNetwork'soutput)3.4多样......
  • xxe学习笔记
    什么是xxeXXE(XMLExternalEntityInjection)全称为XML外部实体注入,由于程序在解析输入的XML数据时,解析了攻击者伪造的外部实体而产生的。例如PHP中的simplexml_load默认情况下会解析外部实体,有XXE漏洞的标志性函数为simplexml_load_string()。当允许引用外部实体时,通过构造恶......
  • python笔记:赋值,浅拷贝和深拷贝
    在Python中,变量赋值、浅拷贝和深拷贝在处理对象时有不同的行为和应用场景。以下是它们的详细区别:1.赋值赋值操作只是创建了一个新的引用(别名)来指向同一个对象。也就是说,赋值操作并不创建新的对象,原始对象和赋值后的变量指向同一块内存区域。a=[1,2,3]b=a#b是a......
  • PointNet笔记
    可能遇到的问题在windows上运行pointnet的代码时,可能会遇到一些问题:1.比如提示OSError:nofilewithexpectedextension,这是因为可视化的show3d_balls.py文件运行不了,具体的解决方法可以看这篇文章:https://blog.51cto.com/u_16213693/7738038。2.由于作者的pointnet所用的p......
  • Halcon的学习笔记(一)——非线性字符识别
    Halcon非线性模式的字符识别(ocr_cd_print_polar_trans.hdev例程分析)Halcon的学习笔记(一)——非线性字符识别项目上需要对非线性模式的字符进行识别,halcon中包含的例程,我搜了一下,网上对于该例程的解析比较少,因此自己便记录了一下自己的学习例程,也算自己的学习笔记。1.什......
  • 用Nginx反向代理之后,swagger出现no response from server错误的解决办法
    问题描述:本地运行项目打开swaager可以用,但是上传到服务器用nginx做反向代理的时候返回"error":"noresponsefromserver",且网址有端口,swaager的请求url端口丢失,使用了默认80端口  问题原因:因为在配置nginx反向代理的时候,没注意到配置代理的端口,导致端口丢失!解决方案:使......