实例讲解java的纯数字加密解密

网友投稿 267 2023-07-30


实例讲解java的纯数字加密解密

我们都知道,在用户添加信息时,一些比较敏感的信息,如身份证号,手机号,用户的登录密码等信息,是不能直接明文存进数据库的.今天我们就以一个具体的例子来说明一下纯数字的java加密解密技术.

一般我们从页面获取到用户添加的信息之后,进行加密然后存入到数据库.需要比对信息时,加密之后的用户信息我们看不懂,所以对应的我们就要用解密技术.其实软考中对加密解密技术进行了很全面的说明,这里我们就用一个比较简单的实例来说明一下.

我们可能会习惯在service层进行加密,这个没有太强制的要求.下面我们就具体来看一下加密的过程.先说明一下,因为我的密码是六位有效数字,所以我们需要把这六位有效数字进行加密,代码如下:

/**

*

Description: 密码加密

* @param Userpasword 传过来的六位数字密码

* @return 加密后的字符串

* @throws Exception

* @date: 2015年7月27日

*/

public String secretEncrypt(String Userpasword) throws Exception {

//使用Cipher的实例

Cipher cipher =Cipher.getInstance("AES");

//得到加密的钥匙

SecretKey key =KeyGenerator.getInstance("AES").generateKey();

//初始化加密操作,传递加密的钥匙

cipher.init(Cipher.ENCRYPT_MODE,key);

//将加密的内容传递进去,返回加密后的二进制数据

String results =cipher.doFinal(Userpasword.getBytes()).toString();

//返回加密后的字符串

return results;

}

在具体代码中的应用:

/**

*

Description: 保存用户基本信息

* @param personBaseInfo 用户基本信息实体

* @return 布尔型,true代表添加成功,false代表添加失败

* @throws Exception

* @date: 2015年7月27日

*/

public boolean saveUserInformation(UserBaseInfo userBaseInfo) throws Exception{

boolean result = false;

try{

//保存用户基本信息

System.out.println("用户密码:" + secretEncrypt(userBaseInfo.getUserPassword()));

//给密码加密,然后放在实体里进行保存

userBaseInfo.setSUserPassword(secretEncrypt(userBaseInfo.getUserPassword()));

//保存用户信息

userBaseInfoService.save(userBaseInfo);

result = true;

}catch(Exception e){

e.printStackTrace();

}

return result;

}

存到数据库中的用户密码为:第二行就是经过加密后的用户密码.

好了,上面介绍了加密的过程,当然少不了解密的过程.你可不能说我们现在需求只让做加密,没有解密.是,可能暂时页面上没有那么多需求,但是加密和解密本身就是一对共生体.你单单你做了加密,如果将来别人接手你的项目,一看只有加密没有解密,无疑就是给别人挖了一个大坑,所以记住,做加密时一定要把解密一起做了,哪怕现在用不到.解密代码如下:

/**

*

Description: 解密函数

* @param userPassword

* @return

* @throws Exception

* @author : gaoying

* @update :

* @date : 2015-7-27

*/

public String secretDecrypt(String userPassword) throws Exception{

//使用Cipher的实例

Cipher cipher =Cipher.getInstance("AES");

//获取文件中的key进行解密

FileInputStream fisKey=new FileInputStream("secretKey.key");

ObjectInputStream oisKey =new ObjectInputStream(fisKey);

Key key =(Key)oisKey.readObject();

oisKey.close();

fisKey.close();

//初始化解密操作,传递加密的钥匙

cipher.init(Cipher.DECRYPT_MODE,key);

//获取文件中的二进制数据

FileInputStream fisDat=new FileInputStream("secretContent.dat");

//获取数据

byte [] src=new byte [fisDat.available()];

int len =fisDat.read(src);

int total =0;

while(total

total +=len;

len=fisDat.read(src,total,src.length-total);

}

//执行解密

String result=cipher.doFinal(src).toString();

return result;

}

好了,综上所述,我们把加密和解密都讲完了,记住我上面说的话,加密和解密本身就是一对共生体,缺一不可.所以不要图一时轻松,只做加密,而把解密给扔掉。

以上就是本文的全部内容,希望对大家的学习有所帮助。

total +=len;

len=fisDat.read(src,total,src.length-total);

}

//执行解密

String result=cipher.doFinal(src).toString();

return result;

}

好了,综上所述,我们把加密和解密都讲完了,记住我上面说的话,加密和解密本身就是一对共生体,缺一不可.所以不要图一时轻松,只做加密,而把解密给扔掉。

以上就是本文的全部内容,希望对大家的学习有所帮助。


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:java使用正则表达式判断邮箱格式是否正确的方法
下一篇:JQ技术实现注册页面带有校验密码强度
相关文章

 发表评论

暂时没有评论,来抢沙发吧~