亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JSP > 正文

JSP動態輸出Excel及中文亂碼的解決

2020-07-27 21:48:35
字體:
來源:轉載
供稿:網友

  最近在網上看到一個用java來操縱excel的open source,在weblogic上試用了一下,覺得很不錯,特此向大家推薦一下。

  首先去http://www.andykhan.com/jexcelapi/index.html下載最新的JExcelApi,把jxl.jar置于你的classpath中。

  寫一個javaBean,利用JExcelApi來動態生成excel文檔,我這里寫一個最簡單的,示意性的。復雜的你可能還要查詢數據庫什么的。

///////////////////////////Test.java///////////////////////////////////////////
package com.jagie.test;
import java.io.*;
import jxl.*;
import jxl.write.*;
import jxl.format.*;
import java.util.*;
import java.awt.Color;

public class Test{
 public static void writeExcel(OutputStream os) throws Exception {
  jxl.write.WritableWorkbook wwb = Workbook.createWorkbook(os);
  jxl.write.WritableSheet ws = wwb.createSheet("TestSheet1", 0);
  jxl.write.Label labelC = new jxl.write.Label(0, 0, "我愛中國");
  ws.addCell(labelC);
  jxl.write.WritableFont wfc = new jxl.write.WritableFont(WritableFont.ARIAL,20, WritableFont.BOLD, false,
  UnderlineStyle.NO_UNDERLINE, jxl.format.Colour.GREEN);
  jxl.write.WritableCellFormat wcfFC = new jxl.write.WritableCellFormat(wfc);
  wcfFC.setBackground(jxl.format.Colour.RED);
  labelC = new jxl.write.Label(6, 0, "中國愛我",wcfFC);
  ws.addCell(labelC);
  //寫入Exel工作表
  wwb.write();
  //關閉Excel工作薄對象
  wwb.close();
 }

 //最好寫一個這樣的main方法來測試一下你的這個class是否寫好了。
 public static void main(String[] args)throws Exception{
  File f=new File("kk.xls");
  f.createNewFile();
  writeExcel(new FileOutputStream(f));
 }
}

  寫一個jsp,來利用Test這個javabean輸出excel文檔。

///////////////////////////test_excel.jsp//////////////////////////

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

  這樣就大功告成了,你用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文件的示意性代碼是這樣的:

public void _jspService(javax.servlet.http.HttpServletRequest request,
javax.servlet.http.HttpServletResponse response) throws java.io.IOException,
javax.servlet.ServletException {

 // declare and set well-known variables:
 javax.servlet.ServletConfig config = getServletConfig();
 javax.servlet.ServletContext application = config.getServletContext();
 javax.servlet.jsp.tagext.Tag _activeTag = null;
 // variables for Tag extension protocol

 Object page = this;
 javax.servlet.jsp.JspWriter out;
 javax.servlet.jsp.PageContext pageContext =
 javax.servlet.jsp.JspFactory.getDefaultFactory().getPageContext(this,
 request, response, null, true, 8192, true);

 response.setHeader("Content-Type", "application/vnd.ms-excel; charset=GBK");
 out = pageContext.getOut();
 JspWriter _originalOut = out;

 javax.servlet.http.HttpSession session = request.getSession(true);

 try { // error page try block
  response.setContentType("application/vnd.ms-excel;charset=GBK");
  out.print("/r/n/r/n/r/n/r/n");
  out.print("/r/n");
  //[ /test_excel.jsp; Line: 6]
  response.reset(); //[ /test_excel.jsp; Line: 7]
  //response.setContentType("application/vnd.ms-excel");
  //[ /test_excel.jsp; Line: 8]
  Test.writeExcel(response.getOutputStream()); //[ /test_excel.jsp; Line: 9]
  } catch (Throwable __ee) {
   while (out != null && out != _originalOut) out = pageContext.popBody();
  ((weblogic.servlet.jsp.PageContextImpl)pageContext).handlePageException((Throwable)__ee);
 }

 //before final close brace...
}

  很明顯,屏蔽response.setContentType("application/vnd.ms-excel");后,在Test.writeExcel(response.getOutputStream());之前,response.reset(); 之后沒有設置response contenttype的正確類型,當然輸出為亂碼了。而正確輸出excel的jsp的編譯后源碼是這樣的:

