java des加密 linux和windows_DES加密解密(适用Windows和Linux系统)防止linux下解密失败 | 学步园...

package com.lasun.util;

import java.io.FileInputStream;

import java.io.FileOutputStream;

import java.io.InputStream;

import java.io.OutputStream;

import java.security.Key;

import java.security.SecureRandom;

import javax.crypto.Cipher;

import javax.crypto.CipherInputStream;

import javax.crypto.CipherOutputStream;

import javax.crypto.KeyGenerator;

import sun.misc.BASE64Decoder;

import sun.misc.BASE64Encoder;

import com.lasun.core.services.ParameterManager;

public class DESUtil {

Key key;

public DESUtil() {

}

public DESUtil(String str) {

setKey(str); // 生成密匙

}

public Key getKey() {

return key;

}

public void setKey(Key key) {

this.key = key;

}

/**

* 根据参数生成 KEY

*/

public void setKey (String strKey) {

try {

KeyGenerator _generator = KeyGenerator.getInstance("DES");

//防止linux下 随机生成key

SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG" );

secureRandom.setSeed(strKey.getBytes());

_generator.init(56,secureRandom);

this.key = _generator.generateKey();

_generator = null;

} catch (Exception e) {

throw new RuntimeException(

"Error initializing SqlMap class. Cause: " + e);

}

}

/**

* 根据参数生成 KEY

*/

/*public void setKey(String strKey) {

try {

KeyGenerator _generator = KeyGenerator.getInstance("DES");

_generator.init(new SecureRandom(strKey.getBytes()));

this.key = _generator.generateKey();

_generator = null;

} catch (Exception e) {

throw new RuntimeException(

"Error initializing SqlMap class. Cause: " + e);

}

}*/

/**

* 加密 String 明文输入 ,String 密文输出

*/

public String encryptStr(String strMing) {

byte[] byteMi = null;

byte[] byteMing = null;

String strMi = "";

BASE64Encoder base64en = new BASE64Encoder();

try {

byteMing = strMing.getBytes("UTF8");

byteMi = this.encryptByte(byteMing);

strMi = base64en.encode(byteMi);

} catch (Exception e) {

throw new RuntimeException(

"Error initializing SqlMap class. Cause: " + e);

} finally {

base64en = null;

byteMing = null;

byteMi = null;

}

return strMi;

}

/**

* 解密 以 String 密文输入 ,String 明文输出

*

* @param strMi

* @return

*/

public String decryptStr(String strMi) {

BASE64Decoder base64De = new BASE64Decoder();

byte[] byteMing = null;

byte[] byteMi = null;

String strMing = "";

try {

byteMi = base64De.decodeBuffer(strMi);

byteMing = this.decryptByte(byteMi);

strMing = new String(byteMing, "UTF8");

} catch (Exception e) {

throw new RuntimeException(

"Error initializing SqlMap class. Cause: " + e);

} finally {

base64De = null;

byteMing = null;

byteMi = null;

}

return strMing;

}

/**

* 加密以 byte[] 明文输入 ,byte[] 密文输出

*

* @param byteS

* @return

*/

private byte[] encryptByte(byte[] byteS) {

byte[] byteFina = null;

Cipher cipher;

try {

cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");

cipher.init(Cipher.ENCRYPT_MODE, key);

byteFina = cipher.doFinal(byteS);

} catch (Exception e) {

throw new RuntimeException(

"Error initializing SqlMap class. Cause: " + e);

} finally {

cipher = null;

}

return byteFina;

}

/**

* 解密以 byte[] 密文输入 , 以 byte[] 明文输出

*

* @param byteD

* @return

*/

private byte[] decryptByte(byte[] byteD) {

Cipher cipher;

byte[] byteFina = null;

try {

cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");

cipher.init(Cipher.DECRYPT_MODE, key);

byteFina = cipher.doFinal(byteD);

} catch (Exception e) {

throw new RuntimeException(

"Error initializing SqlMap class. Cause: " + e);

} finally {

cipher = null;

}

return byteFina;

}

public static void main(String[] args) throws Exception {

DESUtil des = new DESUtil("123456");

// DES 加密文件

// des.encryptFile("G:/test.doc", "G:/ 加密 test.doc");

// DES 解密文件

// des.decryptFile("G:/ 加密 test.doc", "G:/ 解密 test.doc");

String str1 = "jui8qayuh7yhqwsh";

// DES 加密字符串

String str2 = des.encryptStr(str1);

// DES 解密字符串

String deStr = des.decryptStr(str2);

System.out.println(" 加密前: " + str1);

System.out.println(" 加密后: " + str2);

System.out.println(" 加密后长度: " + str2.length());

System.out.println(" 解密后: " + deStr);

}

}

说明:蓝色部分(注释掉的)代码 在windows下面好使,但是在linux下面会导致每次生成的key不一样、也就是说加密之后再解密就会保存,网上说由于两个操作系统处理补充字节默认补齐的方式不同,所以出现这样的情况;

红色部分代码防止在linux下随机生成key,在两个操作系统下通用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PHP和Java都有支持3DES加密解密的库,可以通过这些库来实现互通。以下是一个简单的PHP和Java之间3DES加密解密的例子: PHP代码: ```php $key = "123456789012345678901234"; // 24位密钥 $data = "Hello, world!"; // 待加密的数据 // 加密 $encrypted = openssl_encrypt($data, "DES-EDE3", $key, OPENSSL_RAW_DATA); $encrypted = base64_encode($encrypted); // 转成base64字符串 // 解密 $encrypted = base64_decode($encrypted); // 将base64字符串转成二进制数据 $decrypted = openssl_decrypt($encrypted, "DES-EDE3", $key, OPENSSL_RAW_DATA); echo $decrypted; // 输出:Hello, world! ``` Java代码: ```java import javax.crypto.Cipher; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import javax.crypto.spec.DESedeKeySpec; import java.util.Base64; public class Main { public static void main(String[] args) throws Exception { String key = "123456789012345678901234"; // 24位密钥 String data = "Hello, world!"; // 待加密的数据 // 加密 byte[] encrypted = encrypt(data.getBytes("UTF-8"), key.getBytes("UTF-8")); String encryptedStr = Base64.getEncoder().encodeToString(encrypted); // 转成base64字符串 System.out.println(encryptedStr); // 解密 byte[] encryptedBytes = Base64.getDecoder().decode(encryptedStr); // 将base64字符串转成二进制数据 byte[] decrypted = decrypt(encryptedBytes, key.getBytes("UTF-8")); System.out.println(new String(decrypted, "UTF-8")); // 输出:Hello, world! } public static byte[] encrypt(byte[] data, byte[] key) throws Exception { DESedeKeySpec spec = new DESedeKeySpec(key); SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DESede"); SecretKey secretKey = keyFactory.generateSecret(spec); Cipher cipher = Cipher.getInstance("DESede/ECB/PKCS5Padding"); cipher.init(Cipher.ENCRYPT_MODE, secretKey); return cipher.doFinal(data); } public static byte[] decrypt(byte[] data, byte[] key) throws Exception { DESedeKeySpec spec = new DESedeKeySpec(key); SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DESede"); SecretKey secretKey = keyFactory.generateSecret(spec); Cipher cipher = Cipher.getInstance("DESede/ECB/PKCS5Padding"); cipher.init(Cipher.DECRYPT_MODE, secretKey); return cipher.doFinal(data); } } ``` 这两段代码都使用了3DES算法进行加密解密,PHP使用了OpenSSL库,Java使用了JCE库。在加密时,PHP和Java都使用了相同的密钥和加密模式(ECB),因此可以互相解密

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值