美文网首页
web14 HttpServletResponse

web14 HttpServletResponse

作者: 路人爱早茶 | 来源:发表于2017-09-22 18:26 被阅读0次
    • response是在请求网址时候和request一起创建好的只不过是空的,在doget方法中写入返回的数据(写给的是response,之后toncat将响应行响应头一起和数据封装成返回给客户端的响应)
    • 302是为了代码重定向使用的?重定向请求一次以上服务器
    5秒之后跳转到百度:不常用因为是服务器端写死页面不会有动态效果
    response.setHeader("refresh", "5,url=http://www.baidu.com");
    
    • html等辅助输入提示
      继续打开web→html Files→Editor→Content Assist
      修改Prompt when these characters are inserted:<=.abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVW
      js 类似值 :.abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVW

    • 写图片先有字节输入流需要去读图片(绝对地址用相对地址去获得),写时候用快速方法byte【1024】,while((len=in.read(byte))>0){out.write(byte,0,len)}

    1.响应的response的运行流程

    • 因为response代表响应,所以我们可以通过该对象分别设置Http响应的响应行,响 应头和响应体
    Paste_Image.png
    • 通过response设置响应行
      设置响应行的状态码
      setStatus(int sc)
    • 通过response设置响应头(add增加,set覆盖)
    addHeader(String name, String value) 
    addIntHeader(String name, int value) 
    addDateHeader(String name, long date) 
    setHeader(String name, String value) ***
    setDateHeader(String name, long date) 
    setIntHeader(String name, int value)
    
    • 通过response设置响应体
    (1)响应体设置文本
    PrintWriter getWriter()
    获得字符流,通过字符流的write(String s)方法可以将字符串设置到response  缓冲区中,随后Tomcat会将response缓冲区中的内容组装成Http响应返回给浏览    器端。
    
    关于设置中文的乱码问题
    原因:response缓冲区的默认编码是iso8859-1,此码表中没有中文,可以通过 response的setCharacterEncoding(String charset) 设置response的编码
    
    但我们发现客户端还是不能正常显示文字
    原因:我们将response缓冲区的编码设置成UTF-8,但浏览器的默认编码是本地系  统的编码,因为我们都是中文系统,所以客户端浏览器的默认编码是GBK,我们可以  手动修改浏览器的编码是UTF-8。
    
    我们还可以在代码中指定浏览器解析页面的编码方式,
    通过response的setContentType(String type)方法指定页面解析时的编码是UTF-8
    response.setContentType("text/html;charset=UTF-8");
    
    上面的代码不仅可以指定浏览器解析页面时的编码,同时也内含        setCharacterEncoding的功能,所以在实际开发中只要编写    response.setContentType("text/html;charset=UTF-8");就可以解决页面输出中文乱码问题。
    
    (2)响应头设置字节
    ServletOutputStream  getOutputStream()
    获得字节流,通过该字节流的write(byte[] bytes)可以向response缓冲区中写入字  节,在由Tomcat服务器将字节内容组成Http响应返回给浏览器。
    

    2.文件下载

    -----------重定向路径----
    设置两个头
    //  设置状态码302
    //      response.setStatus(302);
    //      重定向路径
    //      response.setHeader("Location",   "/web14/servlet2");
    //      效果一样
    //  response.sendRedirect( "/web14/servlet2");
    //5秒后跳转
        response.setHeader("refresh", "5,url=http://www.baidu.com");
    -------乱码问题产生-------
    有两方面:tomcat读取时候和读取完客户端展示时候
    //      告诉tomcat存时候要utf-8
    response.setCharacterEncoding("UTF-8");
    //      告诉浏览器取时候要utf-8,仅这一句就可以让tomcat存时候也用u8
    //response.setHeader("content-Type", "text/html;charset=utf-8");
    //等同于
    //response.setContentType( "text/html;charset=utf-8");
        PrintWriter writer = response.getWriter();
        writer.write("你好");
        
    ----------相当于上传图片浏览器展示---------------
    public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            // 使用response获得字节输出流
            ServletOutputStream out = response.getOutputStream();
            // 获得文件字节流
            String path = getServletContext().getRealPath("a.jpg");
            FileInputStream in = new FileInputStream(path);
            int len = 0;
            byte[] butter = new byte[1024];
            while ((len = in.read(butter)) > 0) {
                out.write(butter, 0, len);
            }
            in.close();
            out.close();
        }
    -------------下载文件---------
    
    ----展示的下载页面-------
    <a href="/web14/fileDownload?filename=a.flv">a.flv</a><br>
    参数filename让response获取到文件名字
    fileDownload是xml中url
    ----xml------
    <servlet-mapping>
        <servlet-name>FileDownload</servlet-name>
        <url-pattern>/fileDownload</url-pattern>
      </servlet-mapping>
    --------servlet-------
    public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    主要修改两个头ContentType和Content-Disposition
            // 从html的参数或取名字
            String name = request.getParameter("filename");
            // 告诉浏览器下载文件的类型参数是从全局web.xml中的mime类型转化
            // response.setContentType(this.getServletContext().getMimeType(name));
            // 告诉浏览器要附件下载而不是解开
            response.setHeader("Content-Disposition", "attachment;filename=" + name);
            FileInputStream in = new FileInputStream(this.getServletContext().getRealPath("download/" + name));
            ServletOutputStream out = response.getOutputStream();
            int len = 0;
            byte[] buffer = new byte[1024];
            while ((len = in.read(buffer)) > 0) {
                out.write(buffer, 0, len);
            }
            in.close();
            out.close();// out是response获取会自动被关闭
        }
    
    • 1)告知浏览器文件的类型:response.setContentType(文件的MIME类型);(不写也可以?)
    • 2)告示浏览器文件的打开方式是下载:
      response.setHeader("Content-Disposition","attachment;filename=文件名称");
    • 但是,如果下载中文文件,页面在下载时会出现中文乱码或不能显示文件名的情况, 原因是不同的浏览器默认对下载文件的编码方式不同,ie是UTF-8编码方式,而火狐 浏览器是Base64编码方式。所里这里需要解决浏览器兼容性问题,解决浏览器兼容 性问题的首要任务是要辨别访问者是ie还是火狐(其他),通过Http请求体中的一个属性可以辨别其中agent就是请求头User-Agent的值
    Paste_Image.png
    • 也就是在tomcat识别时候转成u8(new String(filename.getBytes("ISO8859-1"), "UTF-8")),在客户端识别之前根据不同客户端以不同形式转码(if (agent.contains("MSIE")) {)
    protected void doGet(HttpServletRequest request, HttpServletResponse response)
                throws ServletException, IOException {
    
            // *******文件名称是中文的下载*******
            // 获得要下载的文件的名称
            String filename = request.getParameter("filename");// ????.jpg
            // 解决获得中文参数的乱码----
            filename = new String(filename.getBytes("ISO8859-1"), "UTF-8");// 美女.jpg
            // 获得请求头中的User-Agent
            String agent = request.getHeader("User-Agent");
            // 根据不同浏览器进行不同的编码
            String filenameEncoder = "";
            if (agent.contains("MSIE")) {
                // IE浏览器
                filenameEncoder = URLEncoder.encode(filename, "utf-8");
                filenameEncoder = filenameEncoder.replace("+", " ");
            } else if (agent.contains("Firefox")) {
                // 火狐浏览器
                BASE64Encoder base64Encoder = new BASE64Encoder();
                filenameEncoder = "=?utf-8?B?" + base64Encoder.encode(filename.getBytes("utf-8")) + "?=";
            } else {
                // 其它浏览器
                filenameEncoder = URLEncoder.encode(filename, "utf-8");
            }
            // 要下载的这个文件的类型-----客户端通过文件的MIME类型去区分类型      response.setContentType(this.getServletContext().getMimeType(filename));
            // 告诉客户端该文件不是直接解析 而是以附件形式打开(下载)----filename="+filename 客户端默认对名字进行解码
            response.setHeader("Content-Disposition", "attachment;filename=" + filenameEncoder);
            // 获取文件的绝对路径原来中文名字否则找不到
            String path = this.getServletContext().getRealPath("download/" + filename);
            // 获得该文件的输入流
            InputStream in = new FileInputStream(path);
            // 获得输出流---通过response获得的输出流 用于向客户端写内容
            ServletOutputStream out = response.getOutputStream();
            // 文件拷贝的模板代码
            int len = 0;
            byte[] buffer = new byte[1024];
            while ((len = in.read(buffer)) > 0) {
                out.write(buffer, 0, len);
            }
            in.close();
            // out.close();
        }
    
    • //response.getOutputStream();
      //response.getWriter();全局可以认为两种是一个不可以同时写(就算有多个servlet)
    • 默认重定向就是编码结束时候

    相关文章

      网友评论

          本文标题:web14 HttpServletResponse

          本文链接:https://www.haomeiwen.com/subject/wzlasxtx.html