博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java纯数字加密解密实例
阅读量:5838 次
发布时间:2019-06-18

本文共 2778 字,大约阅读时间需要 9 分钟。

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

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

     我们可能会习惯在service层进行加密,这个没有太强制的要求.以下我们就详细来看一下加密的过程.先说明一下,由于我的password是六位有效数字,所以我们须要把这六位有效数字进行加密,代码例如以下:

	/**	 * 

Description: password加密

* @param Userpasword 传过来的六位数字password * @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("用户password:" + secretEncrypt(userBaseInfo.getUserPassword())); //给password加密。然后放在实体里进行保存 userBaseInfo.setSUserPassword(secretEncrypt(userBaseInfo.getUserPassword())); //保存用户信息 userBaseInfoService.save(userBaseInfo); result = true; }catch(Exception e){ e.printStackTrace(); } return result; }

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

     

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

	/**	 * 

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
     好了,综上所述,我们把加密和解密都讲完了,记住我上面说的话,加密和解密本身就是一对共生体,缺一不可.所以不要图一时轻松,仅仅做加密,而把解密给扔掉了.好了,下篇文章我们来说一下div嵌套的问题.

你可能感兴趣的文章
php 用正则替换中文字符一系列问题解决
查看>>
ActiveMQ应用笔记一:基本概念&安装
查看>>
SAE+Java+jetty
查看>>
大话数据结构之四(串)
查看>>
加热炉简是新来的整个系统的板
查看>>
Mockito使用注意事项
查看>>
[LeetCode] Palindrome Linked List 回文链表
查看>>
UVA - 825Walking on the Safe Side(dp)
查看>>
android大概是通过logcat拦截Log
查看>>
android HDMI 清晰度 分辨率
查看>>
JQuery发送Put、Delete请求 - 摘自网络
查看>>
Android基于mAppWidget实现手绘地图(九)–如何处理地图对象的touch事件
查看>>
关于codeMirror插件使用的一个坑
查看>>
矩阵管理——本质是职能分工,例如所有部门都执行财务部门制定的财务制度而不会各自为政...
查看>>
评论:人才流失强力折射出现实畸形人才观
查看>>
git服务器gitlab之搭建和使用--灰常好的git服务器【转】
查看>>
Game Loop Tutorial
查看>>
Android开发之旅:应用程序基础及组件(续)
查看>>
jQuery validate API
查看>>
基于机器学习的web异常检测——基于HMM的状态序列建模,将原始数据转化为状态机表示,然后求解概率判断异常与否...
查看>>