• [代码示例]如何在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(nullnew object[] { validationKeyArray, validationKeyArray.Length });
            
    //将验证密钥字节数组转换为16进制表示的字符串
            string DecryptionKey = (string)byteArrayToHexString.Invoke(nullnew object[] { decryptionKeyArray, decryptionKeyArray.Length });
            
    //将加密密钥字节数组转换为16进制表示的字符串

            
    //作者Blog: http://dudu.cnblogs.com
  • 相关阅读:
    经典基础算法之面试题(系列一)
    Shell脚本中的二维字符串列表
    网络字节流数据解析组件的设计与实现Circular Buffer(Ring Buffer)
    Django开发环境搭建(Windows+Python2.6)
    C++中堆(优先队列)的应用:make_heap, pop_heap, push_heap, sort_heap, priority_queue
    求逆序数的快速算法归并排序
    经典基础算法之BST详解(系列二)
    PHP数组去重
    微信小程序分享设置
    微信小程序判断开发环境
  • 原文地址:https://www.cnblogs.com/dudu/p/350441.html
Copyright © 2020-2023  润新知