下面是我的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=";
///
/// 加密
///
/// 明文
///
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;
}
}
这两部分代码的加密结果不同,无法兼容,请问是什么问题啊?

热AI工具

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

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

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

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

Atom编辑器mac版下载
最流行的的开源编辑器

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

Dreamweaver CS6
视觉化网页开发工具