明輝手游網(wǎng)中心:是一個免費提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺!

從COM組件調(diào)用.NET組件編程實戰(zhàn)

[摘要]在我的編程實踐中,需要從.NET的Web Form頁面?zhèn)鬟f加密的字符串信息(如用戶名和密碼等)到ASP頁面,然后在該頁面對該加密字符串進(jìn)行解密。如果傳遞的不是加密串,通過GET或POST的方式就可以直接傳遞并在ASP頁面中接收,但問題是在.NET的Web Form頁面中加了密的字符串如何才能在AS...
在我的編程實踐中,需要從.NET的Web Form頁面?zhèn)鬟f加密的字符串信息(如用戶名和密碼等)到ASP頁面,然后在該頁面對該加密字符串進(jìn)行解密。如果傳遞的不是加密串,通過GET或POST的方式就可以直接傳遞并在ASP頁面中接收,但問題是在.NET的Web Form頁面中加了密的字符串如何才能在ASP中進(jìn)行解密呢?這主要由于ASP并不能直接訪問由.NET提供的托管類和組件。這時我們就只能借助于COM組件來實現(xiàn)了,通過COM的互操作我們可通過.NET生成COM組件,然后在ASP頁面中訪問該COM組件就可以了。



本文實現(xiàn)的是將加密的用戶名與密碼從.aspx頁面?zhèn)鬟f到.asp頁面,下面就來介紹這些操作的具體步驟:



一、制作具有加密、解密字符串的.NET程序集(VS.NET類庫工程)

這個程序集將會變成COM組件,使用DES對稱加密代碼,可以加密碼,可以加密解密,支持中文!

//文件名:StringCrypt.cs

using System;

using System.Runtime.InteropServices;

using System.Security.Cryptography;

using System.IO;

using System.Text;



namespace jonson

{

// 首先建立接口,這個是Com必須使用的

[Guid("BF6F9C17-37FA-4ad9-9601-C11AD5316F2C")]

public interface IEncrypt

{

string Encrypt(string pToEncrypt,string sKey);

string Decrypt(string pToDecrypt,string sKey);

}



//接口的實現(xiàn)

[Guid("3FBDBB63-3C36-4602-89E1-73EDB0F167D0")]

public class StringCrypt : IEncrypt

{

// 加密的方法

public string Encrypt(string pToEncrypt, string sKey)

{

DESCryptoServiceProvider des = new DESCryptoServiceProvider();

//把字符串放到byte數(shù)組中

byte[] inputByteArray = Encoding.Default.GetBytes(pToEncrypt);

//byte[] inputByteArray=Encoding.Unicode.GetBytes(pToEncrypt);



//建立加密對象的密鑰和偏移量

//原文使用ASCIIEncoding.ASCII方法的GetBytes方法

//使得輸入密碼必須輸入英文文本

des.Key = ASCIIEncoding.ASCII.GetBytes(sKey);

des.IV = ASCIIEncoding.ASCII.GetBytes(sKey);

MemoryStream ms = new MemoryStream();

CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(),CryptoStreamMode.Write);

//Write the byte array into the crypto stream

//(It will end up in the memory stream)

cs.Write(inputByteArray, 0, inputByteArray.Length);

cs.FlushFinalBlock();

//Get the data back from the memory stream, and into a string

StringBuilder ret = new StringBuilder();

foreach(byte b in ms.ToArray())

{

//Format as hex

ret.AppendFormat("{0:X2}", b);

}

ret.ToString();

return ret.ToString();

}



// 解密的方法

public string Decrypt(string pToDecrypt, string sKey)

{

DESCryptoServiceProvider des = new DESCryptoServiceProvider();



//Put the input string into the byte array

byte[] inputByteArray = new byte[pToDecrypt.Length / 2];

for(int x = 0; x < pToDecrypt.Length / 2; x++)

{

int i = (Convert.ToInt32(pToDecrypt.Substring(x * 2, 2), 16));

inputByteArray[x] = (byte)i;

}



//建立加密對象的密鑰和偏移量,此值重要,不能修改

des.Key = ASCIIEncoding.ASCII.GetBytes(sKey);

des.IV = ASCIIEncoding.ASCII.GetBytes(sKey);

MemoryStream ms = new MemoryStream();

CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write);

//Flush the data through the crypto stream into the memory stream

cs.Write(inputByteArray, 0, inputByteArray.Length);

cs.FlushFinalBlock();



//Get the decrypted data back from the memory stream

//建立StringBuilder對象,CreateDecrypt使用的是流對象,必須把解密后的文本變成流對象

StringBuilder ret = new StringBuilder();



return System.Text.Encoding.Default.GetString(ms.ToArray());

}

}

}

