搜索
首页php教程php手册PHP和.NET关于3DES加密兼容问题

PHP和.NET关于3DES加密兼容问题

Jun 06, 2016 pm 07:45 PM
.net3desphp下面关于兼容加密问题

下面是我的C#加解密代码: classDES { //密钥 privateconststringsKey="nuhyrn83Y9LNeygnpq7AMN0aeRQN7kuv"; //矢量,矢量可以为空 privateconststringsIV="qciO6X+aPLw="; ///summary ///加密 ////summary ///paramname="Value"明文/param ///returns密文ba

下面是我的C#加解密代码:

 class DES

      {

          //密钥

          private const string sKey = "nuhyrn83Y9LNeygnpq7AMN0aeRQN7kuv";

  

          //矢量,矢量可以为空

          private const string sIV = "qciO6X+aPLw=";

  

          /// 

          /// 加密

          /// 

          /// 明文

          /// 密文 base64转码

          public static string EncryptString(string Value)

          {

              SymmetricAlgorithm mCSP = new TripleDESCryptoServiceProvider();

              ICryptoTransform ct;

              MemoryStream ms;

              CryptoStream cs;

              byte[] byt;

              mCSP.Key = Convert.FromBase64String(sKey);

              mCSP.IV = Convert.FromBase64String(sIV);

              Console.WriteLine("Key:" + mCSP.Key.ToString() + ",IV:" + mCSP.IV.ToString());

              //指定加密的运算模式

              mCSP.Mode = System.Security.Cryptography.CipherMode.ECB;

              //获取或设置加密算法的填充模式

              mCSP.Padding = System.Security.Cryptography.PaddingMode.PKCS7;

              ct = mCSP.CreateEncryptor(mCSP.Key, mCSP.IV);

              byt = Encoding.UTF8.GetBytes(Value);

              ms = new MemoryStream();

              cs = new CryptoStream(ms, ct, CryptoStreamMode.Write);

              cs.Write(byt, 0, byt.Length);

              cs.FlushFinalBlock();

              cs.Close();

              return Convert.ToBase64String(ms.ToArray());

          }

  

          /// 

          /// 解密

          /// 

          /// base64转码密文

          /// 明文

          public static string DecryptString(string Value)

          {

              SymmetricAlgorithm mCSP = new TripleDESCryptoServiceProvider();

              ICryptoTransform ct;

              MemoryStream ms;

              CryptoStream cs;

              byte[] byt;

              mCSP.Key = Convert.FromBase64String(sKey);

              mCSP.IV = Convert.FromBase64String(sIV);

              mCSP.Mode = System.Security.Cryptography.CipherMode.ECB;

              mCSP.Padding = System.Security.Cryptography.PaddingMode.PKCS7;

              ct = mCSP.CreateDecryptor(mCSP.Key, mCSP.IV);

              byt = Convert.FromBase64String(Value);

              ms = new MemoryStream();

              cs = new CryptoStream(ms, ct, CryptoStreamMode.Write);

              cs.Write(byt, 0, byt.Length);

              cs.FlushFinalBlock();

              cs.Close();

  

              return Encoding.UTF8.GetString(ms.ToArray());

          }

      }

 下面是我的PHP加解密代码:

 class DesCrypt {

  /**

   * 使用3DES加密源数据

   * @param string $oriSource 源数据

   * @param string $key       密钥

   * @param string $defaultIV 加解密向量

   * @return string $result   密文

   */

  public function encryptByTDES($oriSource, $key, $defaultIV) {

  $key = base64_decode ( $key ); //结果为24位

  $iv = base64_decode ( $defaultIV ); //结果为8位

  $oriSource = $this->addPKCS7Padding ( $oriSource );

  $td = mcrypt_module_open ( MCRYPT_3DES, '', MCRYPT_MODE_CBC, '' );

  mcrypt_generic_init ( $td, $key, $iv );

  $result = mcrypt_generic ( $td, $oriSource );

  mcrypt_generic_deinit ( $td );

  mcrypt_module_close ( $td );

  $result = base64_encode ( $result );

  return $result;

  }

  

  /**

   * 使用3DES解密密文

   * @param string $encryptedData 密文

   * @param string $key           密钥

   * @param string $defaultIV     加解密向量

   * @return string $result       解密后的原文

   */

  public function decryptByTDES($encryptedData, $key, $defaultIV) {

  $key = base64_decode ( $key ); //结果为24位

  $iv = base64_decode ( $defaultIV ); //结果为8位

  $encryptedData = base64_decode ( $encryptedData );

  $td = mcrypt_module_open ( MCRYPT_3DES, '', MCRYPT_MODE_CBC, '' );

  mcrypt_generic_init ( $td, $key, $iv );

  $result = mdecrypt_generic ( $td, $encryptedData );

  mcrypt_generic_deinit ( $td );

  mcrypt_module_close ( $td );

  $result = $this->stripPKSC7Padding ( $result );

  return $result;

  }

  

  /**

   * 为字符串添加PKCS7 Padding

   * @param string $source    源字符串

   */

  private function addPKCS7Padding($source) {

  $block = mcrypt_get_block_size ( 'tripledes', 'cbc' );

  $pad = $block - (strlen ( $source ) % $block);

  if ($pad 

  $char = chr ( $pad );

  $source .= str_repeat ( $char, $pad );

  }

  return $source;

  }

  

  /**

   * 去除字符串末尾的PKCS7 Padding

   * @param string $source    带有padding字符的字符串

   */

  public function stripPKSC7Padding($source) {

  $block = mcrypt_get_block_size ( 'tripledes', 'cbc' );

  $char = substr ( $source, - 1, 1 );

  $num = ord ( $char );

  if ($num > 8) {

  return $source;

  }

  $len = strlen ( $source );

  for($i = $len - 1; $i >= $len - $num; $i --) {

  if (ord ( substr ( $source, $i, 1 ) ) != $num) {

  return $source;

  }

  }

  $source = substr ( $source, 0, - $num );

  return $source;

  }

  }

 这两部分代码的加密结果不同,无法兼容,请问是什么问题啊?

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 个月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
1 个月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
1 个月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它们
1 个月前By尊渡假赌尊渡假赌尊渡假赌

热工具

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

安全考试浏览器

安全考试浏览器

Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具