Jsp输出excel文档和中文乱码问题的解决

开发 后端
本文介绍Jsp输出excel文档和中文乱码问题的解决,包括写一个JSP,来利用Test这个javabean输出excel文档。

写一个javaBean,利用JExcelApi来动态生成excel文档,我这里写一个最简单的,示意性的。复杂的你可能还要查询数据库什么的。

  1. package com.jagie.test
  2. import java.io. 
  3. import jxl.
  4. import jxl.write.
  5. import jxl.format.
  6. import java.util.
  7. import java.awt.Color
  8. public class Test 

写一个JSP,来利用Test这个javabean输出excel文档。

  1. <%@page import="com.jagie.test.Test" %> 
  2. <%  
  3. response.reset();  
  4. response.setContentType("application/vnd.ms-excel");  
  5. Test.writeExcel(response.getOutputStream());  
  6. %> 

这样就大功告成了,你用ie访问test_excel.JSP就能在ie里面打开动态生成的excel文档了。一点乱码也没有。

也许有人会问:response.reset();可不可以不要这一句,我的建议是一定要写,除非你能保证response的buffer里面没有别的东西。

还有人也许会问:我在JSP开头加上< %@page contentType="application/vnd.ms-excel;charset=GBK" %>这一句,去掉response.setContentType("application/vnd.ms-excel");行不行?回答这个问题很简单,就是查看JSP服务器编译JSP后生成的java代码,如果改成这样,我的welogic7编译test_excel.JSP后生成的java文件的示意性代码是这样的:

  1. public void _jspService(javax.servlet.http.HttpServletRequest
    request,   
  2. javax.servlet.http.HttpServletResponse response) throws 
    java.io.IOException,   
  3. javax.servlet.ServletException  catch (Throwable __ee)   
  4.  
  5.  
  6.         //before final close brace...  
  7.     } 

很明显,屏蔽 response.setContentType("application/vnd.ms-excel");后,在 Test.writeExcel(response.getOutputStream());之前,response.reset(); 之后没有设置 response contenttype的正确类型,当然输出为乱码了。而正确输出excel的JSP的编译后源码是这样的:

  1. public void _jspService(javax.servlet.http.HttpServletRequest request,   
  2. javax.servlet.http.HttpServletResponse response) throws 
    java.io.IOException,  
  3. javax.servlet.ServletException   
  4.      catch (Throwable __ee)   
  5.  
  6.  
  7.         //before final close brace...  
  8.     } 

大家可以看到在response.reset();之后,Test.writeExcel(response.getOutputStream());之前正确的设置了response的输出内容。所以输出就正常了。

【编辑推荐】

  1. JSP自定义标签由浅到深详细讲解
  2. 在JSP环境中配置使用fckeditor详细讲解
  3. 基于JSP实现数据库中图片的存储与显示
  4. 构造JSP和Javabean开发和发布环境的方法
  5. JSP+JavaBean+Servlet工作原理实例讲解
责任编辑:佚名 来源: builder
相关推荐

2009-07-02 13:26:32

JSP中文乱码

2009-07-01 18:05:54

JSP中文乱码

2009-07-06 17:50:13

Java JSP

2012-06-19 14:35:24

JSPJava乱码

2009-07-07 18:20:54

JSP页面显示乱码

2009-07-07 13:42:57

Servlet JSP

2010-11-09 17:09:23

SQL Server中

2009-07-01 18:14:36

JSP乱码

2009-11-26 16:30:52

Suse中文乱码问题

2011-02-24 10:48:51

FireFTP

2012-03-21 10:16:31

JavaJSP

2009-07-02 13:32:56

JSP中文乱码

2009-06-30 15:22:55

JSP页面

2010-06-07 14:50:50

jsp MySQL

2011-08-08 10:29:12

MySQL

2010-06-07 11:13:46

MySQL中文乱码

2010-05-28 18:05:22

jsp MySQL

2009-06-30 17:26:56

JSP页面

2017-08-02 15:51:24

PHP中文乱码

2009-07-03 14:23:35

JSP实用案例教程
点赞
收藏

51CTO技术栈公众号