使用VS2010 C#開(kāi)發(fā)ActiveX控件(下),完整代碼打包下載
圖1
拋出異常如下:
************** Exception Text **************
System.MethodAccessException: Attempt by security transparent method 'Rare.Card.Libary.Controls.
ReadCardControl.btnRead_Click(System.Object, System.EventArgs)' to call native code through method 'Rare.Card.Libary.MifareOneHelper.rf_read(Int32, Int32, Byte[])' failed. Methods must be security critical or
security safe-critical to call native code.
通過(guò)查閱MSDN,對(duì)異常的解釋如下:
在 Microsoft .NET Framework 4 中,公共語(yǔ)言運(yùn)行時(shí) (CLR) 安全模型發(fā)生了不少變化。其中一項(xiàng)變化,即采用 Level2 透明性
(與 Silverlight 的安全模型非常相似)很可能影響 AllowPartiallyTrustedCallers (APTCA) 庫(kù)的作者。透明性屬性有三種:SecurityTransparent、SecuritySafeCritical 和 SecurityCritical。
SecurityTransparent:標(biāo)記為 SecurityTransparent 的代碼從安全性角度而言是可靠的。它不能完成任何危險(xiǎn)操作,例如聲明權(quán)限、
執(zhí)行無(wú)法驗(yàn)證的代碼或調(diào)用本機(jī)代碼。它也不能直接調(diào)用 SecurityCritical 代碼。
如上文所述,出于安全的考慮,所有部分受信任代碼都強(qiáng)制為 SecurityTransparent。這也是 APTCA 庫(kù)的默認(rèn)透明性。
SecurityCritical:與 SecurityTransparent 不同,SecurityCritical 代碼能夠執(zhí)行任何所需操作。它能夠執(zhí)行聲明、
調(diào)用本機(jī)代碼和其他操作。它能夠調(diào)用其他方法,且不受透明性標(biāo)記的限制。
只有完全受信任代碼才能為 SecurityCritical。事實(shí)上,(非 APTCA)完全受信任代碼默認(rèn)情況下屬于 SecurityCritical,
從而保護(hù)其免受透明的部分受信任調(diào)用方的調(diào)用。
SecuritySafeCritical:SecuritySafeCritical 代碼起著橋梁的作用,它允許透明代碼調(diào)用關(guān)鍵方法。SecuritySafeCritical
代碼與 SecurityCritical 代碼的權(quán)限相同,但它可由 SecurityTransparent 代碼調(diào)用。因此,SecuritySafeCritical 代碼必須以安全方式公開(kāi)基礎(chǔ) SecurityCritical 方法(以避免一些部分受信任的惡意代碼嘗試通過(guò) SecuritySafeCritical 層攻擊這些方法),這一點(diǎn)極為重要。
與 SecurityCritical 代碼一樣,SecuritySafeCritical 代碼必須完全受信任。
具體可以參考:
http://msdn.microsoft.com/zh-cn/magazine/ee336023.aspx
根據(jù)MSDN的解釋?zhuān)瑔?wèn)題出在了封裝原始Dll的C#類(lèi)庫(kù)CardReader.Library上,我們可以在代碼級(jí)別設(shè)置透明性屬性可以解決問(wèn)題。
具體解決辦法如下:
1. 設(shè)置ActiveX控件讀卡代碼的透明屬性為:SecuritySafeCritical,設(shè)置以后的代碼清單如下:
[SecuritySafeCritical]
/// <summary>
/// 讀卡
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btnRead_Click(object sender, EventArgs e)
{
int i = 0;
byte[] data = new byte[16];
byte[] buff = new byte[32];
for (i = 0; i < 16; i++)
data[i] = 0;
for (i = 0; i < 32; i++)
buff[i] = 0;
st = MifareOneHelper.rf_read(icdev, sec * 4 + 1, data);
if (st == 0)
{
SerialInterfaceHelper.hex_a(data, buff, 16);
txtCardID.Text = System.Text.Encoding.ASCII.GetString(buff);
lblMsg.Text = "讀取卡號(hào)成功!";
}
else
lblMsg.Text = "讀取卡號(hào)失敗!";
//test method
//if (string.IsNullOrEmpty(txtCardID.Text))
//{
// lblMsg.Text = "讀取數(shù)據(jù)失敗!";
//}
//else
//{
// lblMsg.Text = string.Format("讀取數(shù)據(jù):{0}!", txtCardID.Text);
//}
}
注意要添加引用:using System.Security;
在這里注掉了測(cè)試代碼,使用了串口通信和讀卡代碼。
2. 設(shè)置封裝原始讀卡器Dll的透明屬性。
設(shè)置M1讀卡器幫助類(lèi)MifareOneHelper的透明屬性為:[SecurityCritical],同時(shí)設(shè)置調(diào)用的方法MifareOneHelper.rf_read的
透明屬性為[SecurityCritical]。
設(shè)置串口通信幫助類(lèi)SerialInterfaceHelper的透明屬性為:[SecurityCritical],同時(shí)設(shè)置調(diào)用的方法SerialInterfaceHelper.hex_a的
透明屬性為[SecurityCritical]。
完整代碼已提供,還有2個(gè)地方需要注意的是,客戶(hù)端如果安裝ActiveX失敗,則把運(yùn)行ActiveX的地址加入到信任站點(diǎn)里,
信任站點(diǎn)的安全級(jí)別降低到最低或者設(shè)置信任站點(diǎn)關(guān)于A(yíng)ctiveX的選項(xiàng)。
打包下載地址 http://xiazai.jb51.net/201105/yuanma/CardReader.rar
- C#將dll打包到程序中的具體實(shí)現(xiàn)
- C#調(diào)用動(dòng)態(tài)unlha32.dll解壓Lha后綴的打包文件分享
- C#服務(wù)端圖片打包下載實(shí)現(xiàn)代碼解析
- C#使用InstallerProjects打包桌面應(yīng)用程序的完整步驟
- Unity C#打包AssetBundle與場(chǎng)景詳解
- C#利用VS中插件打包并發(fā)布winfrom程序
- c#打包文件解壓縮的實(shí)例
- C#打包應(yīng)用程序,與.NETFramework介紹
- 將c#編寫(xiě)的程序打包成應(yīng)用程序的實(shí)現(xiàn)步驟分享(安裝,卸載) 圖文
- c#項(xiàng)目將dll打包到exe中的步驟
相關(guān)文章
C#?HttpClient超時(shí)重試機(jī)制詳解
超時(shí)重試的實(shí)現(xiàn)方式可以使用循環(huán)結(jié)構(gòu),在請(qǐng)求發(fā)起后等待一定時(shí)間,若超時(shí)未收到響應(yīng),則再次發(fā)起請(qǐng)求,循環(huán)次數(shù)可以根據(jù)實(shí)際情況進(jìn)行設(shè)置,一般建議不超過(guò)三次,這篇文章主要介紹了C#?HttpClient超時(shí)重試,需要的朋友可以參考下2023-06-06c#使用dynamic類(lèi)型優(yōu)化反射的方法
dynamic是FrameWork4.0的新特性,下面這篇文章主要給大家介紹了關(guān)于c#使用dynamic類(lèi)型優(yōu)化反射的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-12-12C#實(shí)現(xiàn)虛擬鍵盤(pán)的實(shí)例詳解
這篇文章主要為大家詳細(xì)介紹了如何利用C#實(shí)現(xiàn)虛擬鍵盤(pán),文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)C#有一定的幫助,感興趣的小伙伴可以跟隨小編一起了解一下2022-12-12C#實(shí)現(xiàn)字符串首字母大寫(xiě)的方法示例
這篇文章主要給大家介紹了關(guān)于利用C#實(shí)現(xiàn)字符串首字母大寫(xiě)的相關(guān)資料,這是在最近工作中遇到的一個(gè)需求,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2018-01-01基于C#實(shí)現(xiàn)自定義計(jì)算的Excel數(shù)據(jù)透視表
數(shù)據(jù)透視表(Pivot?Table)是一種數(shù)據(jù)分析工具,通常用于對(duì)大量數(shù)據(jù)進(jìn)行匯總、分析和展示,本文主要介紹了C#實(shí)現(xiàn)自定義計(jì)算的Excel數(shù)據(jù)透視表的相關(guān)知識(shí),感興趣的可以了解下2023-12-12DevExpress之ChartControl實(shí)現(xiàn)時(shí)間軸實(shí)例
這篇文章主要介紹了DevExpress中ChartControl實(shí)現(xiàn)時(shí)間軸的方法,涉及相關(guān)C#繪圖程序用法,具有一定的實(shí)用價(jià)值,需要的朋友可以參考下2014-10-10C#實(shí)現(xiàn)獲取設(shè)置IP地址小工具
c# 開(kāi)發(fā),方便更改IP地址。由于公司和家里的ip設(shè)置不一樣,公司要求手動(dòng)設(shè)置,在家可以自動(dòng)獲取IP,切都是無(wú)線(xiàn)網(wǎng)絡(luò),為了方便操作,故做了這個(gè)小工具!2015-06-06c#?復(fù)寫(xiě)Equals方法的實(shí)現(xiàn)
本文主要介紹了c#?復(fù)寫(xiě)Equals方法的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05