Java基础之HttpServletResponse响应(2)

public class Servlet02 extends HttpServlet {
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        response.getWriter().write("Servlet02");
    }
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doGet(request, response);
    }

}

六、通过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"),就可以解决页面输出中文乱码问题。

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
    <a href="https://www.linuxidc.com/WEB0/DownloadServlet?file=乱码.png">乱码.png</a>
    <a href="https://www.linuxidc.com/WEB0/DownloadServlet?file=a.txt">a.txt</a>
    <a href="https://www.linuxidc.com/WEB0/DownloadServlet?file=a.zip">a.zip</a>
</body>
</html>

package com.Oracle;

import java.io.FileInputStream;
import java.io.IOException;
import java.net.URLEncoder;

import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import sun.misc.BASE64Encoder;


public class DownloadServlet extends HttpServlet {
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //服务器获取文件名(文件名是中文的话,获取的时候就成了乱码了)
        String filename = request.getParameter("file");//??.png
        //get请求中---解决文件名中文乱码问题
        filename =new String(filename.getBytes("ISO-8859-1"),"UTF-8");//乱码.png
       
        //获取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");               
        }
        //告知浏览器文件的类型(响应体)
        response.setContentType(getServletContext().getMimeType(filename));
        //告知浏览器以附件的方式提供下载功能 而不是解析
        response.setHeader("Content-Disposition","attachment;filename="+filenameEncoder);
        //服务器获取后开始进行复制的程序:获取字节输出流
        ServletOutputStream sos = response.getOutputStream();
        //获取数据源的绝对路径
        String realpath = getServletContext().getRealPath("download/"+filename);
        //获取字节输入流
        FileInputStream fis =new FileInputStream(realpath);
        //开始复制
        byte[] bytes=new byte[1024];
        int len=0;
        while((len=fis.read(bytes))!=-1){
            sos.write(bytes, 0, len);
        }
        //释放资源
        fis.close();
    }
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doGet(request, response);
    }

}

2、response细节点:

①、response获得的流不需要手动关闭,web容器(tomcat容器)会帮助我们关闭,

②、getWriter和getOutputStream不能同时调用

③、重定向语句一般作为终结代码

Linux公社的RSS地址https://www.linuxidc.com/rssFeed.aspx

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/9a47469aef06609cfc9a2f9f99bec82b.html