問題描述:創(chuàng)建了類庫編譯成RSCustomLib.dll
在服務(wù)器報(bào)表引用一點(diǎn)問題也沒有,也能如期工作。但在本地報(bào)表引用相同的程序集則編譯時(shí)報(bào)如下錯(cuò)誤:
加載代碼模塊時(shí)出錯(cuò):“RSCustomLib, Version=1.0.0.0, Culture=neutral,
PublicKeyToken=null”。詳細(xì)信息: 未能加載文件或程序集“RSCustomLib, Version=1.0.0.0,
Culture=neutral, PublicKeyToken=null”或它的某一個(gè)依賴項(xiàng)。系統(tǒng)找不到指定的文件。
細(xì)心的朋友從上面信息可以猜出本地報(bào)表的自定義程序集需要部署為GAC方式,確實(shí)如此。
本地報(bào)表使用自定義程序集部署步驟:
1.打開自定義的程序集項(xiàng)目;
2.對托管程序集進(jìn)行強(qiáng)簽名(您可以使用SDK命令:>sn /K c:\key.snk然后將Key.snk添加到項(xiàng)目并簽名,或在VS project->properties->signing中進(jìn)行簽名)
3.保存并編譯。
4.在運(yùn)行的計(jì)算機(jī)的GAC中安裝程序集。(您可以使用VS Command:>gacutil /i AssemblyName.dll,也可以直接把dll拖入C:\Windows\assembly文件夾)
(PS:不放GAC好像也可以,復(fù)制到C:\Program Files\Microsoft Visual Studio 9\Common7\IDE\PrivateAssemblies下,還需要在前端使用本地報(bào)表(或者說使用ReportViewer控件)的工程引用該程序集;當(dāng)然bin\debug目錄下需要存在該dll文件)
接著,在本地報(bào)表文件(.rdlc)中選中報(bào)表單擊報(bào)表屬性切到引用頁,引用剛才編譯的dll文件,設(shè)置號類名(如RSCustomLib.TestClass)、實(shí)例名(如myTestClass);
然后在需要使用的位置如報(bào)表的文本框設(shè)置其值(如表達(dá)式:=Code.myTestClass.GetHello());
另外,需要強(qiáng)調(diào)的是您需要使用在顯示報(bà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è)置;
運(yùn)行可能還會(huì)報(bào)錯(cuò)“該程序集不支持部分受信任的調(diào)用方”。
在自定義程序集項(xiàng)目的AssemblyInfo.cs文件中加入:[assembly: AllowPartiallyTrustedCallers] 就可以解決了。
在%RSCustomLib\bin\Debug運(yùn)行部署批文件deploy.bat,內(nèi)容如下:
copy RSCustomLib.* "C:\Program Files\Microsoft Visual Studio 8\Common7\IDE\PrivateAssemblies"(BIDS報(bào)表設(shè)計(jì)預(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ù)器端報(bào)表部署使用該自定義程序集的步驟:
1、copy RSCustomLib.* "C:\Program Files\Microsoft SQL Server\MSSQL.3\Reporting Services\ReportServer\bin"
2、服務(wù)器報(bào)表的自定義程序集如使用打開文件、訪問SQL資源等還必須作下面的設(shè)置(原因RS對于表達(dá)式默認(rèn)執(zhí)行權(quán)限是“Execution”,需要修改為“FullTrust”):
還需要設(shè)置安全性,將FullTrust安全許可賦予報(bào)表表達(dá)式(注意:這是高風(fēng)險(xiǎn)操作,在生產(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個(gè)</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
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
