• [代码示例]如何在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
  • 相关阅读:
    JavaWeb核心编程之(四.1)JSP
    一起来说 Vim 语
    你应该知道的基础 Git 命令
    Git 系列(五):三个 Git 图形化工具
    Git 系列(四):在 Git 中进行版本回退
    Git 系列(三):建立你的第一个 Git 仓库
    Git 系列(二):初步了解 Git
    Git 系列(一):什么是 Git
    JavaWeb核心编程之(三.6)HttpServlet
    多线程:子线程执行完成后通知主线程
  • 原文地址:https://www.cnblogs.com/dudu/p/350441.html
Copyright © 2020-2023  润新知