import java.security.Key;
import java.security.SecureRandom;
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;
/**
* @author
* 加密/解密 公共类
*/
@SuppressWarnings("restriction")
public class DESUtils
{
private static Key key;
private static String KEY_STR="mykey";
static{
// 在之前的linux服务器上这样使用没有问题,但同事往新的linux服务器上部署时出现以下异常:
// java.lang.RuntimeException: javax.crypto.BadPaddingException: Invalid pad value!
// 原因分析:
// try
// {
// KeyGenerator generator = KeyGenerator.getInstance("DES");
// SecureRandom secureRandom=SecureRandom.getInstance("SHA1PRNG");
// secureRandom.setSeed(KEY_STR.getBytes());
// generator.init(secureRandom);
// key = generator.generateKey();
// generator=null;
// }
// catch (Exception e)
// {
// throw new RuntimeException(e);
// }
// 改成这样后,就解决了!
try {
KeyGenerator generator=KeyGenerator.getInstance("AES");
SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG");
secureRandom.setSeed(KEY_STR.getBytes());
generator.init(128,secureRandom);
key = generator.generateKey();
generator=null;
} catch (Exception e) {
throw new RuntimeException("初始化密钥出现异常");
}
}
/**
* 对字符串进行加密,返回BASE64的加密字符串
* <功能详细描述>
* @param str
* @return
* @see [类、类#方法、类#成员]
*/
public static String getEncryptString(String str){
BASE64Encoder base64Encoder = new BASE64Encoder();
System.out.println(key);
try
{
byte[] strBytes = str.getBytes("UTF-8");
Cipher cipher = Cipher.getInstance("AES");
cipher.init(Cipher.ENCRYPT_MODE, key);
byte[] encryptStrBytes = cipher.doFinal(strBytes);
return base64Encoder.encode(encryptStrBytes);
}
catch (Exception e)
{
throw new RuntimeException(e);
}
}
/**
* 对BASE64加密字符串进行解密
* <功能详细描述>
* @param str
* @return
* @see [类、类#方法、类#成员]
*/
public static String getDecryptString(String str){
BASE64Decoder base64Decoder = new BASE64Decoder();
try
{
byte[] strBytes = base64Decoder.decodeBuffer(str);
Cipher cipher = Cipher.getInstance("AES");
cipher.init(Cipher.DECRYPT_MODE, key);
byte[] encryptStrBytes = cipher.doFinal(strBytes);
return new String(encryptStrBytes,"UTF-8");
}
catch (Exception e)
{
throw new RuntimeException(e);
}
}
//main测试
// public static void main(String[] args)
// {
// String name ="admin";
// String password="123456";
// String encryname = getEncryptString(name);
// String encrypassword = getEncryptString(password);
// System.out.println("用户名加密后:"+encryname);
// System.out.println("密码加密后:"+encrypassword);
//
// System.out.println("用户名解密后:"+getDecryptString(encryname));
// System.out.println("密码解密后:"+getDecryptString(encrypassword));
// }
}
===================================================================================
import org.springframework.beans.factory.config.PropertyPlaceholderConfigurer;
/**
* @author
* 扩展PropertyPlaceholderConfigurer将prop文件中加密后的属性解密后递交给Spring
*/
public class EncryptPropertyPlaceholderConfigurer extends PropertyPlaceholderConfigurer
{
//encryptPropNames存储需要解密的属性
private String[] encryptPropNames = {"jdbc.username", "jdbc.password"};
/*
*重写convertProperty,对已有加密特征的属性进行解密
*/
@Override
protected String convertProperty(String propertyName, String propertyValue)
{
//如果在加密属性名单中发现该属性
if (isEncryptProp(propertyName))
{
String decryptValue = DESUtils.getDecryptString(propertyValue);
return decryptValue;
}else {
return propertyValue;
}
}
/**
* 判断属性值是否加密
* @param propertyName
* @return
*/
private boolean isEncryptProp(String propertyName)
{
for (String encryptName : encryptPropNames)
{
if (encryptName.equals(propertyName))
{
return true;
}
}
return false;
}
}
===================================================================================
在spring.xml文件中增加如下配置:
<bean id="propertyConfig" class="com.gdt.smart.modules.slms.util.EncryptPropertyPlaceholderConfigurer">
<property name="locations">
<list>
<value>classpath:jdbc.properties</value>
</list>
</property>
</bean>
相关推荐
java代码实例 AES加密解密 Base64加密解密
微信小程序 对称加密 AES ECB base64 加密解密 真实项目可用
java实现SHA1、SHA、MD5、AES加密、AES解密、BASE64解密、BASE64加密,以及apache BASE64 jar和源码
java AES加密解密,使用 CBC 解密模式,EncryptByAes Aes加密 后 base64 再加 DecryptByAes Aes 解密,对 PKCS7 填充的数据进行反填充,对数据进行 PKCS7 填充 使用 CBC 解密模式, // aesDecrypt 解密 public ...
非常实用的Base64加密,解密角本。基于UTF8,支持中文加解密。
本源码从CSDN一位前辈的源码基础上做了更改,增加支持加密返回BASE64,更加完善。在此感谢原作者: http://download.csdn.net/download/qiaohaidong/9477264 需要注意的是仅在XE及以上版本支持Base64返回结果,...
SqlSerVer 进行Base64 加密解密,支持中文,数字,字母
AES128加密,当前测试实现不超过64字节明文的加解密,Base64格式输入输出。 加密方式:ECB 0补齐 密钥16B 如需实现192/256加密,需修改内部函数。 测试代码,仅供参考。
加密工具类 包含md5加密 base加密解密 md5加密 aes加密解密 urlencoude
加解密工具集 对字符串做BASE64加密 解密 MD5加密 解密 DES加密 DES解密 AES加密 AES解密
Base64转码,AES加密解密,IOS,Android,Java 后台。 本工程可以直接使用,而且与IOS,Android,JAVA 已调通。 主要用于客户端进行通信,数据之间地安全性。对数据进行加密和解密。 适用于银行等较为保密的项目中。 ...
Delphi7AES加密解密与JAVA互转(默认128位+ECB+PKCS5Padding+先BASE64再HEX)
base64中文加密 注意中文编码为UTF-8
' 功能: AES加密解密 password<==>hwWpiegaWDeE8kTlb/5BQg== , 8705a989e81a583784f244e56ffe4142 ' [Str] 预备转换的byte ' [StrKey] 16位的密钥 ' [StrIv] 16位的偏移 ' [Encrypt] 加密(缺省值)还是解密 ' ...
VB6.0 RSA/AES/Md5/Base64加密 解密 微信小程序 javascript 通用 仅demo实例!可先测试使用!
c语言实现aes ecb模式加密,可以和java,c#,obj-c互相 加,解密。包含base64编码,urlEncode编码 注意,该算法里面的密文是转换成16进制的字串,如果不要16进制,可自行转换,内的函数。 vc6,vs2008,可编译。
java代码实现各种加密算法:AES加密解密,RAS加密解密,DES加密解密,MD5加密,Base64加密解密,异或加密解密
crypto-js 和 pako实现数据加密, 解密
由于项目需要必须采用JS端来对字符串进行MD5,AES,Base64等加密解密,所以搜集和测试了这些相关的方法实现,可以通过打开WebRoot/index.html页面来测试代码
* 编码工具类 * 1.将byte[]转为各种进制的字符串 * 2.base 64 encode * 3.base 64 decode * 4.... * 5.... * 6.结合base64实现md5加密 ... * 8.AES加密为base 64 code * 9.AES解密 * 10.将base 64 code AES解密