java c# 加密与解密对照
最近一直烦恼,java , c# 加密的不同,然后整理了一下,留个备份的轮子:
其中在 java、c#加密转换时,最重要的是 IV 的确定,我常常用如下方法使得java和c#之间的 IV 可以转换:
将其中某个 IV 数组转为 10进制后,在转换为相应的 byte数组就好了。10进制数组成为 java、c# 中IV转换的桥梁了。最后分别有java(我用myeclipse)和c#的编译器(SharpDevelop2很轻量级的编译器,但是运行代码后需要在后面写上 "Console.ReadLine(); " ,不然dos框会一闪而过。这个编译器还需要系统中安装有.net 2.0或者其他版本)多多实践,这样可以更加直接的看到结果。 下面实例中java与c#的代码都是一一对应的:当然,这些加密算法并不适合所有的加密结构,但是重要的是 IV 、key 的格式化。 网上查了资料,找到java转换为16进制的方法(已测)
- // java格式化16进制输出
- public static void formatIntTo16(byte[] bytes) {
- String[] resultBytes = new String[bytes.length];
- for (int i = 0; i < bytes.length; i++) {
- resultBytes[i] = Integer.toHexString(bytes[i] & 0xFF);
- }
- }
- //MD5加密
- public static String md5Encode(String strContent) {
- try {
- MessageDigest messageDigest = MessageDigest.getInstance("MD5");
- byte[] tempBytes = messageDigest.digest(strContent.getBytes("UnicodeLittleUnmarked"));
- StringBuffer stringBuffer = new StringBuffer();
- for(byte bytes: tempBytes) {
- String tempByte = Integer.toHexString(bytes & 0xFF);
- if(tempByte.length() == 1) {
- stringBuffer.append("0");
- }
- stringBuffer.append(tempByte);
- }
- return stringBuffer.toString();
- } catch(Exception e) {
- e.printStackTrace();
- }
- return null;
- }
- //md5加密
- public static void MD5(string str) {
- string cl1 = str;
- string pwd = "";
- System.Security.Cryptography.MD5 md5 = System.Security.Cryptography.MD5.Create();
- byte[] s = md5.ComputeHash(Encoding.Unicode.GetBytes(cl1));
- for (int i = 0; i < s.Length; i++) {
- pwd = pwd + s[i].ToString("x");
- }
- Console.Write(pwd);
- Console.WriteLine();
- }
- // 3DES加密 基方法
- public static byte[] des3EncodeCBC(byte[] data, byte[] key) throws Exception {
- Key deskey = null;
- DESedeKeySpec spec = new DESedeKeySpec(key);
- SecretKeyFactory keyfactory = SecretKeyFactory.getInstance("desede");
- deskey = keyfactory.generateSecret(spec);
- Cipher cipher = Cipher.getInstance("desede" + "/CBC/PKCS5Padding");
- IvParameterSpec ips = new IvParameterSpec(IV);
- cipher.init(Cipher.ENCRYPT_MODE, deskey, ips);
- return cipher.doFinal(data, 0, data.length);
- }
- // 3DES加密算法
- private static bool Encrypt( byte[] key, byte[] input, out byte[] output )
- {
- output = null;
- try
- {
- TripleDESCryptoServiceProvider trippleDesProvider = new TripleDESCryptoServiceProvider();
- ICryptoTransform encryptObj = trippleDesProvider.CreateEncryptor(rkey, IV);
- output = encryptObj.TransformFinalBlock(input, 0, input.Length);
- trippleDesProvider.Clear();
- }
- catch (Exception)
- {
- return false;
- }
- return true;
- }
- // 3DES 解密 基方法
- public static byte[] des3DecodeCBC(byte[] data, byte[] key) throws Exception {
- Key deskey = null;
- DESedeKeySpec spec = new DESedeKeySpec(key);
- SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("desede");
- deskey = keyFactory.generateSecret(spec);
- Cipher cipher = Cipher.getInstance("desede" + "/CBC/PKCS5Padding");
- IvParameterSpec ips = new IvParameterSpec(IV);
- cipher.init(Cipher.DECRYPT_MODE, deskey, ips);
- return cipher.doFinal(data, 0, data.length);
- }
- // 3DES 解密 基方法
- private static bool Decrypt(byte[] key, byte[] input, out byte[] output)
- {
- output = null;
- try
- {
- TripleDESCryptoServiceProvider trippleDesProvider = new TripleDESCryptoServiceProvider();
- ICryptoTransform decryptObj = trippleDesProvider.CreateDecryptor(key, IV);
- output = decryptObj.TransformFinalBlock(input, 0, input.Length);
- trippleDesProvider.Clear();
- }
- catch (Exception ex)
- {
- return false;
- }
- return true;
- }
- //DES加密
- public static String encode(byte[] key, byte[] iv, byte[] data) throws Exception {
- Key deskey = null;
- DESKeySpec spec = new DESKeySpec(key);
- SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
- deskey = keyFactory.generateSecret(spec);
- IvParameterSpec ips = new IvParameterSpec(iv);
- Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
- cipher.init(Cipher.ENCRYPT_MODE, deskey, ips);
- return new BASE64Encoder().encode(cipher.doFinal(data, 0, data.length));
- }
- //DES加密
- public static string DESEncode(string encryptString, string encryptKey) {
- byte[] rgbKey = Encoding.UTF8.GetBytes(encryptKey.Substring(0, 8));
- byte[] rgbIV = DESKeys;
- byte[] inputByteArray = Encoding.UTF8.GetBytes(encryptString);
- DESCryptoServiceProvider dCSP = new DESCryptoServiceProvider();
- MemoryStream mStream = new MemoryStream();
- CryptoStream cStream = new CryptoStream(mStream, dCSP.CreateEncryptor(rgbKey, rgbIV),
- CryptoStreamMode.Write);
- cStream.Write(inputByteArray, 0, inputByteArray.Length);
- cStream.FlushFinalBlock();
- return Convert.ToBase64String(mStream.ToArray());
- }
java c# 加密与解密对照的更多相关文章
- Java Base64加密、解密原理Java代码
Java Base64加密.解密原理Java代码 转自:http://blog.csdn.net/songylwq/article/details/7578905 Base64是什么: Base64是 ...
- java AES加密、解密(兼容windows和linux)
java AES加密.解密 CreationTime--2018年7月14日10点06分 Author:Marydon 1.准备工作 updateTime--2018年8月10日15点28分 up ...
- Java的加密与解密
package com.wangbo.util; import java.security.Key; import java.security.Security; import javax.crypt ...
- Java DES 加密和解密源码(转)
原文地址:http://www.oschina.net/code/snippet_727646_18383 Java密码学结构设计遵循两个原则: 1) 算法的独立性和可靠性. 2) 实现的独立性和相互 ...
- C# 与 Java Rsa加密与解密互通
Rsa 加密标准的制定已经过去了十多年了. 这两天在看rsa 加密的文章,基本上都是在说 .net 与 java 之间的 rsa加密是不能互通的.因为项目有用到,所以花了点时间对rsa加密做了一点点了 ...
- Java aes加密C#解密的取巧方法
摘要: 项目开发过程中遇到一个棘手的问题:A系统使用java开发,通过AES加密数据,B系统使用C#开发,需要从A系统获取数据,但在AES解密的时候遇到麻烦.Java的代码和C#的代码无法互通. Ja ...
- java AES 加密与解密
package com.ss.util.secret; import java.io.UnsupportedEncodingException; import java.security.Inva ...
- java常用加密和解密工具类EncryptUtil.java
package cn.util; import java.io.UnsupportedEncodingException; import java.security.MessageDigest; im ...
- java——base64 加密和解密
base64 一.加密 *.若有要求输入字符必须为UTF-8: 则需str.getByte("utf-8"); //在getByte()中指定utf-8编码,否则中文字符将被加密 ...
随机推荐
- javascript refresh page 几种页面刷新的方法
Javascript刷新页面的几种方法:1 history.go(0) 2 location.reload() 3 location=location 4 location.a ...
- Delphi 二次开发 CorelDRAW
我们首先通过一个简单的程序例子来看一下Delphi对CorelDRAW二次开发有什么样的效果.本程序实现CorelDRAW程序的打开和关闭. 1.1 Delphi与CorelDRAW连接 在程序与Co ...
- c# 刻度:毫米 英寸 像素转换
从目前所掌握的资料来看,c#程序中将毫米转换像素的方法无非两种: 第一种: 1: /// <summary> 2: /// 以毫米为单位的显示宽度 3: /// </summary& ...
- openerp经典收藏 OpenERP库存管理的若干概念讲解(新增库存价值)(转载)
OpenERP库存管理的若干概念讲解(新增库存价值) 原文:http://shine-it.net/index.php/topic,2425.0/topicseen.html 一.复式库存(Doubl ...
- (转)使用getevent监听Android输入设备文件
尊重原创转载请注明:From AigeStudio(http://blog.csdn.net/aigestudio)Power by Aige 侵权必究! 炮兵镇楼 上一节Android事件分发完全解 ...
- 【译】Android系统简介
简介 本文主要介绍Android的基础知识和体系结构,本文主题: 简介什么是Android,为什么开发者需要关注Android: Android体系结构(如Linux Kernel, Librari ...
- 关于使用视图进行分页时出现当前记录集不支持书签的错误解决方法及原因(asp)
一般在使用视图进行查询时,视图中意般都关联了两个或者更多个表,一般在这种情况下才会使用视图,但是但我在使用视图来查询数据时没有问题,但是一旦在分页中使用到视图进行查询就会出现错误提示如下: ADODB ...
- linux总线、设备和设备驱动的关系
之一:bus_type 总线是处理器和一个或多个设备之间的通道,在设备模型中,所有的设备都通过总线相连,甚至是内部的虚拟"platform"总线.可以通过ls -l /sys/bu ...
- 时序图 Sequence Diagram
时序图(Sequence Diagram)是显示对象之间交互的图,这些对象是按时间顺序排列的. 时序图中显示的是参与交互的对象及其对象之间消息交互的顺序. 下面这张图介绍了时序图的基本内容: 下面这张 ...
- 【BZOJ 1026】 [SCOI2009]windy数
Description windy定义了一种windy数.不含前导零且相邻两个数字之差至少为2的正整数被称为windy数. windy想知道,在A和B之间,包括A和B,总共有多少个windy数? In ...