A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 王海亮 中级黑马   /  2012-7-18 14:05  /  1166 人查看  /  1 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

我要做一个加密记事本的小程序  要把编辑完成后的.txt文件 加密成未知程序 如何获取文件名并对名称和后缀名进行异或运算?

评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

1 个回复

正序浏览
//默认密钥向量
private static byte[] Keys = { 0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF };
//加密成功返回加密后的字符串,失败返回源串
public static string Encode(string encryptString, string encryptKey)
{
       encryptKey = encryptKey.PadRight(8, ' ');
       byte[] rgbKey = Encoding.UTF8.GetBytes(encryptKey.Substring(0, 8));
       byte[] rgbIV = Keys;
       byte[] inputByteArray = Encoding.UTF8.GetBytes(encryptString);
       DESCryptoServiceProvider dCSP = new DESCryptoServiceProvider();
       MemoryStream mStream = new MemoryStream();
       CryptoStream cStream = new CryptoStream(mStream, dCSP.CreateEncryptor(rgbKey, rgbIV), CryptoStreamMode.Write);
       cStream.Write(inputByteArray, 0, inputByteArray.Length);
       cStream.FlushFinalBlock();
        return Convert.ToBase64String(mStream.ToArray());
   }
//解密成功返回解密后的字符串,失败返源串
public static string Decode(string decryptString, string decryptKey)
{
      try
      {
             decryptKey = decryptKey.PadRight(8, ' ');
             byte[] rgbKey = Encoding.UTF8.GetBytes(decryptKey);
             byte[] rgbIV = Keys;
             byte[] inputByteArray = Convert.FromBase64String(decryptString);
             DESCryptoServiceProvider DCSP = new DESCryptoServiceProvider();
             MemoryStream mStream = new MemoryStream();
             CryptoStream cStream = new CryptoStream(mStream, DCSP.CreateDecryptor(rgbKey, rgbIV), CryptoStreamMode.Write);
             cStream.Write(inputByteArray, 0, inputByteArray.Length);
             cStream.FlushFinalBlock();
              return Encoding.UTF8.GetString(mStream.ToArray());
       }
            catch
            {
                return "";
            }
}


评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马