Java response響應(yīng)體和文件下載實現(xiàn)原理
通過response 設(shè)置響應(yīng)體:
響應(yīng)體設(shè)置文本:
PrintWriter getWriter()
獲得字符流,通過字符流的write(String s)方法可以將字符串設(shè)置到response 緩沖區(qū)中,隨后Tomcat會將response緩沖區(qū)中的內(nèi)容組裝成Http響應(yīng)返回給瀏覽 器端。
關(guān)于設(shè)置中文的亂碼問題
原因:response緩沖區(qū)的默認編碼是iso8859-1,此碼表中沒有中文,可以通過 response的setCharacterEncoding(String charset) 設(shè)置response的編碼,
但我們發(fā)現(xiàn)客戶端還是不能正常顯示文字。
原因:我們將response緩沖區(qū)的編碼設(shè)置成UTF-8,但瀏覽器的默認編碼是本地系統(tǒng)的編碼,因為我們都是中文系統(tǒng),所以客戶端瀏覽器的默認編碼是GBK,我們可以手動修改瀏覽器的編碼是UTF-8。
我們還可以在代碼中指定瀏覽器解析頁面的編碼方式,通過response的setContentType(String type)方法指定頁面解析時的編碼是UTF-8。
response.setContentType('text/html;charset=UTF-8');
上面的代碼不僅可以指定瀏覽器解析頁面時的編碼,同時也內(nèi)含 setCharacterEncoding的功能,所以在實際開發(fā)中只要編寫 response.setContentType('text/html;charset=UTF-8'),就可以解決頁面輸出中文亂碼問題。
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 { //服務(wù)器獲取文件名(文件名是中文的話,獲取的時候就成了亂碼了) 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'); } //告知瀏覽器文件的類型(響應(yīng)體) response.setContentType(getServletContext().getMimeType(filename)); //告知瀏覽器以附件的方式提供下載功能 而不是解析 response.setHeader('Content-Disposition','attachment;filename='+filenameEncoder); //服務(wù)器獲取后開始進行復(fù)制的程序:獲取字節(jié)輸出流 ServletOutputStream sos = response.getOutputStream(); //獲取數(shù)據(jù)源的絕對路徑 String realpath = getServletContext().getRealPath('download/'+filename); //獲取字節(jié)輸入流 FileInputStream fis =new FileInputStream(realpath); //開始復(fù)制 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); }}
<%@ 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='http://www.cgvv.com.cn/WEB02/DownLoadServlet?filename=a.txt' rel='external nofollow' >a.txt</a> <a href='http://www.cgvv.com.cn/WEB02/DownLoadServlet?filename=a.wmv' rel='external nofollow' >a.wmv</a> <a href='http://www.cgvv.com.cn/WEB02/DownLoadServlet?filename=科比.png' rel='external nofollow' >科比.png</a> <a href='http://www.cgvv.com.cn/WEB02/DownLoadServlet?filename=a.zip' rel='external nofollow' >a.zip</a></body></html>
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
