日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

baseresponse响应类_Java response响应体和文件下载实现原理

發布時間:2023/12/4 java 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 baseresponse响应类_Java response响应体和文件下载实现原理 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

通過response 設置響應體:

響應體設置文本:

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"),就可以解決頁面輸出中文亂碼問題。

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);

}

}

pageEncoding="UTF-8"%>

Insert title here

a.txt

a.wmv

科比.png

a.zip

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

總結

以上是生活随笔為你收集整理的baseresponse响应类_Java response响应体和文件下载实现原理的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。