如何在ASP.NET中获取随机生成的cookie加密与验证密钥

王朝asp·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

本文是从ASP.NE T 1.1升级到ASP.NET 2.0需要考虑的Cookie问题的补充,通过示例代码说明如何通过反射在ASP.NET 1.1与ASP.NET 2.0中获取随机生成的cookie加密与验证密钥。

ASP.NET 1.1示例代码:

object machineKeyConfig = HttpContext.Current.GetConfig("system.web/machineKey");

//得到System.Web.Configuration.MachineKey+MachineKeyConfig的实例,MachineKeyConfig是MachineKey的嵌套类

Type machineKeyType = machineKeyConfig.GetType().Assembly.GetType("System.Web.Configuration.MachineKey");

//得到System.Web.Configuration.MachineKey类型

BindingFlags bf = BindingFlags.NonPublic | BindingFlags.Static;

//设置绑定标志

MethodInfo byteArrayToHexString = machineKeyType.GetMethod("ByteArrayToHexString", bf);

//通过反射获取MachineKey中的ByteArrayToHexString方法,该方法用于将字节数组转换为16进制表示的字符串

Byte[] validationKey = (Byte[])machineKeyType.GetField("s_validationKey",bf).GetValue(machineKeyConfig);

//获取验证密钥字节数组

SymmetricAlgorithm algorithm = (SymmetricAlgorithm)machineKeyType.GetField("s_oDes",bf).GetValue(machineKeyConfig);

Byte[] decryptionKey = algorithm.Key;

//获取加密密钥字节数组

string ValidationKey = (string)byteArrayToHexString.Invoke(null,new object[]{validationKey,validationKey.Length});

//将验证密钥字节数组转换为16进制表示的字符串

string DecryptionKey = (string)byteArrayToHexString.Invoke(null,new object[]{decryptionKey,decryptionKey.Length});

//将加密密钥字节数组转换为16进制表示的字符串

ASP.NET 2.0示例代码:

System.Web.Configuration.MachineKeySection machineKeySection = new System.Web.Configuration.MachineKeySection();

//直接创建MachineKeySection的实例,ASP.NET 2.0中用machineKeySection取代ASP.NET 1.1中的MachineKey,并且可以直接访问,没有被internal保护。

Type type = typeof(System.Web.Configuration.MachineKeySection);//或者machineKeySection.GetType();

PropertyInfo propertyInfo = type.GetProperty("ValidationKeyInternal", BindingFlags.NonPublic | BindingFlags.Instance);

Byte[] validationKeyArray = (Byte[])propertyInfo.GetValue(machineKeySection, null);

//获取随机生成的验证密钥字节数组

propertyInfo = type.GetProperty("DecryptionKeyInternal", BindingFlags.NonPublic | BindingFlags.Instance);

Byte[] decryptionKeyArray = (Byte[])propertyInfo.GetValue(machineKeySection, null);

//获取随机生成的加密密钥字节数组

MethodInfo byteArrayToHexString = type.GetMethod("ByteArrayToHexString", BindingFlags.Static | BindingFlags.NonPublic);

//通过反射获取MachineKeySection中的ByteArrayToHexString方法,该方法用于将字节数组转换为16进制表示的字符串

string validationKey = (string)byteArrayToHexString.Invoke(null, new object[] { validationKeyArray, validationKeyArray.Length });

//将验证密钥字节数组转换为16进制表示的字符串

string DecryptionKey = (string)byteArrayToHexString.Invoke(null, new object[] { decryptionKeyArray, decryptionKeyArray.Length });

//将加密密钥字节数组转换为16进制表示的字符串

//作者Blog: http://dudu.cnblogs.com

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航