欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

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

系統 1705 0

問題描述:創建了類庫編譯成RSCustomLib.dll
在服務器報表引用一點問題也沒有,也能如期工作。但在本地報表引用相同的程序集則編譯時報如下錯誤:
加載代碼模塊時出錯:“RSCustomLib, Version=1.0.0.0, Culture=neutral,
PublicKeyToken=null”。詳細信息: 未能加載文件或程序集“RSCustomLib, Version=1.0.0.0,
Culture=neutral, PublicKeyToken=null”或它的某一個依賴項。系統找不到指定的文件。
細心的朋友從上面信息可以猜出本地報表的自定義程序集需要部署為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好像也可以,復制到C:\Program Files\Microsoft Visual Studio 9\Common7\IDE\PrivateAssemblies下,還需要在前端使用本地報表(或者說使用ReportViewer控件)的工程引用該程序集;當然bin\debug目錄下需要存在該dll文件)

接著,在本地報表文件(.rdlc)中選中報表單擊報表屬性切到引用頁,引用剛才編譯的dll文件,設置號類名(如RSCustomLib.TestClass)、實例名(如myTestClass);
然后在需要使用的位置如報表的文本框設置其值(如表達式:=Code.myTestClass.GetHello());
另外,需要強調的是您需要使用在顯示報表前使用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等值需要根據您部署在GAC的相應值設置;

運行可能還會報錯“該程序集不支持部分受信任的調用方”。
在自定義程序集項目的AssemblyInfo.cs文件中加入:[assembly: AllowPartiallyTrustedCallers] 就可以解決了。

在%RSCustomLib\bin\Debug運行部署批文件deploy.bat,內容如下:
copy RSCustomLib.* "C:\Program Files\Microsoft Visual Studio 8\Common7\IDE\PrivateAssemblies"(BIDS報表設計預覽)
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"
?

服務器端報表部署使用該自定義程序集的步驟:
1、copy RSCustomLib.* "C:\Program Files\Microsoft SQL Server\MSSQL.3\Reporting Services\ReportServer\bin"
2、服務器報表的自定義程序集如使用打開文件、訪問SQL資源等還必須作下面的設置(原因RS對于表達式默認執行權限是“Execution”,需要修改為“FullTrust”):
還需要設置安全性,將FullTrust安全許可賦予報表表達式(注意:這是高風險操作,在生產環境最好不要使用):
修改下面文件C:\Program Files\Microsoft SQL Server\MSSQL.4\Reporting Services\ReportServer\rssrvpolicy.config
在該文件中查找文本Name="Report_Expressions_Default_Permissions"將其上面一行內容修改為PermissionSetName=" FullTrust ";

3、其次還需在該文件(rssrvpolicy.config)的倒數第2個</CodeGroup>前增加一段引用自定義程序集的內容:
<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本地報表引用自定義程序集需要注意的問題


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

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

【本文對您有幫助就好】

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

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 国产免费福利视频一区二区 | 成人嗯啊视频在线观看 | 亚洲精品免费观看 | 欧美伊人久久 | 91精品国产乱码久久久久久久久 | 日本九九视频 | 国产成人免费视频网站高清观看视频 | 日本三级网 | 国产不卡视频在线播放 | 日韩在线视频在线观看 | 黄a在线观看 | 日本不卡在线观看免费v | 日本天堂一区 | 久久亚洲国产精品五月天婷 | 欧美日韩国产一区二区三区伦 | 色屁屁www影院免费观看软件 | 久久精品性视频 | 欧美成a人片在线观看 | www.一区二区 | 18pao成人国产永久视频 | 91视频这里只有精品 | 亚洲综合久久久久久888 | 国产一区 | 欧美激情一区二区三级高清视频 | 香蕉视频在线观看免费国产婷婷 | 成人免费大片a毛片 | 欧美中文字幕一区二区三区亚洲 | 操久久久 | 成av在线| 天堂资源在线观看 | 国产精品区二区三区日本 | 天天插天天操 | 国产萝控精品福利视频免费观看 | 综合色区 | 欧美大片在线看免费观看 | 一区不卡 | 多女多p多杂交视频在线观看 | 日韩中文字幕在线有码视频网 | 亚洲成色 | 国产精品秒播无毒不卡 | 国产综合在线播放 |