public void _jspService(javax.servlet.http.HttpServletRequest request,
javax.servlet.http.HttpServletResponse response) throws java.io.IOException,
javax.servlet.ServletException
{
 // declare and set well-known variables:
 javax.servlet.ServletConfig config = getServletConfig();
 javax.servlet.ServletContext application = config.getServletContext();
 javax.servlet.jsp.tagext.Tag _activeTag = null;
 // variables for Tag extension protocol

 Object page = this;
 javax.servlet.jsp.JspWriter out;
 javax.servlet.jsp.PageContext pageContext =
  javax.servlet.jsp.JspFactory.getDefaultFactory().getPageContext(this, request, response, null, true, 8192, true);

 out = pageContext.getOut();
 JspWriter _originalOut = out;

 javax.servlet.http.HttpSession session = request.getSession(true);

 try { // error page try block
  out.print("/r/n");
  //[ /test_excel.jsp; Line: 2]
  response.reset(); //[ /test_excel.jsp; Line: 3]
  response.setContentType("application/vnd.ms-excel"); //[ /test_excel.jsp; Line: 4]
  Test.writeExcel(response.getOutputStream()); //[ /test_excel.jsp; Line: 5]
 } catch (Throwable __ee) {
  while (out != null && out != _originalOut) out = pageContext.popBody();
  ((weblogic.servlet.jsp.PageContextImpl)pageContext).handlePageException((Throwable)__ee);
 }

  //before final close brace...
}

  大家可以看到在response.reset();之后,Test.writeExcel(response.getOutputStream());之前正確的設置了response的輸出內容。所以輸出就正常了。

  最后,希望這篇文章能對你有所啟發,如有錯誤之處,敬請批評指正!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩一区二区在线| 亚洲女成人图区| 日韩高清有码在线| 九九精品视频在线观看| 成人亚洲欧美一区二区三区| 97视频免费观看| 色婷婷av一区二区三区久久| 国产成人精品在线| 国产91色在线播放| 日韩有码在线播放| 国产自产女人91一区在线观看| 亚洲第一页在线| 欧美大片免费观看在线观看网站推荐| 97av视频在线| 久久亚洲精品毛片| 热门国产精品亚洲第一区在线| 69视频在线播放| 懂色aⅴ精品一区二区三区蜜月| 伊人青青综合网站| 亚洲视频视频在线| 欧美精品在线观看91| 成人久久久久久久| 欧美一区在线直播| 日本精品久久久| 国产精品久久久久久久7电影| 日韩在线观看成人| 亚洲精品久久视频| 欧美性受xxx| 日本中文字幕成人| 92版电视剧仙鹤神针在线观看| 日韩大胆人体377p| 欧美一级片在线播放| 国产亚洲精品91在线| 性色av香蕉一区二区| 久久69精品久久久久久久电影好| 成人黄色免费网站在线观看| 国产小视频国产精品| 欧美黑人一级爽快片淫片高清| 成人免费午夜电影| 国产欧美精品一区二区| 欧美精品18videos性欧美| 国产成人福利视频| 欧美专区在线播放| 亚洲精品久久久久久久久久久久久| 97精品伊人久久久大香线蕉| 国产成人涩涩涩视频在线观看| 综合av色偷偷网| 欧美黑人巨大精品一区二区| 亚洲国产欧美精品| 久久亚洲精品视频| 亚洲性生活视频在线观看| 在线看日韩欧美| 亚洲性无码av在线| 亚洲国产精品久久精品怡红院| 国产精品欧美风情| 亚洲最大成人网色| 亚洲情综合五月天| 久久久久国产精品www| 久久香蕉国产线看观看网| 欧美日韩国产综合新一区| 久久777国产线看观看精品| 最近2019好看的中文字幕免费| 麻豆精品精华液| 亚洲精品理论电影| 亚洲va久久久噜噜噜久久天堂| 日韩欧美在线视频免费观看| 三级精品视频久久久久| 日韩在线观看免费| 国产99久久精品一区二区| 久久影院免费观看| 国产精品青青在线观看爽香蕉| 亚洲偷欧美偷国内偷| 中文字幕久热精品视频在线| 欧美男插女视频| 国产女同一区二区| 欧美国产精品日韩| 理论片在线不卡免费观看| 狠狠操狠狠色综合网| 精品福利在线看| 亚洲精品国产免费| 精品国产成人在线| 亚洲精品久久久久中文字幕欢迎你| 一区二区成人精品| 精品久久久久久| 91av中文字幕| 奇米影视亚洲狠狠色| 91精品国产自产在线观看永久| 亚洲摸下面视频| 亚洲国产欧美精品| 91中文精品字幕在线视频| 在线观看国产精品日韩av| 粉嫩av一区二区三区免费野| 国产成人精品日本亚洲专区61| 欧美国产日韩精品| 国产91九色视频| 亚洲第一色中文字幕| 高潮白浆女日韩av免费看| 日韩大片在线观看视频| 欧美大片免费看| 国产精品xxx视频| 亚洲人成电影网站色| 最近2019中文字幕大全第二页| 疯狂做受xxxx欧美肥白少妇| 日韩欧美aⅴ综合网站发布| 亚洲人成网站在线播| 精品福利一区二区| 91老司机精品视频| 亚洲男人天堂手机在线| 国产午夜精品免费一区二区三区| 成人黄色生活片| 日本高清视频一区| 欧美在线视频免费观看| 亚洲成人激情在线| 亚洲第一精品自拍| 久青草国产97香蕉在线视频| 亚洲欧美中文字幕在线一区| 中文字幕精品一区久久久久| 亚洲国产成人爱av在线播放| 日本中文字幕久久看| 欧美一级大片在线观看| 亚洲成人a级网| 国产精品久久久久999| 国内久久久精品| 久久久久久久电影一区| 日本高清视频精品| 亚洲欧美激情精品一区二区| 在线观看中文字幕亚洲| 亚洲激情电影中文字幕| 亚洲桃花岛网站| 欧美高清电影在线看| 亚洲欧美制服综合另类| 欧美放荡办公室videos4k| 九九九久久国产免费| 成人在线视频网站| 精品国产一区二区三区久久狼5月| 久久久久久网站| 中文字幕亚洲第一| 另类专区欧美制服同性| 久久久久久久久久久91| 91网站在线免费观看| 国产精品尤物福利片在线观看| 欧美二区在线播放| 国产精品69精品一区二区三区| 欧美日韩精品二区| 欧美视频专区一二在线观看| 国产mv久久久| 亚洲激情视频网| 亚洲第五色综合网| 亚洲精品自拍第一页| www日韩欧美| 国外日韩电影在线观看| 亚洲天堂第一页| 欧美华人在线视频| 亚洲精品日韩久久久| 久久影视电视剧免费网站清宫辞电视| 成人欧美一区二区三区黑人孕妇| 国产视频在线观看一区二区| 国产精品色悠悠| 色伦专区97中文字幕| 亚洲一区二区三区四区视频| 欧美在线观看网站| 九色91av视频| 成人午夜一级二级三级| 日韩中文字幕精品|