轉: ASP.Net call Excel

來源:互聯網
上載者:User

轉自:http://www.cnblogs.com/xuanhun/archive/2010/04/29/1724500.html

 

。。。

 

四. "未將對象引用設定到對象執行個體"和伺服器端部署

用戶端一切運行正常,接下來就是要把DLL部署到伺服器上。可是伺服器根本沒用安裝Office,在網站找了很久,也沒找到此種方法的解決方案。無奈就安裝了Office,本來以為萬事大吉,但是每次都提示"未將對象引用設定到對象執行個體"。採用拋異常的方法才知道樣本程式中的幾個主要欄位都為空白,那就是本地的COM根本沒調用成功。找到http://www.cnblogs.com/Mainz/archive/2009/11/11/microsoft_office_interop_excel.html文章,於是乎又進行了如下操作。

從伺服器上把EXCEL.EXE拷到了本機上,然後從VS2010的命令列啟動TlbImp,執行命令:TlbImp /out:Interop.Excel.dll Excel.exe。產生Interop.Excel.dll。

在項目中去除了Microsoft.Office.Interop.Excel.dll的引用,添加Interop.Excel.dll,將頂部的using Excel=Microsoft.Office.Interop.Excel,該為using Excel= Interop.Excel,本地運行程式沒有問題。再次補救伺服器端程式,結果又出了新的異常:檢索 COM 類別工廠中 CLSID 為 {00024500-0000-0000-C000-000000000046} 的組件時失敗,原因是出現以下錯誤: 80080005

五. "80080005異常"與許可權配置

"80080005異常"是應用程式對COM組件操作許可權不足引起的。於是有了下面的操作:

1)控制台->管理工具->元件服務->電腦->我的電腦->DCOM-> Microsoft Excel 應用程式

2)單擊屬性開啟此應用程式的屬性對話方塊。

3) 單擊標識選項卡,然後選擇互動式使用者。

4) 單擊預設安全性選項卡。設定當前伺服器與ASP.NET相關的使用者的存取權限。

5)單擊啟動許可權的編輯預設值。設定ASP.NET相關的使用者的存取權限。

至此,程式才運行成功,可謂一波三折。

六.關閉Excel進程

如果使用這種方式使用者每匯出一個Excel檔案,伺服器端就會啟動一個Excel進程。這回引起兩個問題,一是耗費伺服器資源,二是當進程數達到上限時,會引發異常,調用COM失敗。這個時候要想辦法結束Excel進程。我採用了殺進程的方式,類似下面的做法:

private void DoExcel()
{
Microsoft.Office.Interop.Excel.Application application = new Microsoft.Office.Interop.Excel.Application();
//這裡釋放所有引用的資源
application.Quit();
KillExcel(application);
}

[DllImport("User32.dll", CharSet = CharSet.Auto)]
public static extern int GetWindowThreadProcessId(IntPtr hwnd,out int ID);
public static void KillExcel(Microsoft.Office.Interop.Excel.Application excel)
{
IntPtr t = new IntPtr(excel.Hwnd); //得到這個控制代碼,具體作用是得到這塊記憶體入口

int k = 0;
GetWindowThreadProcessId(t, out k); //得到本進程唯一標誌k
System.Diagnostics.Process p = System.Diagnostics.Process.GetProcessById(k); //得到對進程k的引用
p.Kill(); //關閉進程k
}

 

 

七.還有其他選擇

產生Excel方式不止一種,比如利用OpenXml,還是留給你們導論吧,我向你們學習。

 

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.