当前位置: 首页 > 编程笔记 >

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

田硕
2023-03-14
本文向大家介绍实例讲解java的纯数字加密解密,包括了实例讲解java的纯数字加密解密的使用技巧和注意事项,需要的朋友参考一下

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

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

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

<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; 
    } 

在具体代码中的应用:

<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; 
  } 

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

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

<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> 

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

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

 类似资料:
  • 本文向大家介绍java 实现DES 加密解密的示例,包括了java 实现DES 加密解密的示例的使用技巧和注意事项,需要的朋友参考一下 以上就是java 实现DES 加密解密的示例代码的详细内容,更多关于java des加密解密的资料请关注呐喊教程其它相关文章!

  • 本文向大家介绍Java使用AES加密和解密的实例详解,包括了Java使用AES加密和解密的实例详解的使用技巧和注意事项,需要的朋友参考一下 Java使用AES加密和解密的实例详解 前言: AES的基本要求是,采用对称分组密码体制,密钥长度的最少支持为128、192、256,分组长度128位,算法应易于各种硬件和软件实现。1998年NIST开始AES第一轮分析、测试和征集,共产生了15个候选算法。1

  • 本文向大家介绍C#实现数据包加密与解密实例详解,包括了C#实现数据包加密与解密实例详解的使用技巧和注意事项,需要的朋友参考一下 在很多项目中,为了安全安全考虑,需要对数据包进行加密处理,本文实例所述的即为C#加密代码,在应用开发中有很大的实用价值。说起数据包加密,其实对C#编程者来说,应该是一个基础的技巧,是进行C#程序设计人员必须要掌握的技能。 C#实现加密功能的核心代码如下: 本例备有详细的注

  • 本文向大家介绍java 数据的加密与解密普遍实例代码,包括了java 数据的加密与解密普遍实例代码的使用技巧和注意事项,需要的朋友参考一下   这是一个关于密钥查询的jsp文件,接受上级文件的数据并加密处理,放入Map集合中,通过form表单提交到xdoc文件中;不过这种做法是为了满足公司的要求,用到了框架的内容不免显得繁琐;下篇文章会介绍一种简便的不需要搭建太多环境的普遍做法。 希望本篇文章实例

  • 本篇主要从计数DP上结合实例分析。 一、计数类DP——整数划分 整数划分大体上可以分为3类 (1)考虑顺序的拆分方案(即1,1,2;和2,1,1 是两种不同的方案),这种问题一般转化为完全背包即可解决。 (2)不考虑顺序的拆分方案,可以划分出空集(也就是可以有对拆分完全没贡献的东西存在(0)) (3)不考虑顺序的拆分方案,要求划分出的集合不为空集(不可以拆出0) 主要讨论2,3类DP问题 二、空集

  • 本文向大家介绍PHP加密解密实例分析,包括了PHP加密解密实例分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了PHP加密解密方法。分享给大家供大家参考,具体如下: 希望本文所述对大家PHP程序设计有所帮助。