java纯数字加密解密实例

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

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

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

<span style="white-space:pre">	</span>/**
	 * <p>Description: password加密</p>
	 * @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;
    	}

在详细代码中的应用:

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

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

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" >

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

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

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

时间: 2024-12-26 08:13:52

java纯数字加密解密实例的相关文章

Asp.net,C# 纯数字加密解密字符串

也就是说加密后的数据不再是:N8lAaHMFtSAQgaf3+RUFng== 希望encryptedString是"120387789370480938409832840923492384028934…”; 当然上面的数字是我随便乱敲的. 那么如何实现纯数字呢?? 想法很简单,只要将字符变成Ascll 码就可以了.例如a:97, =:61; 那么encryptedString 就可以变成 97 81 61 33 44 55 ...; 但是如果合在一起的话就变成了978161334455. 问题来

JAVA实现RSA加密解密 非对称算法

首先RSA是一个非对称的加密算法,所以在使用该算法加密解密之前,必须先行生成密钥对,包括公钥和私钥 JDK中提供了生成密钥对的类KeyPairGenerator,实例如下: public static Map<String, Object> genKeyPair() throws Exception { // 获取公钥私钥密钥对的生成器 KeyPairGenerator kpg = KeyPairGenerator.getInstance("RSA"); // 初始化确定密

兼容PHP和Java的des加密解密代码分享

这篇文章主要介绍了兼容PHP和Java的des加密解密代码分享,适合如服务器是JAVA语言编写,客户端是PHP编写,并需要des加密解密的情况,需要的朋友可以参考下 php <?php class DES { var $key; var $iv; //偏移量 function DES($key, $iv=0) { $this->key = $key; if($iv == 0) { $this->iv = $key; } else { $this->iv = $iv; } } //加

php与java通用AES加密解密算法

php与java通用AES加密解密算法 AES指高级加密标准(Advanced Encryption Standard),是当前最流行的一种密码算法,在web应用开发,特别是对外提供接口时经常会用到,下面是我整理的一套php与java通用的AES加密解密算法. php版代码如下: <?php class CryptAES { protected $cipher = MCRYPT_RIJNDAEL_128; protected $mode = MCRYPT_MODE_ECB; protected

Des 对称加密算法 加密\解密实例

Des 加密相关类介绍: SecureRandom  这个类是继承自java.util.Random 这个类 SecureRandom 这个类的构造器有三种,下面例举两种: SecureRandom()构造一个实现默认随机数算法的安全随机数生成器 (RNG). SecureRandom(byte[] seed)构造一个实现默认随机数算法的安全随机数生成器 (RNG). DESKeySpec 这个类是用来使用原始秘钥来生成秘钥的秘钥内容 DESKeySpec 有两个构造函数: DESKeySpec

java 采用MD5加密解密

MD5加密解密 package endecrypt; import java.io.UnsupportedEncodingException; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; /** * 采用MD5加密解密 * @author tfq * @datetime 2011-10-13 */ public class MD5Util { /*** * MD5加码 生成3

JAVA使用DES加密解密

在使用DES加密解密的时候,遇到了一些问题,廖记一下.如有哪位大神亲临留言指点,不胜感激. 先上代码: public DESUtil() { } //密码,长度要是8的倍数 注意此处为简单密码 简单应用 要求不高时可用此密码 /*DES是一种对称加密算法,所谓对称加密算法即:加密和解密使用相同密钥的算法.DES加密算法出自IBM的研究,后来被美国政府正式采用,之后开始广泛流传,但是近些年使用越来越少,因为DES使用56位密钥,以现代计算能力,24小时内即可被破解.*/ private stati

java 实现 DES加密 解密算法

DES算法的入口参数有三个:Key.Data.Mode.其中Key为8个字节共64位,是DES算法的工作密钥:Data也为8个字节64位,是要被加密或被解密的数据:Mode为DES的工作方式,有两种:加密或解密.  DES算法是这样工作的:如Mode为加密,则用Key 去把数据Data进行加密, 生成Data的密码形式(64位)作为DES的输出结果:如 Mode为解密,则用Key去把密码形式的数据Data解密,还原为Data的明码形式(64位)作为DES的输出结果.在通信网络的两端,双方约定一致

Java使用RSA加密解密签名及校验

由于项目要用到非对称加密解密签名校验什么的,于是参考<Java加密解密的艺术>写一个RSA进行加密解密签名及校验的Demo,代码很简单,特此分享! RSA加密解密类: package com.ihep; import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.FileReader; import java.io.FileWriter; import java.io.IOException; imp