社区
C#
帖子详情
C# 怎么解开JAVA 3DES加密后的数据
heijigaoke
2006-03-09 02:51:38
各位高手:
请问C#怎么解开JAVA 3DES加密后的数据!C#,JAVA的KEY要怎么才能对应起来!麻烦做过的兄弟指导一下!谢谢
...全文
342
9
打赏
收藏
C# 怎么解开JAVA 3DES加密后的数据
各位高手: 请问C#怎么解开JAVA 3DES加密后的数据!C#,JAVA的KEY要怎么才能对应起来!麻烦做过的兄弟指导一下!谢谢
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
9 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
linuxyf
2006-03-20
打赏
举报
回复
我有java和C#平台下,利用des和3des交叉加密解密的解决方案,需要的,联系我white_dove3000@hotmail.com
heijigaoke
2006-03-16
打赏
举报
回复
能解但解的时候多了一串尾巴,因为那些参数都有意义的,所以最后一个参数无法区分
dreadknightll
2006-03-14
打赏
举报
回复
如果.net不能解,恐怕要借助Java创建的Web服务了,晕
heijigaoke
2006-03-14
打赏
举报
回复
zai ding
heijigaoke
2006-03-11
打赏
举报
回复
ding
heijigaoke
2006-03-10
打赏
举报
回复
呵呵,解决了!
问题是a$b$c$0$1$2$3是我加密前的数据
加密后我对数据进行解密
得到的确是a$b$c$0$1$2$3
后面有尾巴!问题是我是以$区分参数的,带了个尾巴,就会影响到我的最后一个参数!有什么办法去掉吗?
raulredondo
2006-03-09
打赏
举报
回复
往下看,DES在下面
heijigaoke
2006-03-09
打赏
举报
回复
这是RSA吧?3DES,JAVA的与。NET的有点不同!比如,JAVA的KEY可以是DAEFE3161F3578E0DFDFABD28C9E2F567A27EE5F2F8A2C9B,而。NET的我就不知道它对应的KEY了!因为JAVA是做了一次转码生成KEY的,哎
raulredondo
2006-03-09
打赏
举报
回复
用下面的方法加密:
using System;
using System.IO;
using System.Text;
using System.Security.Cryptography;
/// <summary>
/// 一个简单的使用.NET非对称加密算法的例子
/// 本例的程序很简单,仅用于说明如何在.NET里面使用非对称(RSA)算法。
/// Kwanhong 2005.9
/// </summary>
class Class1
{
public static void Main(string[] args)
{
Class1 c=new Class1();
c.StartDemo();
}
public void StartDemo()
{
//RSA的加解密过程:
// 有 rsa1 和 rsa2 两个RSA对象。
// 现在要 rsa2 发送一段信息给 rsa1, 则先由 rsa1 发送“公钥”给 rsa2
// rsa2 获取得公钥之后,用来加密要发送的数据内容。
// rsa1 获取加密后的内容后,用自己的私钥解密,得出原始的数据内容。
RSACryptoServiceProvider rsa1 = new RSACryptoServiceProvider();
RSACryptoServiceProvider rsa2 = new RSACryptoServiceProvider();
string publickey;
publickey=rsa1.ToXmlString(false); //导出 rsa1 的公钥
string plaintext;
plaintext="你好吗?这是用于测试的字符串。"; //原始数据
Console.WriteLine("原始数据是:\n{0}\n",plaintext);
rsa2.FromXmlString(publickey); //rsa2 导入 rsa1 的公钥,用于加密信息
//rsa2开始加密
byte[] cipherbytes;
cipherbytes=rsa2.Encrypt(
Encoding.UTF8.GetBytes(plaintext),
false);
/*//////////////////////////////////////////////*/
Console.WriteLine("加密后的数据是:");
for(int i=0; i< cipherbytes.Length; i++)
{
Console.Write("{0:X2} ",cipherbytes[i]);
}
Console.WriteLine("\n");
/*//////////////////////////////////////////////*/
//rsa1开始解密
byte[] plaintbytes;
plaintbytes = rsa1.Decrypt(cipherbytes,false);
Console.WriteLine("解密后的数据是:");
Console.WriteLine(Encoding.UTF8.GetString(plaintbytes));
Console.ReadLine();
}
}
using System;
using System.Security.Cryptography;
using System.Text;
using System.IO;
/// <summary>
/// 使用对称加密的例子
/// </summary>
class Class2
{
static void Main(string[] args)
{
Class2 c=new Class2();
c.StartDemo();
}
public void StartDemo()
{
//establish symmetric algorithm
SymmetricAlgorithm sa = Rijndael.Create();
//key and iv
sa.GenerateKey(); //产生随机的 (32*8) 位的密钥
//sa.GenerateIV(); //初始向量,在ECB模式里面可以不用IV
sa.Mode = CipherMode.ECB; //块处理模式
sa.Padding = PaddingMode.Zeros; //末尾数据块的填充模式
Console.WriteLine("密钥是:"); ///////////
for (int i=0; i<sa.Key.Length; i++) ///////////
{ ///////////
Console.Write("{0:X2} ",sa.Key[i]); ///////////
} ///////////
Console.WriteLine("\n"); ///////////
//establish crypto stream
MemoryStream ms = new MemoryStream();
CryptoStream cs = new CryptoStream(ms,sa.CreateEncryptor(),CryptoStreamMode.Write);
//
string plaintext; //原始文本
byte[] cipherbytes; //加密后的数据
byte[] finalbytes; //解密后的数据
plaintext="How are you? 这是一行文字。";
byte[] plainbytes = Encoding.UTF8.GetBytes(plaintext);
Console.WriteLine("原始文本是:\n{0}\n",plaintext);
//display plaint text byte array in hex format
Console.WriteLine("原始数据是:"); ///////////
for (int i=0; i<plainbytes.Length; i++) ///////////
{ ///////////
Console.Write("{0:X2} ",plainbytes[i]); ///////////
} ///////////
Console.WriteLine("\n"); ///////////
//加密过程
cs.Write(plainbytes, 0, plainbytes.Length);
cs.Close();
cipherbytes = ms.ToArray();
ms.Close();
//display ciphertext byte array in hex format
Console.WriteLine("加密后的数据是:"); ///////////
for (int i=0; i<cipherbytes.Length; i++) ///////////
{ ///////////
Console.Write("{0:X2} ",cipherbytes[i]);///////////
} ///////////
Console.WriteLine("\n"); ///////////
//下面的为加密过程
ms=new MemoryStream(cipherbytes);
cs=new CryptoStream(ms,sa.CreateDecryptor(),CryptoStreamMode.Read);
finalbytes=new byte[plainbytes.Length];
cs.Read(finalbytes,0,plainbytes.Length);
Console.WriteLine("解密后的数据是:"); ///////////
for (int i=0; i<finalbytes.Length; i++) ///////////
{ ///////////
Console.Write("{0:X2} ",finalbytes[i]); ///////////
} ///////////
Console.WriteLine("\n"); ///////////
string finaltext=Encoding.UTF8.GetString(finalbytes);
Console.WriteLine("解密后的文本是:\n{0}\n\n",finaltext );
Console.WriteLine("按任意键继续......");
Console.ReadLine();
}
}
c#
和
java
通用D
ES
加密
.docx
在本文中,我们将探讨如何在
C#
和
Java
之间实现通用的D
ES
加密
和解密。
C#
和
Java
都提供了对D
ES
算法的支持,但它们的实现略有不同。下面我们将详细解释
C#
和
Java
中的D
ES
加密
过程,并展示如何创建可互操作的
加密
类。 首先...
D
ES
加密
DEMO(
C#
与
JAVA
)
3. **
JAVA
实现D
ES
加密
解密** - **
java
x.crypto命名包**:
JAVA
中使用`
java
x.crypto.Cipher`类配合`D
ES
KeySpec`和`SecretKeyFactory`实现D
ES
加密
解密。首先需要创建`D
ES
KeySpec`对象,然后通过`SecretKeyFactory`生成...
java
和
C#
通用d
es
3加解密
标题中的“
java
和
C#
通用d
es
3加解密”指的是在
Java
和
C#
这两种不同的编程语言中实现D
ES
(Data Encryption ...通过理解这些知识点,开发者可以在
Java
和
C#
之间实现
3D
ES
的兼容
加密
,确保
数据
在不同系统间的无缝安全交换。
C#
对接
Java
3d
es
md5WithRsa
本篇文章将详细讲解如何在
C#
中实现与
Java
的
3D
ES
加密
以及MD5withRSA签名的对接。
3D
ES
(Triple Data Encryption Algorithm)是一种对称
加密
算法,它使用了D
ES
(Data Encryption Standard)算法三次,增强了
加密
强度...
3D
ES
-ECB模式
加密
,可以与
C#
和
Java
互通
在描述中提到的“可以与
C#
和
Java
互通”,意味着实现的
3D
ES
-ECB
加密
代码在C/C++环境下编译运行后,其
加密
结果应该与
C#
和
Java
平台上的
3D
ES
-ECB
加密
算法得到的结果一致。这通常需要确保所有平台都遵循相同的密钥、初始...
C#
111,120
社区成员
642,537
社区内容
发帖
与我相关
我的任务
C#
.NET技术 C#
复制链接
扫一扫
分享
社区描述
.NET技术 C#
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
让您成为最强悍的C#开发者
试试用AI创作助手写篇文章吧
+ 用AI写文章