jsp 导出excel文件,文件名含有中文 出现乱码 解决方案
方案一:
public String toUtf8String(String s){
StringBuffer sb = new StringBuffer();
for (int i=0;i<s.length();i++){
char c = s.charAt(i);
if (c >= 0 && c <= 255){sb.append(c);}
else{
byte[] b;
try { b = Character.toString(c).getBytes("utf-8");}
catch (Exception ex) {
System.out.println(ex);
b = new byte[0];
}
for (int j = 0; j < b.length; j++) {
int k = b[j];
if (k < 0) k += 256;
sb.append("%" + Integer.toHexString(k).toUpperCase());
}
}
}
return sb.toString();
}
测试方法:
String utf8;
try {
utf8 = new String(toUtf8String("全部合计_2011_4_17.xls").getBytes(), "UTF-8");
System.out.println("utf8******1**********"+utf8);//结果为:utf8******1**********%E5%85%A8%E9%83%A8%E5%90%88%E8%AE%A1_2011_4_17.xls
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
原理是:浏览器或迅雷它们不能直接识别中文字符,虽然你在导出页面上已把中文字符转为utf-8编码格式了,但是浏览器或迅雷还是不能识别的,只有类似%E5%85%A8%E9%83%A8%E5...编码格式它们才能识别。
方案二: URLEncoder.encode(f.getName(),"UTF-8");
原理: 把要被下载的文件的文件名转成utf-8格式的,能够让浏览器或迅雷识别的名字。
分享到:
相关推荐
本篇文章主要探讨了在使用JSP导出Excel时可能会遇到的一般性问题及其解决方案。 一、导出Excel的基本流程 1. 数据准备:首先,你需要从数据库或其他数据源获取要导出的数据,将其组织成二维数组或集合。 2. 创建...
### 使用JSP下载Excel文件知识点解析 #### 一、引言 在Web开发中,经常需要将服务器上生成的数据导出为Excel文件供用户下载。本文档将详细介绍如何使用Java Server Pages (JSP) 实现从服务器端下载Excel文件到...
"导出jsp页面为excel文档"这个话题,主要涉及的是如何在Java环境中,利用JSP(JavaServer Pages)技术生成Excel报表,并通过浏览器以下载或直接打开的方式呈现给用户。 首先,我们要明白,JSP是一种基于Java的...
- **Service代码**:实现导出Excel的具体逻辑,包括解决文件名中文乱码问题。 - **DAO代码**:可能涉及查询数据库获取需要导出的数据。 5. **JSP页面** - **index.jsp**:主页,提供导出链接或按钮。 - **list....
4. **导出文件名及内容支持中文**:导出的文件名和文件内容在中文环境下可能出现乱码,这不仅影响用户的使用体验,还可能导致文件无法正常打开。 #### 二、解决方案及方法 接下来详细介绍如何解决上述问题: 1. *...
在IT领域,特别是Web开发与办公自动化处理中,将数据从服务器端导出为常见的办公文件格式,如Word(.doc或.docx)和Excel(.xls或.xlsx),是一项非常实用且频繁的需求。这一过程涉及到的技术包括但不限于Java、...
在Java Web开发中,处理Excel文件的读写是一项常见的任务,尤其在企业级应用中,数据导入导出的需求频繁出现。Java提供了多种库来支持这种功能,其中jxl是一个广泛使用的开源工具,允许开发者通过Java代码操作Excel...
在本文的示例中,使用Blob对象下载文件,特别是在以POST请求方式导出Excel时非常有用。通常,后端会返回一个包含文件内容的输出流,这些内容可能是ArrayBuffer或Blob格式。前端接收到数据后,可以通过Blob对象对这些...
给出的部分代码示例展示了如何在JSP(Java Server Pages)中设置响应头,以便通过IE浏览器导出数据到Excel文件: ```jsp <%@page contentType="application/vnd.ms-excel;charset=UTF-8" language="java"%> ...
Java 创建及在线打开或下载 Excel 文件是常见的需求,特别是在 Web 应用中,例如报表生成、数据导出等场景。以下将详细介绍如何使用 Java 实现这个功能,主要涉及的库是 JExcelApi。 JExcelApi 是一个开源的 Java ...
值得注意的是,对于中文支持存在局限,可能会出现乱码问题。 - `exportFileName='我自定义的文件名'`:自定义导出文件的名称,便于识别和管理。 - `exportAtClient='0'`:确定是否仅在客户端执行导出操作,此处设置...
- **解决方法**:直接替换原有的JSP文件即可,通常无需重启服务。 ##### 3.8 在OA界面上出现???workTask_baseInfo_list_label1??? - **问题描述**:在OA界面中出现未知的标签或文本。 - **解决方法**:检查国际化...
7. 数据库对象导出:通常,数据库对象可以导出到Microsoft Excel格式,便于分析和处理(正确答案:B)。 8. 电子邮件乱码:收到的邮件出现乱码通常是由于编码不统一,导致字符无法正确显示(正确答案:D)。 9. ...