java 客户端和服务端加密_Java服务端和安卓客户端对消息的加密

importjava.security.SecureRandom;importjavax.crypto.Cipher;importjavax.crypto.SecretKey;importjavax.crypto.SecretKeyFactory;importjavax.crypto.spec.DESKeySpec;importorg.apache.commons.codec.binary.Base64;importorg.apache.commons.codec.binary.StringUtils;/*** 客户端与服务器通讯时对消息体加密和解密的工具类

*@authorLIUTAO

**/

public classDESBase64Util {/*** 密码长度必须是8的倍数*/

public final static String KEY = "RS35836780805258";/*** 加密方式*/

public final static String DES = "DES";/*** 默认编码*/

public final static String ENCODING = "UTF-8";/*** DES加密

*

*@paramsrc

*@paramkey

*@return*@throwsException*/

public static byte[] encrypt(byte[] src, byte[] key) throwsException {//DES算法要求有一个可信任的随机数源

SecureRandom sr = newSecureRandom();//从原始密匙数据创建DESKeySpec对象

DESKeySpec dks = newDESKeySpec(key);//创建一个密匙工厂,然后用它把DESKeySpec转换成一个SecretKey对象

SecretKeyFactory keyFactory =SecretKeyFactory.getInstance(DES);

SecretKey securekey=keyFactory.generateSecret(dks);//Cipher对象实际完成加密操作

Cipher cipher =Cipher.getInstance(DES);//用密匙初始化Cipher对象

cipher.init(Cipher.ENCRYPT_MODE, securekey, sr);//现在,获取数据并加密//正式执行加密操作

returncipher.doFinal(src);

}/*** DES解密

*

*@paramsrc

*@paramkey

*@return*@throwsException*/

public static byte[] decrypt(byte[] src, byte[] key) throwsException {//DES算法要求有一个可信任的随机数源

SecureRandom sr = newSecureRandom();//从原始密匙数据创建一个DESKeySpec对象

DESKeySpec dks = newDESKeySpec(key);//创建一个密匙工厂,然后用它把DESKeySpec对象转换成//一个SecretKey对象

SecretKeyFactory keyFactory =SecretKeyFactory.getInstance(DES);

SecretKey securekey=keyFactory.generateSecret(dks);//Cipher对象实际完成解密操作

Cipher cipher =Cipher.getInstance(DES);//用密匙初始化Cipher对象

cipher.init(Cipher.DECRYPT_MODE, securekey, sr);//现在,获取数据并解密//正式执行解密操作

returncipher.doFinal(src);

}/*** BASE64编码

*

*@paraminfo

*@return

*/

public static String base64Encode(byte[] info) {returnBase64.encodeBase64String(info);

}/*** BASE64解码

* *

*@paraminfo

*@return

*/

public static byte[] base64Decode(String info) {returnBase64.decodeBase64(info);

}/*** 先对消息体进行DES编码再进行BASE64编码

*@paraminfo

*@return

*/

public staticString encodeInfo(String info) {try{byte[] temp =encrypt(info.getBytes(ENCODING),

KEY.getBytes(ENCODING));returnbase64Encode(temp);

}catch(Exception e) {

e.printStackTrace();

}return "";

}/*** 先对消息体进行BASE64解码再进行DES解码

*@paraminfo

*@return

*/

public staticString decodeInfo(String info) {byte[] temp =base64Decode(info);try{byte[] buf =decrypt(temp,

KEY.getBytes(ENCODING));returnStringUtils.newStringUtf8(buf);

}catch(Exception e) {

e.printStackTrace();

}return "";

}public static voidmain(String[] args) {

String info= "我是中国人,我爱祖国这是测试数据无所设置无所设置";//生成密文

String encodeInfo =encodeInfo(info);

System.out.println(encodeInfo);//还原成原文

String decodeInfo =decodeInfo(encodeInfo);

System.out.println(decodeInfo);

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值