問題描述:創(chuàng)建了類庫編譯成RSCustomLib.dll
在服務(wù)器報表引用一點問題也沒有,也能如期工作。但在本地報表引用相同的程序集則編譯時報如下錯誤:
加載代碼模塊時出錯:“RSCustomLib, Version=1.0.0.0, Culture=neutral,
PublicKeyToken=null”。詳細信息: 未能加載文件或程序集“RSCustomLib, Version=1.0.0.0,
Culture=neutral, PublicKeyToken=null”或它的某一個依賴項。系統(tǒng)找不到指定的文件。
細心的朋友從上面信息可以猜出本地報表的自定義程序集需要部署為GAC方式,確實如此。
本地報表使用自定義程序集部署步驟:
1.打開自定義的程序集項目;
2.對托管程序集進行強簽名(您可以使用SDK命令:>sn /K c:\key.snk然后將Key.snk添加到項目并簽名,或在VS project->properties->signing中進行簽名)
3.保存并編譯。
4.在運行的計算機的GAC中安裝程序集。(您可以使用VS Command:>gacutil /i AssemblyName.dll,也可以直接把dll拖入C:\Windows\assembly文件夾)
(PS:不放GAC好像也可以,復(fù)制到C:\Program Files\Microsoft Visual Studio 9\Common7\IDE\PrivateAssemblies下,還需要在前端使用本地報表(或者說使用ReportViewer控件)的工程引用該程序集;當然bin\debug目錄下需要存在該dll文件)
接著,在本地報表文件(.rdlc)中選中報表單擊報表屬性切到引用頁,引用剛才編譯的dll文件,設(shè)置號類名(如RSCustomLib.TestClass)、實例名(如myTestClass);
然后在需要使用的位置如報表的文本框設(shè)置其值(如表達式:=Code.myTestClass.GetHello());
另外,需要強調(diào)的是您需要使用在顯示報表前使用LocalReport.ExecuteReportInCurrentAppDomain(AppDomain.CurrentDomain.Evidence);
及LocalReport.AddTrustedCodeModuleInCurrentAppDomain() 來添加程序集為信任程序集。
如:reportViewer1.LocalReport.ExecuteReportInCurrentAppDomain(AppDomain.CurrentDomain.Evidence);
this.reportViewer1.LocalReport.AddTrustedCodeModuleInCurrentAppDomain("RSCustomLib, Version=1.0.0.0, Culture=neutral, PublicKeyToken=f1252188e7ed8fc3");
PublicKeyToken等值需要根據(jù)您部署在GAC的相應(yīng)值設(shè)置;
運行可能還會報錯“該程序集不支持部分受信任的調(diào)用方”。
在自定義程序集項目的AssemblyInfo.cs文件中加入:[assembly: AllowPartiallyTrustedCallers] 就可以解決了。
在%RSCustomLib\bin\Debug運行部署批文件deploy.bat,內(nèi)容如下:
copy RSCustomLib.* "C:\Program Files\Microsoft Visual Studio 8\Common7\IDE\PrivateAssemblies"(BIDS報表設(shè)計預(yù)覽)
copy RSCustomLib.* "C:\Program Files\Microsoft Visual Studio
9
\Common7\IDE\PrivateAssemblies"(如果使用VS2008的話)
copy RSCustomLib.* "C:\Program Files\Microsoft SQL Server\MSSQL.3\Reporting Services\ReportServer\bin"
?
服務(wù)器端報表部署使用該自定義程序集的步驟:
1、copy RSCustomLib.* "C:\Program Files\Microsoft SQL Server\MSSQL.3\Reporting Services\ReportServer\bin"
2、服務(wù)器報表的自定義程序集如使用打開文件、訪問SQL資源等還必須作下面的設(shè)置(原因RS對于表達式默認執(zhí)行權(quán)限是“Execution”,需要修改為“FullTrust”):
還需要設(shè)置安全性,將FullTrust安全許可賦予報表表達式(注意:這是高風(fēng)險操作,在生產(chǎn)環(huán)境最好不要使用):
修改下面文件C:\Program Files\Microsoft SQL Server\MSSQL.4\Reporting Services\ReportServer\rssrvpolicy.config
在該文件中查找文本Name="Report_Expressions_Default_Permissions"將其上面一行內(nèi)容修改為PermissionSetName="
FullTrust
";
3、其次還需在該文件(rssrvpolicy.config)的倒數(shù)第2個</CodeGroup>前增加一段引用自定義程序集的內(nèi)容:
<CodeGroup class="UnionCodeGroup" version="1" PermissionSetName="
FullTrust
" Description="This special code group grants RSCustomLib.dll FUllTrust permission. ">
??????? <IMembershipCondition class="UrlMembershipCondition" version="1" Url="C:\Program Files\Microsoft SQL Server\MSSQL.3\Reporting Services\ReportServer\bin\RSCustomLib.dll" />
</CodeGroup>
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
