服务器之家

服务器之家 > 正文

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

时间:2019-12-29 14:45     来源/作者:奔跑吧吕子

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

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

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<span style="white-space:pre">  </span>/**
   * <p>Description: 密码加密</p>
   * @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;
    }

在具体代码中的应用:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<span style="white-space:pre">  </span>/**
   * <p>Description: 保存用户基本信息</p>
   * @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;
  }

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

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

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
<span style="font-size: 18px; white-space: pre;"> </span><span style="font-size:14px;">/**
   * <p>Description: 解密函数</p>
   * @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<src.length){ 
      total +=len; 
      len=fisDat.read(src,total,src.length-total); 
    
    //执行解密    
    String result=cipher.doFinal(src).toString();
    return result;
  }</span>

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

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

标签:

相关文章

热门资讯

玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分 2019-06-21
男生常说24816是什么意思?女生说13579是什么意思?
男生常说24816是什么意思?女生说13579是什么意思? 2019-09-17
配置IIS网站web服务器的安全策略配置解决方案
配置IIS网站web服务器的安全策略配置解决方案 2019-05-23
华为nova5pro和p30pro哪个好 华为nova5pro和华为p30pro对比详情
华为nova5pro和p30pro哪个好 华为nova5pro和华为p30pro对比详情 2019-06-22
Nginx服务器究竟是怎么执行PHP项目
Nginx服务器究竟是怎么执行PHP项目 2019-05-24
返回顶部