亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

ExtJs Excel導(dǎo)出并下載IIS服務(wù)器端遇到的問題

 更新時間:2011年09月16日 23:22:52   作者:  
進項目一個多月不到。熟悉了這個二次開發(fā)的項目因為前面遺留下來的問題比較嚴(yán)重報表的導(dǎo)出和圖表以及打印功能都沒有實現(xiàn),所以這兩天工作量比較大。
項目是Extjs的主要針對于Extjs GridPanel數(shù)據(jù)導(dǎo)出這塊先做一下說明。
我們可以通過Ext.getcmp()方法獲取到GridPanel對象并通過重寫的方法獲取Excel字符串具體方法可以百度到。這個應(yīng)該也不是什么大問題。
復(fù)制代碼 代碼如下:

//輸出報表
function ExportReport(title) {
var vExportContent = Ext.getCmp("gridPanel").getExcelXml(null, title);
if (Ext.isIE6 || Ext.isIE7 || Ext.isSafari || Ext.isSafari2 || Ext.isSafari3 || Ext.isIE8) {
// var frm = document.createElement('form');
// frm.id = 'frmExtjs';
// frm.className = 'x-hidden';
// document.body.appendChild(frm);
var f = document.createElement("form");
f.id = "frmExtjs";
document.body.appendChild(f);
var i = document.createElement("input");
i.type = "hidden";
i.id = "exportContent";
i.name = "exportContent";
f.appendChild(i);
i.value = vExportContent;
Ext.Ajax.request({
url: 'frmExcel.aspx',
method: 'POST',
form: Ext.get('frmExtjs'),
isUpload: true,
params: { FileName: title + '.xls' }
})
} else {
document.location = 'data:application/vnd.ms-excel;base64,' + Base64.encode(vExportContent);
}

以上是表單虛擬提交的方法。但是實驗了很多方法。發(fā)現(xiàn)數(shù)據(jù)post過去后無法生成Excel通過生成后下載方法也無法實現(xiàn)。(即在服務(wù)器端無法生成,但本機可以生成。)經(jīng)過多次思路的轉(zhuǎn)折后來想到通過數(shù)據(jù)分析來調(diào)試??纯吹降讛?shù)據(jù)是否post到網(wǎng)頁
復(fù)制代碼 代碼如下:

string tmpFileName = "export.xls";
string tmpContent = Request["ExportContent"];
if (Request["FileName"] != "")
{
tmpFileName = Request["FileName"];//獲取傳遞來的文件名?
tmpFileName = System.Web.HttpUtility.UrlEncode(Request.ContentEncoding.GetBytes(tmpFileName));//處理中文文件名的情況
}
Response.Clear();
Response.Buffer = true;
Response.ContentType = "application/vnd.ms-excel";
Response.AddHeader("Content-Disposition", "attachment;filename=\"" + tmpFileName + "\"");
Response.Charset = "";
System.IO.StringWriter tmpSW = new System.IO.StringWriter();
System.Web.UI.HtmlTextWriter tmpHTW = new System.Web.UI.HtmlTextWriter(tmpSW);
tmpHTW.WriteLine(tmpContent);
Response.Write(tmpSW.ToString());
Response.End();

以上是生成并下載的CS文件

clip_image002

后來找到這個工具

具體步驟很簡單:

打開工具欄上的插件

clip_image004

雖然是英文的,但是不在話下。文檔都是看的英文的。

clip_image006

clip_image008

兩張近照

這邊就可以看到post過去以后的報錯信息。

這個是無刷新post無法看到的頁面。正因為這個而糾結(jié)了好久。今天終于知道哪錯了。

把錯誤信息復(fù)制到文本生成html文件。

clip_image010

原來是.net安全機制搞的鬼。

在web.config 的System.Web 后面加兩句話就搞定了。

<httpRuntime requestValidationMode="2.0" />

<pages validateRequest="false" />

好了 問題解決了 結(jié)博。

相關(guān)文章

最新評論