[代码示例]如何在ASP.NET中获取随机生成的cookie加密与验证密钥

本文是 从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
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值