【sunmoonfire 】在SharePoint中編寫呼叫Excel Services的Filter Consumer WebPart
下面是建立filter consumer WebPart的五大步驟
- 在Visual Studio 2005中建立一個web control library專案。
- 新增到Microsoft.SharePoint.dll的引用。
- 設定assembly的版本號。
- 為assembly新增強命名。
- 編寫頭條新聞filter consumer webpart的程式碼。
在Visual Studio 2005中建立一個web control library專案
建立一個filter consumer WebPart最簡單的方式是套用Visual Studio 2005的自定義Web控制元件模板。
下面是建立的步驟:
- 檔案->新建->專案,出現新建專案對話方塊。
- 在專案型別中,選擇C#,選擇Windows類別。
- 在模板選擇中,選擇web控制元件庫。
- 為專案指定一個名稱NewsHeadlinesWebPart 。
- 指定儲存的位置,確定。現在,專案中包含一個名為WebCustomControl1.cs的程式碼檔案。
- 在解決方案瀏覽器中右擊該檔案,選重名名。將該檔案重新命名為NewsHeadlinesWebPart.cs。
新增必要的程式集的引用
我們將要編寫的頭條新聞篩選消費者WebPart是要從Microsoft.SharePoint.WebPartPages.WebPart類繼承而來。因此,必須新增Windows SharePoint Services的程式集;由於使用到了Excel Services,還要引用Excel Services的程式集,以便允許使用其中的類。
下面的步驟是展示瞭如何直接連線到Excel Web Serivces庫。之所以如此是因為頭條新聞WebPart執行域SharePoint環境中,這與使用SOAP通過HTTP訪問Web service的方式不同。在我們的這種場景下直接連線可以提供更高的效能和安全性,並允許我們的頭條新文WebPart可以工作在所有的SharePoint拓撲結構下。而當我們建立獨立的Web應用程式(Web應用程式並不執行在SharePoint中)時,實際上是真正用到Web service的介面。關於何時選擇使用SOAP方式通過HTTP訪問,何時直接連線到Excel Web Services DLL,您可以參考這篇MOSS SDK文章:Loop-back SOAP Calls and Direct Linking
如果Visual Studio執行在Office SharePoint Server 2007伺服器上,請以下面的步驟進行引用:
- 專案->新增引用,出現新增引用對話方塊。
- 點選.NET標籤,選擇Excel Web Service 元件(Microsoft.Office.Excel.Server.WebServics.dll)。接著向下滾動,找到Windows SharePoint Services元件(Microsoft.SharePoint.dll),按住Ctrl鍵,再選擇。
- 確定,完成引用的新增。
如果Visual Studio與Office SharePoint Server 2007不在同一臺機器上,我們需要從一臺裝有Office SharePoint Server 2007的機器上拷貝該檔案到我們的開發環境所在機器的專案資料夾下。預設情況下,Microsoft.SharePoint.dll和Microsoft.Office.Excel.Server.WebServics.dll位於裝有SharePoint的機器的以下目錄中:
拷貝過來後,將這兩個檔案新增到引用中。
新增到本地拷貝的程式集的引用
- 專案->新增引用,出現新增引用對話方塊。
- 點選瀏覽,導航到放Windows SharePoint Services和Excel Web Service程式集檔案的目錄
選中Microsoft.SharePoint.dll 和Microsoft.Office.Excel.Server.WebServices.dll 檔案。 - 確定,完成引用的新增。
如果要使Excel Web Service正常工作,還需要新增到System.Web.Services程式集的引用:
-
專案->新增引用,出現新增引用對話方塊。
- 點選.NET標籤,選擇System.Web.Services 元件。
- 確定,完成引用的新增。
設定WebPart程式集的版本號
預設情況下,自定義Web控制元件專案的AssemblyVersion屬性設為每次重新編譯時自動增加。Web部件頁通過Web.config檔案中註冊的版本號來識別WebPart。如果AssemblyVersion屬性設為每次重新編譯時自動增加,當我們把WebPart匯入到Web部件頁後又重新編譯了該WebPart,就會因為找不到程式集而出錯了。避免字增的方法就是手工指定一個版本號。
為WebPart程式集手工指定版本號
- 專案->NewsHeadlinesWebPart 屬性。
- 在專案屬性頁面中,點應用程式標籤。
- 點程式集資訊
- 在程式集資訊對話方塊中,設定版本為1.0.0.0
- 確定,儲存。
- 關閉專案屬性頁。
為了使我們的WebPart可以部署到GAC(global assembly cache)中,供多個應用程式共享,我們必須為WebPart增加強命名。強名稱由一個文字格式的名稱,版本號,地區語言資訊(如果提供了的話)和一個公鑰數字簽名組成。
在Visual Studio中為WebPart強命名
- 專案->NewsHeadlinesWebPart 屬性。
- 在專案屬性頁面中,點簽名標籤。
- 在選擇一個強名key檔案處,點新建。
- 在建立強命名key檔案對話方塊中,填寫keypair檔名。取消下面的使用密碼保護我的金鑰的選擇框。
- 關閉專案屬性頁。
實現頭條新聞Filter Consumer WebPart
下面我們將建立一個類實現頭條新聞篩選消費者部件。在程式碼檔案頭部新增下列引用。
using aspnetwebparts = System.Web.UI.WebControls.WebParts;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Text;
using System.Web;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Collections.ObjectModel;
using Microsoft.Office.Excel.Server.WebServices;
引用這些名稱空間可以使我們方便的使用其中的類庫和型別,而不必通過使用完整的名稱空間路徑來訪問。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/12639172/viewspace-374714/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- User Get 'Access Denied' with Excel Service WebPartExcelWeb
- 在FILTER中,能取得URI,並且呼叫forward嗎?FilterForward
- sharepoint2010中的WebPart開發--資料庫連線Web資料庫
- [原] SharePoint 2010 WebPart與Google地圖系列 一:建立顯示地圖的WebPartWebGo地圖
- SharePoint 2013 開發——開發並部署webpartWeb
- ASP.NET AJAX中的非同步Web Services呼叫ASP.NET非同步Web
- SharePoint 2013 WebPart 管理工具分享[開源]Web
- 在sqlplus中呼叫編寫的refcursor 遊標型別的儲存過程SQL型別儲存過程
- c#中呼叫ExcelC#Excel
- 在Jboss中建立的EJB,JSP呼叫如何寫JS
- 在Laravel 中如何自定義servicesLaravel
- Install Reporting Services SharePoint Mode for SharePoint 2013
- Filter在Vue,JS,JQ中的使用FilterVueJS
- 用Excel編寫小遊戲 (轉)Excel遊戲
- Python呼叫C++編寫的方法PythonC++
- 使用Delphi呼叫C++編寫的DLLC++
- C#呼叫c++編寫的dllC#C++
- 在PowerShell中操作SharePoint物件物件
- 在 Laravel 中編寫簡潔的程式碼的策略Laravel
- 在 Linux 中如何編寫基本的 udev 規則Linuxdev
- 在Delphi中編寫控制元件的基本方法 (轉)控制元件
- 在 VSCode 中編寫 Markdown 的進階指南VSCode
- java編寫的介面可以呼叫python嗎JavaPython
- 利用Delphi 5中呼叫Excel 97 (轉)Excel
- 在Excel VBA中寫SQL,是一種什麼體驗ExcelSQL
- 在Delphi中編寫控制元件的基本方法(1) (轉)控制元件
- 為在網頁中插入「空格」編寫的JS指令碼網頁JS指令碼
- QT6編寫外部庫並呼叫QT
- 滑鼠雙擊在Excel中的妙用Excel
- 在iOS中呼叫HTMLiOSHTML
- aardio 兩行程式碼 呼叫 libxl 讀寫 excel行程Excel
- 使用Filter介面編寫過濾器解決post亂碼Filter過濾器
- filter在JavaScript中過濾陣列元素FilterJavaScript陣列
- 在 Admin 中自定義 list_filterFilter
- 在React工程中利用Mota編寫物件導向的業務模型React物件模型
- 在 React 工程中利用 Mota 編寫物件導向的業務模型React物件模型
- 用XML編寫EXCEL檔案,XML的寫法注意事項,可以C#+xslt匯出ExcelXMLExcelC#
- 【PB】powerbuilder呼叫VC編寫的動態連結庫UI