光波表厂家
免费服务热线

Free service

hotline

010-00000000
光波表厂家
热门搜索:
行业资讯
当前位置:首页 > 行业资讯

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

发布时间:2022-04-02 09:36:01 阅读: 来源:光波表厂家
Jsp输出excel文档和中文乱码问题的解决 作者:网络 2009-06-30 13:49:21 开发 后端 本文介绍Jsp输出excel文档和中文乱码问题的解决2021年国家老旧小区拆迁吗,包括写一个JSP,来利用Test这个javabean输出excel文档。

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

  1. packagecom.jagie.test
  2. importjava.io.
  3. importjxl.
  4. importjxl.write.
  5. importjxl.format.
  6. importjava房屋拆迁到什么程度强拆.util.
  7. importjava.awt.Color
  8. publicclassTest

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

  1. <%@pageimport="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. publicvoid_jspService(javax.servlet.http.HttpServletRequest
    request,
  2. javax.servlet.http.HttpServletResponseresponse)throws
    java.io.IOException,
  3. javax.servlet.ServletExceptioncatch(Throwable__ee)
  4. //beforefinalclosebrace...
  5. }

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

  1. publicvoid_jspService(javax.servlet.http.HttpServletRequestrequest,
  2. javax.servlet.http.HttpServletResponseresponse)throws
    java.io.IOException,
  3. javax.servlet.ServletException
  4. catch(Throwable__ee)
  5. //beforefinalclosebrace...
  6. }

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

【编辑推荐】

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