java web导出csv文件中文乱码问题解决

部署运行你感兴趣的模型镜像

今天用java web 导出csv文件时,导出的csv文件内容乱码.  之前因为过滤器一直用utf-8,最后在代码中设置ContentType时试了下gbk居然没乱码了. 

猜想大概原因是本地打开的格式为gbk吧.

 

相关代码:

import java.io.IOException;
import java.net.URLEncoder;
import java.util.Date;
import java.util.List;

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

import com.itheima.domain.Sale;
import com.itheima.factory.BasicFactory;
import com.itheima.service.OrderService;

public class SaleListServlet extends HttpServlet {

	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		String fileName = new String(
				("销售榜单_" + new Date().toLocaleString() + ".csv").getBytes("GBK"),
				"ISO-8859-1");
		//下面这段必须放在Writer前,否则还是乱码
		response.setContentType(this.getServletContext().getMimeType(fileName) + ";charset=gbk");
		// response.setContentType("application/csv;charset=gbk");
		// 获取销售榜单
		OrderService service = BasicFactory.getFactory().getInstance(OrderService.class);
		List<Sale> saleList = service.getSaleList();

		// 生成数据
		StringBuffer buffer = new StringBuffer();
		buffer.append("商品id,商品名称,销售数量\r\n");
		for (Sale sale : saleList) {
			buffer.append(sale.getId() + "," + sale.getName() + "," + sale.getSalenum() + "\r\n");
		}
		String str = buffer.toString();
		response.getWriter().write(str);

		// 提供下载

		response.setHeader("Content-disposition", "attachment;filename=" + fileName);

	}

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {

		doGet(request, response);

	}

}


 

您可能感兴趣的与本文相关的镜像

Seed-Coder-8B-Base

Seed-Coder-8B-Base

文本生成
Seed-Coder

Seed-Coder是一个功能强大、透明、参数高效的 8B 级开源代码模型系列,包括基础变体、指导变体和推理变体,由字节团队开源

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值