当前位置:首页 > 计算机相关 > .net专区 > 正文内容

python和C# 的DES3加密通信

piikee3年前 (2019-11-20).net专区706

python和C#的兼容DES3通讯,triple des 通用C#和python。C#和python的兼容加密通讯方式

C# DES3加密模块:

 public static string Encrypt(string text, string iv, string key)//要加密的内容,IV,KEY
{
try
{
var provider = new DESCryptoServiceProvider
{
Key = Encoding.UTF8.GetBytes(key),
IV = Encoding.UTF8.GetBytes(iv)
};
var bytes = Encoding.UTF8.GetBytes(text);
using (var memoryStream = new MemoryStream())
{
using (var cryptoStream = new CryptoStream(memoryStream, provider.CreateEncryptor(), CryptoStreamMode.Write))
{
cryptoStream.Write(bytes, 0, bytes.Length);
cryptoStream.FlushFinalBlock();
var builder = new StringBuilder();
foreach (var num in memoryStream.ToArray())
{
builder.AppendFormat("{0:x2}", num);
}
return builder.ToString();
}
}
}
catch (Exception)
{
return null;
}
}

C# DES3解密模块:

    public static string Decrypt(string text, string iv, string key)//要加密的内容,IV,KEY
{
var provider = new DESCryptoServiceProvider
{
Key = Encoding.UTF8.GetBytes(key),
IV = Encoding.UTF8.GetBytes(iv)
};
var buffer = new byte[text.Length / 2];
for (var i = 0; i < text.Length / 2; i++)
{
var num2 = Convert.ToInt32(text.Substring(i * 2, 2), 0x10);
buffer[i] = (byte)num2;
}
using (var memoryStream = new MemoryStream())
{
using (var cryptoStream = new CryptoStream(memoryStream, provider.CreateDecryptor(), CryptoStreamMode.Write))
{
cryptoStream.Write(buffer, 0, buffer.Length);
cryptoStream.FlushFinalBlock();
return Encoding.UTF8.GetString(memoryStream.ToArray());
}
}
}

python DES3加密模块:

 
import pyDes
k = pyDes.des(key, pyDes.CBC,iv, pad=None, padmode=pyDes.PAD_PKCS5)
oktext=k.encrypt(text)

python DES3解密模块:

 
import pyDes
k = pyDes.des(key, pyDes.CBC,iv, pad=None, padmode=pyDes.PAD_PKCS5)
oktext=k.decrypt(text)

扫描二维码推送至手机访问。

版权声明:本文由萍客小居发布,如需转载请注明出处。

本文链接:https://www.piikee.net/1364.html

分享给朋友:

相关文章

带后缀判别的文件上传asp.net程序

Default.aspx.csusing System;using System.Collections;using System.Configuration;using System.Data;using System.Linq;usin...

Power Designer反向数据库时的一个问题

Power Designer反向数据库时,遇到一个问题,如下:弹出警告框Unable to list the users.[Microsoft][ODBC SQL Server Driver][SQL Server]无法预定义语句SQLST...

让SQL Server2005允许远程连接

在尝试从远程计算机连接到 Microsoft SQL Server 2005 实例时,可能会接收到错误消息。在使用任何程序连接到 SQL Server 时都可能会发生此问题。例如,在使用 SQLCMD 实用工具连接到 SQL Server...

Windows 7下IIS+VS2008+Office2007无错完美安装方法

(1)先把IIS给装上。(2)安装VS2008。(3)安装Office2007。注意顺序,还有VS2008必须解压出来安装,不能用虚拟光驱。仅此而已。...

SQL语句重命名数据库表和表中的列

A.   重命名表将表   oldTableName  重命名为  newTableName :EXEC   sp_rename   'oldTableName','newTableName'B.   重命名列将表 EMIS  中的列  ...

asp.net实现动态显示当前时间

asp.net实现动态显示时间的两个方法方法一:不用javascrip,而是用了AJAX。(开销比较大,每秒向服务器请求一次时间)Default.aspx页面:先拉一个ScriptManager控件到页面,然后拉一个UpdatePanel控...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。