說明:注意上面的Guid是使用vs.net工具菜單里面的創(chuàng)建guid工具生成的,這個每個Com組件所必須的。輸入密匙的時候,必須使用英文字符,區(qū)分大小寫,且字符數(shù)量是8個,不能多也不能少,否則出錯。



然后使用vs.net的“Vsitual Studio .Net工具”-->Vistual Studio .Net命令提示符。在命令行內(nèi)打下cd c:\ <回車>

sn -k myKey.snk<回車>

這樣就在C盤根目錄下生成一個名叫myKey.snk的強(qiáng)名稱文件,然后將其拷貝到上述工程目錄中(與StringCrypt.cs文件同目錄)后關(guān)閉提示符窗口。

在vs.net的那個類庫工程自動生成的AssemblyInfo.cs文件內(nèi)

把[assembly: AssemblyKeyFile("")]改成[assembly: AssemblyKeyFile("../../myKey.snk ")]

把[assembly: AssemblyVersion("1.0.*")]改成[assembly: AssemblyVersion("1.0.0.0")] // 注意:這時你的Com組件版本為1.0.0.0版



然后按Shift + Ctrl + B鍵生成dll庫(使用Release模式),StringCrypt.dll。這時候,程序集就建立成功了。



二、注冊該程序集并創(chuàng)建一個類型庫



仍然使用開始菜單中的Visual Studio .Net命令提示符

進(jìn)入你的項目目錄,假設(shè)為D:\project\bin\Release

在對話框中輸入

d:<回車>

cd project\bin\release<回車>

然后輸入 dir 命令可以看見StringCrypt.dll文件

然后輸入:regasm StringCrypt.dll<回車>

然后就在這個目錄下生成了StringCrypt.tlb類型庫文件。不要關(guān)閉此提示符窗口。

這時候,這個.dll的.net程序集就變成一個標(biāo)準(zhǔn)的Com組件了,但是還不能用,必須讓它變成全局Com組件。



這個regasm 實用程序?qū)?chuàng)建一個類型庫并在 Windows 注冊表中對其進(jìn)行注冊,以便 COM Services可以訪問.NET組件。在使用regasm對.NET進(jìn)行注冊之后,標(biāo)準(zhǔn)的Windows客戶就可以后期綁定組件中的類。注冊組件的過程必須一次完成。在.NET組件被注冊之后,所有的COM 客戶都可以訪問它。



三、將程序集添加到全局程序集緩存中



在使用.NET程序集之前,我們必須把程序集安裝到全局的高速緩存中。為此進(jìn)入Visual Studio .Net提示符窗口,輸入



gacutil /I StringCrypt.dll<回車>



這時,你的這個dll就被復(fù)制到全局程序集緩存中了。也就是說無論在這個電腦的哪個硬盤上都可以使用此dll組件了。



四、使用方法

1. 在source.aspx中生成加密串

using jonson;



jonson.StringCrypt crypt = new jonson.StringCrypt();

String tmpstr = username+"^"+password;

… …

strinfo = crypt.Encrypt(tmpstr,"fk58Fgju"); // fk58Fgju為密匙

Response.Redirect("target.asp?info="+strinfo);



2. 在target.asp頁面中接收并解密字符串

info = Request.QueryString(“info”)

set obj = Server.CreateObject("jonson.StringCrypt")



str1 = obj.Encrypt(info,"fk58Fgju") // 解密



本文的順利實現(xiàn),得到了網(wǎng)友TomMax(笑望人生)等人的大力幫助,在此表示衷心的感謝。