unity xml加密解密源码

    //加密方法
  public void encryptionClick()
  {




      //接受加载过来的对象的内容
      inputText = Resources.Load("Test1").ToString();
      
      //调用加密的方法,返回的是一段字符串 ,参数以此是要加密的内容,密匙
      strEncryption = encryptionContent(inputText, strkeyValue);


      //写入
      StreamWriter writer;
      //找到文件夹
      FileInfo info1 = new FileInfo(Application.dataPath + "/Resources/" + "Test1.xml");
      //删除掉
      info1.Delete();
      //创建新的文本
      writer = info1.CreateText();
      //写入
      writer.WriteLine(strEncryption);
      //关闭基础流
      writer.Close();


      Debug.Log(strEncryption + "我加密了");
  }
    //解密方法
  public void decipherClick()
  {


      string data = Resources.Load("Test1").ToString();
      
      inputText = decipheringContent(data, strkeyValue);
      print(inputText);
      //xml加载
      doc.LoadXml(inputText);
      rootElem = doc.DocumentElement;   //获取根节点  


     
  }


 
    
      


  /// <summary>
  /// 内容加密
  /// </summary>
  /// <param name="ContentInfo">要加密内容</param>
  /// <param name="strkey">key值</param>
  /// <returns></returns>
  public string encryptionContent(string ContentInfo, string strkey)
  {
      byte[] keyArray = UTF8Encoding.UTF8.GetBytes(strkey);
      RijndaelManaged encryption = new RijndaelManaged();
      encryption.Key = keyArray;
      encryption.Mode = CipherMode.ECB;
      encryption.Padding = PaddingMode.PKCS7;
      ICryptoTransform cTransform = encryption.CreateEncryptor();
      byte[] _EncryptArray = UTF8Encoding.UTF8.GetBytes(ContentInfo);
      byte[] resultArray = cTransform.TransformFinalBlock(_EncryptArray, 0, _EncryptArray.Length);
      return Convert.ToBase64String(resultArray, 0, resultArray.Length);
  }


  /// <summary>
  /// 内容解密
  /// </summary>
  /// <param name="encryptionContent">被加密内容</param>
  /// <param name="strkey">key值</param>
  /// <returns></returns>
  public string decipheringContent(string encryptionContent, string strkey)
  {
      byte[] keyArray = UTF8Encoding.UTF8.GetBytes(strkey);
      RijndaelManaged decipher = new RijndaelManaged();
      decipher.Key = keyArray;
      decipher.Mode = CipherMode.ECB;
      decipher.Padding = PaddingMode.PKCS7; 
      ICryptoTransform cTransform = decipher.CreateDecryptor();
      byte[] _EncryptArray = Convert.FromBase64String(encryptionContent);
      byte[] resultArray = cTransform.TransformFinalBlock(_EncryptArray, 0, _EncryptArray.Length);
      return UTF8Encoding.UTF8.GetString(resultArray);
  }
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
xml加密XML Encryption)是w3c加密xml的标准。这个加密过程包括加密xml文档的元素及其子元素,通过加密xml的初始内容将被替换,但其xml格式仍然被完好的保留。 介绍 我们有3个加密xml的方法 1、仅仅使用对称加密的方法加密xml 这种加密方法只使用一个密钥,也就是说无论是加密xml还是解密xml都使用一个相同的密钥。因为这个密钥不会在被加密xml中保存,所以我们需要在加密解密的过程中加载这个密钥并保护它不被窃取。 2、使用对称加密和非对称加密相结合的方法来加密xml 这种方法需要一个用于加密数据的对称密钥和一个用于保护这个对称密钥的非对称密钥。被加密的对称密钥和被加密的数据一起保存在xml文档中。当用私有非对称密钥解密密钥的时候要用公开非对称密钥对密钥进行加密。 本文就将使用这种方法。想学到其他更多的方法请参看MSDN等到更多的信息。 (译者注:非对称加密算法需要两个密钥:公开密钥(publickey)和私有密钥(privatekey)。公开密钥与私有密钥是一对,如果用公开密钥对数据进行加密,只有用对应的私有密钥才能解密;如果用私有密钥对数据进行加密,那么只有用对应的公开密钥才能解密。因为加密解密使用的是两个不同的密钥,所以这种算法叫作非对称加密算法。) 3、使用X.509加密xml,这种方法是用X.509作为非对称密钥,它由诸如VeriSign之类的第三方提供。 方法 不管xml加密是如何完成的,保存加密数据总是用两种方法之一。 1、加密后所有的元素都被命名为 2、加密后只有数据被替换,而元素名称仍然是可读的,不会发生变化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值