亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

ReportingService本地報表引用自定義程序集需要

系統(tǒng) 1632 0

問題描述:創(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>

ReportingService本地報表引用自定義程序集需要注意的問題


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

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

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 小视频国产 | 乱码一区二区三区完整视频 | 奇米影视7777久久精品人人爽 | 九九免费在线视频 | 国产成人福利在线 | 九九影院理论片私人影院 | 国产一级毛片国产 | 久久视频在线观看免费 | www.久久精品 | 免费观看一级欧美在线视频 | 9999热视频 | 国产剧情一区二区 | 全部免费国产潢色一级 | 日韩男女视频 | 香蕉网站狼人久久五月亭亭 | 精品久久久久中文字幕日本 | 国产视频久 | 亚洲最新在线 | 一级毛片特黄久久免费看 | 日本不卡一区二区三区视频 | 欧美色激情 | 精品乱人伦一区二区三区 | 久热精品视频在线播放 | 成人影院一区二区三区 | 免费h片在线观看网址最新 免费v片在线观看无遮挡 | 朴妮唛禁福利视频在线 | 久久亚洲精品中文字幕 | 亚洲不卡视频 | 国产综合久久久久影院 | 日本一区不卡视频 | 99精品久久久久久久 | 免费的毛片| 亚洲伦理视频 | 免费一级欧美大片久久网 | 国内精品久久久久久久久 | 嘿嘿嘿视频免费网站在线观看 | 久久香蕉精品 | 四虎永久影院 | 久热福利视频 | 天堂成人在线 | 欧美日本黄色 |