zoukankan      html  css  js  c++  java
  • 传递参数安全验证代码示例

    在开发内部系统当中,我们经常使用参数进行传递,但由于明文传递会涉及到安全问题。所以我们一般都是加密明文再和明文一起传递,接受方再检测是否被明文是否中途被篡改。

    表达不好,还是看代码吧!

    上图是我对字符串加密和解密后的对照图。

    下面是才是我调用的类:

    /// <summary>
    /// 对称加密处理类
    /// </summary>
    public class SymmCrypt
    {
        private SymmetricAlgorithm mobjCryptoService;
    
        public enum SymmProvEnum
        {
            DES, RC2, Rijndael
        }
    
        public SymmCrypt()
        {
            this.mobjCryptoService = new DESCryptoServiceProvider();
        }
    
        /// <summary>
        /// 构造函数,选择加密方式
        /// </summary>
        /// <param name="encryptType"></param>
        public SymmCrypt(SymmProvEnum encryptType)
        {
            switch (encryptType)
            {
                case SymmProvEnum.DES:
                    mobjCryptoService = new DESCryptoServiceProvider();
                    break;
                case SymmProvEnum.RC2:
                    mobjCryptoService = new RC2CryptoServiceProvider();
                    break;
                case SymmProvEnum.Rijndael:
                    mobjCryptoService = new RijndaelManaged();
                    break;
    
            }
        }
    
        /// <summary>
        /// 利用MD5加密算法加密
        /// </summary>
        /// <param name="strIN">需要加密的字符串</param>
        /// <returns>返回加密过的字符串</returns>
        public static string MD5Encrypt(string strIN)
        {
            byte[] tmpByte;
            MD5 md5 = new MD5CryptoServiceProvider();
            tmpByte = md5.ComputeHash(GetBytesBySting(strIN));
            md5.Clear();
            return GetStringByBytes(tmpByte);
    
        }
    
        /// <summary>
        /// 利用SHA1加密算法加密
        /// </summary>
        /// <param name="strIN">需要加密的字符串</param>
        /// <returns>返回加密过的字符串</returns>
        public static string SHA1Encrypt(string strIN)
        {
            byte[] tmpByte;
            SHA1 sha1 = new SHA1CryptoServiceProvider();
            tmpByte = sha1.ComputeHash(GetBytesBySting(strIN));
            sha1.Clear();
            return GetStringByBytes(tmpByte);
    
        }
    
        /// <summary>
        /// 利用SHA256加密算法加密
        /// </summary>
        /// <param name="strIN">需要加密的字符串</param>
        /// <returns>返回加密过的字符串</returns>
        public static string SHA256Encrypt(string strIN)
        {
            byte[] tmpByte;
            SHA256 sha256 = new SHA256Managed();
            tmpByte = sha256.ComputeHash(GetBytesBySting(strIN));
            sha256.Clear();
            return GetStringByBytes(tmpByte);
        }
    
        /// <summary>
        /// 利用SHA512加密算法加密
        /// </summary>
        /// <param name="strIN">需要加密的字符串</param>
        /// <returns>返回加密过的字符串</returns>
        public static string SHA512Encrypt(string strIN)
        {
            byte[] tmpByte;
            SHA512 sha512 = new SHA512Managed();
            tmpByte = sha512.ComputeHash(GetBytesBySting(strIN));
            sha512.Clear();
            return GetStringByBytes(tmpByte);
    
        }
    
        #region Base64加密
        /// <summary>
        /// Base64加密
        /// </summary>
        /// <param name="text">要加密的字符串</param>
        /// <returns></returns>
        public static string EncodeBase64(string text)
        {
            //如果字符串为空,则返回
            if (string.IsNullOrEmpty(text))
            {
                return "";
            }
    
            try
            {
                char[] Base64Code = new char[]{'A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T',
                                                'U','V','W','X','Y','Z','a','b','c','d','e','f','g','h','i','j','k','l','m','n',
                                                'o','p','q','r','s','t','u','v','w','x','y','z','0','1','2','3','4','5','6','7',
                                                '8','9','+','/','='};
                byte empty = (byte)0;
                ArrayList byteMessage = new ArrayList(Encoding.Default.GetBytes(text));
                StringBuilder outmessage;
                int messageLen = byteMessage.Count;
                int page = messageLen / 3;
                int use = 0;
                if ((use = messageLen % 3) > 0)
                {
                    for (int i = 0; i < 3 - use; i++)
                        byteMessage.Add(empty);
                    page++;
                }
                outmessage = new System.Text.StringBuilder(page * 4);
                for (int i = 0; i < page; i++)
                {
                    byte[] instr = new byte[3];
                    instr[0] = (byte)byteMessage[i * 3];
                    instr[1] = (byte)byteMessage[i * 3 + 1];
                    instr[2] = (byte)byteMessage[i * 3 + 2];
                    int[] outstr = new int[4];
                    outstr[0] = instr[0] >> 2;
                    outstr[1] = ((instr[0] & 0x03) << 4) ^ (instr[1] >> 4);
                    if (!instr[1].Equals(empty))
                        outstr[2] = ((instr[1] & 0x0f) << 2) ^ (instr[2] >> 6);
                    else
                        outstr[2] = 64;
                    if (!instr[2].Equals(empty))
                        outstr[3] = (instr[2] & 0x3f);
                    else
                        outstr[3] = 64;
                    outmessage.Append(Base64Code[outstr[0]]);
                    outmessage.Append(Base64Code[outstr[1]]);
                    outmessage.Append(Base64Code[outstr[2]]);
                    outmessage.Append(Base64Code[outstr[3]]);
                }
                return outmessage.ToString();
            }
            catch (Exception ex)
            {
                throw ex;
            }
        }
        #endregion
    
        #region Base64解密
        /// <summary>
        /// Base64解密
        /// </summary>
        /// <param name="text">要解密的字符串</param>
        public static string DecodeBase64(string text)
        {
            ////如果字符串为空,则返回
            //if (ValidationHelper.IsNullOrEmpty<string>(text))
            //{
            //    return "";
            //}
    
            //将空格替换为加号
            text = text.Replace(" ", "+");
    
            try
            {
                if ((text.Length % 4) != 0)
                {
                    return "包含不正确的BASE64编码";
                }
                if (!Regex.IsMatch(text, "^[A-Z0-9/+=]*$", RegexOptions.IgnoreCase))
                {
                    return "包含不正确的BASE64编码";
                }
                string Base64Code = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
                int page = text.Length / 4;
                ArrayList outMessage = new ArrayList(page * 3);
                char[] message = text.ToCharArray();
                for (int i = 0; i < page; i++)
                {
                    byte[] instr = new byte[4];
                    instr[0] = (byte)Base64Code.IndexOf(message[i * 4]);
                    instr[1] = (byte)Base64Code.IndexOf(message[i * 4 + 1]);
                    instr[2] = (byte)Base64Code.IndexOf(message[i * 4 + 2]);
                    instr[3] = (byte)Base64Code.IndexOf(message[i * 4 + 3]);
                    byte[] outstr = new byte[3];
                    outstr[0] = (byte)((instr[0] << 2) ^ ((instr[1] & 0x30) >> 4));
                    if (instr[2] != 64)
                    {
                        outstr[1] = (byte)((instr[1] << 4) ^ ((instr[2] & 0x3c) >> 2));
                    }
                    else
                    {
                        outstr[2] = 0;
                    }
                    if (instr[3] != 64)
                    {
                        outstr[2] = (byte)((instr[2] << 6) ^ instr[3]);
                    }
                    else
                    {
                        outstr[2] = 0;
                    }
                    outMessage.Add(outstr[0]);
                    if (outstr[1] != 0)
                        outMessage.Add(outstr[1]);
                    if (outstr[2] != 0)
                        outMessage.Add(outstr[2]);
                }
                byte[] outbyte = (byte[])outMessage.ToArray(Type.GetType("System.Byte"));
                return Encoding.Default.GetString(outbyte);
            }
            catch (Exception ex)
            {
                throw ex;
            }
        }
        #endregion
    
    
        /// <summary>
        /// 把字节转换成字符串
        /// </summary>
        /// <param name="Byte">需要转换字节数组</param>
        /// <returns>转换后的字符串</returns>
        private static string GetStringByBytes(byte[] Byte)
        {
            string tmpString = "";
            //tmpString = UTF8Encoding.Default.GetString(Byte);
            tmpString = BitConverter.ToString(Byte);
            return tmpString;
        }
    
        /// <summary>
        /// 把字符串转换成字节数组
        /// </summary>
        /// <param name="strKey">需要转换的字符串</param>
        /// <returns>转换后的字节数组</returns>
        private static byte[] GetBytesBySting(string strKey)
        {
            int tmpStrLen = strKey.Length;
            byte[] tmpByte = new byte[tmpStrLen - 1];
            tmpByte = UTF8Encoding.Default.GetBytes(strKey);
            return tmpByte;
        }
    
    
        /// <summary>
        /// 获取Key的字节
        /// </summary>
        /// <param name="keyString">Key字符串</param>
        /// <returns>转换后的字节形式</returns>
        private byte[] GetKeyBytes(string keyString)
        {
            string sTemp = "";
            if (mobjCryptoService.LegalKeySizes.Length > 0)
            {
                int lessSize = 0;
                int moreSize = mobjCryptoService.LegalKeySizes[0].MinSize;
                while (keyString.Length * 8 > moreSize)
                {
                    lessSize = moreSize;
                    moreSize += mobjCryptoService.LegalKeySizes[0].SkipSize;
                    System.Threading.Thread.Sleep(0);
                }
                sTemp = keyString.PadRight(moreSize / 8, '_');
            }
            else
                sTemp = keyString;
            return ASCIIEncoding.ASCII.GetBytes(sTemp);
        }
    
        /// <summary>
        /// 获取IV向量的字节
        /// </summary>
        /// <param name="ivString">IV向量字符串</param>
        /// <returns>转换后的字节形式</returns>
        private byte[] GetIvBytes(string ivString)
        {
            ivString += "diksk.sl";
            ivString = ivString.Substring(0, this.mobjCryptoService.IV.Length);
            return ASCIIEncoding.ASCII.GetBytes(ivString);
        }
    
    
    
        /// <summary>
        /// 对输入的字符串进行加密
        /// </summary>
        /// <param name="sourceString">需要加密的原始字符串</param>
        /// <param name="keyString">加密密钥</param>
        /// <param name="ivString">加密向量</param>
        /// <returns>加密后的字符串</returns>
        public string Encrypt(string sourceString, string keyString, string ivString)
        {
            byte[] data = Encoding.Default.GetBytes(sourceString);
            byte[] result;
            mobjCryptoService.Key = GetKeyBytes(keyString);
            mobjCryptoService.IV = GetIvBytes(ivString);
            ICryptoTransform desencrypt = mobjCryptoService.CreateEncryptor();
            result = desencrypt.TransformFinalBlock(data, 0, data.Length);
            string desString = "";
            for (int i = 0; i < result.Length; i++)
            {
                desString += result[i].ToString() + "-";
            }
    
            //return desString.TrimEnd('-');
            return BitConverter.ToString(result);
        }
    
        /// <summary>
        /// 对输入的密文字符串进行解密
        /// </summary>
        /// <param name="sourceString">需要解密的密文字符串</param>
        /// <param name="keyString">解密密钥</param>
        /// <param name="ivString">解密向量</param>
        /// <returns>解密后的原始字符串</returns>
        public string Decrypt(string sourceString, string keyString, string ivString)
        {
            try
            {
                string[] sInput = sourceString.Split("-".ToCharArray());
                byte[] data = new byte[sInput.Length];
                byte[] result;
                for (int i = 0; i < sInput.Length; i++)
                    data[i] = byte.Parse(sInput[i], System.Globalization.NumberStyles.HexNumber);
                mobjCryptoService.Key = GetKeyBytes(keyString);
                mobjCryptoService.IV = GetIvBytes(ivString);
                ICryptoTransform desencrypt = mobjCryptoService.CreateDecryptor();
                result = desencrypt.TransformFinalBlock(data, 0, data.Length);
                return Encoding.Default.GetString(result);
            }
            catch
            {
                return "error";
            }
        }
    
        
    }
  • 相关阅读:
    P1309 瑞士轮 (吸氧了)
    P1158 导弹拦截
    腾讯笔试题 构造回文(LCS问题)
    蓝桥杯之大臣的旅费(两次dfs)
    蓝桥杯之买不到的数目(数学公式或缩小范围+暴力)
    蓝桥杯之翻硬币(思维,找规律,贪心)
    蓝桥杯之 连号区间数(巧妙遍历)
    蓝桥杯之剪格子(经典dfs)
    蓝桥杯之带分数(全排列+暴力)
    面试题之O(n)内旋转字符串
  • 原文地址:https://www.cnblogs.com/flyfish2012/p/3431353.html
Copyright © 2011-2022 走看看