zoukankan      html  css  js  c++  java
  • c# 解密微信encryptedData字段

    参考链接:https://www.cnblogs.com/jetz/p/6384809.html

    我写了一个工具方法,直接照搬链接中的方法,还有一个工具类。

        public class Encrypt
        {
            #region SHA1解密
    
            /// <summary>
            /// 解密小程序的encryptedData
            /// </summary>
            /// <param name="encryptedData">加密的信息</param>
            /// <param name="sessionKey">key</param>
            /// <param name="iv">加密算法的初始向量</param>
            public static WxPhoneModel DescodeWxSHA1(string encryptedData, string sessionKey, string iv)
            {
                WxPhoneModel model = null;
                var res = AESDecrypt(encryptedData, sessionKey, iv);// {"phoneNumber":"152XXXX9583","purePhoneNumber":"1525XXXX3","countryCode":"86","watermark":{"timestamp":1525829586,"appid":"wx38XXXXXXXX43"}} 
                if (!string.IsNullOrEmpty(res))
                {
                    model = JObject.Parse(res).ToObject<WxPhoneModel>();
                }
                return model;
            }
    
            public static string AESDecrypt(string encryptedData, string sessionKey, string iv)
            {
                try
                {
                    //16进制数据转换成byte
                    var encryptedDataByte = Convert.FromBase64String(encryptedData);  // strToToHexByte(text);
                    var rijndaelCipher = new RijndaelManaged
                    {
                        Key = Convert.FromBase64String(sessionKey),
                        IV = Convert.FromBase64String(iv),
                        Mode = CipherMode.CBC,
                        Padding = PaddingMode.PKCS7
                    };
                    
                    var transform = rijndaelCipher.CreateDecryptor();
                    var plainText = transform.TransformFinalBlock(encryptedDataByte, 0, encryptedDataByte.Length);
                    var result = Encoding.Default.GetString(plainText);
                    
                    return result;
                }
                catch (Exception ex)
                {
                    return null;
    
                }
            }
    
            #endregion
        }
    public class WxPhoneModel { /// <summary> /// 用户绑定的手机号(国外手机号会有区号) /// </summary> public string PhoneNumber { set; get; } /// <summary> /// 没有区号的手机号 /// </summary> public string PurePhoneNumber { set; get; } /// <summary> /// 区号 /// </summary> public string CountryCode { set; get; } /// <summary> /// 水印 /// </summary> public WaterMarkModel WaterMark { set; get; } } public class WaterMarkModel { /// <summary> /// appid /// </summary> public string AppId { set; get; } /// <summary> /// 时间戳 /// </summary> public string TimeStamp { set; get; } }
  • 相关阅读:
    路由基础、多app共存,路由分配、路由分发(将app自己的路由分发给应用自身管理)、反解
    Django项目的创建与介绍,三件套,静态文件,配置Mysql完成数据迁移,单表ORM记录的增删改查
    Django框架导读
    Flask简易版本、Ajax、DOM操作,表单操作
    JQuery
    0820-信心赛
    codeforces比赛总(吐)结(嘈)
    洛谷P3403 跳楼机(最短路)
    求逆序对的三种方法
    NKOJ 3751 扫雷游戏
  • 原文地址:https://www.cnblogs.com/dawenyang/p/9012852.html
Copyright © 2011-2022 走看看