奶头挺立呻吟高潮av全片,成人试看120秒体验区,性欧美极品v,A片高潮抽搐揉捏奶头视频

java語言

講解java的純數字加密解密

時間:2025-05-02 10:54:39 java語言 我要投稿
  • 相關推薦

講解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 * @: * @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; }

【講解java的純數字加密解密】相關文章:

BIOS設置的加密與解密07-04

PHP可逆加密解密算法07-22

PHP加密和解密函數10-08

java講解06-23

PHP解密Unicode及Escape加密字符串11-02

PHP如何使用AES加密算法進行數據加密和解密06-07

java加密算法是什么09-14

C語言如何使用異或(xor)加密或解密文件09-07

講解Java的泛型07-13

主站蜘蛛池模板: 霍山县| 呈贡县| 安塞县| 杭锦后旗| 吐鲁番市| 禹州市| 龙江县| 海淀区| 汝州市| 德庆县| 山丹县| 莎车县| 潞城市| 海盐县| 始兴县| 六盘水市| 庄浪县| 昭通市| 江达县| 民勤县| 类乌齐县| 德江县| 昭平县| 绥宁县| 兴宁市| 芜湖县| 乌拉特中旗| 钦州市| 京山县| 广东省| 阳谷县| 延寿县| 凉城县| 景宁| 马关县| 孝昌县| 浑源县| 正安县| 海城市| 修文县| 仙游县|