接着Java和C#交叉加密解密方法(DES)(一):
C#代码:
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using System.Security.Cryptography;
using System.Configuration;
using System.Web;
using System.IO;
namespace DES
{
public partial class Form1 : Form
{
private string DES_Key = "20100728";
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender, EventArgs e)
{
string jiami = textBox3.Text;
this.textBox1.Text = DESEnCode(jiami);
}
private void button2_Click(object sender, EventArgs e)
{
string jiemi = textBox1.Text;
textBox2.Text = DESDeCode(jiemi);
}
#region DESEnCode DES加密
public string DESEnCode(string pToEncrypt)
{
DESCryptoServiceProvider des = new DESCryptoServiceProvider();
byte[] inputByteArray = Encoding.GetEncoding("UTF-8").GetBytes(pToEncrypt);
des.Key = ASCIIEncoding.ASCII.GetBytes(DES_Key);
des.IV = ASCIIEncoding.ASCII.GetBytes(DES_Key);
MemoryStream ms = new MemoryStream();
CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write);
cs.Write(inputByteArray, 0, inputByteArray.Length);
cs.FlushFinalBlock();
StringBuilder ret = new StringBuilder();
foreach (byte b in ms.ToArray())
{
ret.AppendFormat("{0:X2}", b);
}
ret.ToString();
return ret.ToString();
}
#endregion
#region DESDeCode DES解密
public string DESDeCode(string pToDecrypt)
{
DESCryptoServiceProvider des = new DESCryptoServiceProvider();
byte[] inputByteArray = new byte[pToDecrypt.Length / 2];
for (int x = 0; x < pToDecrypt.Length / 2; x++)
{
int i = (Convert.ToInt32(pToDecrypt.Substring(x * 2, 2), 16));
inputByteArray[x] = (byte)i;
}
des.Key = ASCIIEncoding.ASCII.GetBytes(DES_Key);
des.IV = ASCIIEncoding.ASCII.GetBytes(DES_Key);
MemoryStream ms = new MemoryStream();
CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write);
cs.Write(inputByteArray, 0, inputByteArray.Length);
cs.FlushFinalBlock();
StringBuilder ret = new StringBuilder();
return System.Text.Encoding.UTF8.GetString(ms.ToArray());
}
#endregion
}
}
经过测试,可运行!附件为C#的打包文件。下载到本地运行后可以与上一篇Java的加密解密结果互相调试,得到一致的结果。
分享到:
相关推荐
DES加密方法JAVA和C#交叉加密解密代码
分别用C#、Java实现的RSA和DES加解密算法,包含demo源码,经实际项目验证。
C# DES加密解密方法类文件,下载后直接放入工程即可用了。
C#DES标准ECB加密解密示例源码,根据标准的C改的源码,与网上所搜索到的完全不一样,可以支持中文为密钥的加密,也可以支持为中文字符串的加密,如,密钥为:替天行道,明文为:来自替天行道的C#DES标准ECB加密解密...
java和C#的通用型加解密
php和C#通用的DES加密解密方法
C#加密解密,包括DES、MD5、SHA256
C#与JAVA通用DES: 1、C#平台上的加密与解密 2、JAVA平台上的加密与解密 3、C#平台上的加密,能在JAVA平台上解密 4、JAVA平台上的加密,能在C#平台上解密 这个工具类,是基于平台的,不调用任何第三方软件,已经运用...
C#通过des对文件进行加密,java通过密钥对C#加密的文件进行解密
DES加密解密算法。通过密钥对对字符串进行加密解密操作,64位加密
C#_加密解密类_DES_3DES_MD5
javascript前端DES加密,VB.NET、C#后端服务器解密,经常用在账号密码验证的界面,避免用户凭据明文传输
C#的字符串加密码类,DES加密解密类 DESEncrypt 简单实用,直接导入。
c#的3DES加密解密强制要求不能使用简单的密钥,这里按照3DES双倍长的算法原理,实现双倍长的加密解密
开发环境VS2013;编程语言C#;用des对称加解密方法对任意文本文件进行加解密操作。可通过选择读入文本文件的方式,对文件进行操作。程序已编译运行通过,可放心使用。
C#中DES加密解密(兼容前端网页在线DES加密解密)
des加密解密的cs程序 方便对字符串进行加密和解密