亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? aes.java

?? AES C++加密解密和java版加密解密方法
?? JAVA
?? 第 1 頁 / 共 2 頁
字號:
package com.hanssun.aes;
import java.io.IOException;
import java.io.FileOutputStream;
import java.io.FileInputStream;

public class AES extends AESMap {
/**
* This method is used to encrypt data with AES.
* @param OpenPath the path of the file which you want to encrypt.
* @param SavePath the path to save the encrypted file
* @param m_Key the encrypt key of user.
* @param Nb the length of file blocks(32bits)
* @param Nk the length of key.
* @return the length of data.(bytes)
* @throws IOException
////////////////////////////////////////////////////     
            功能:    AES加密
            入口參數:m_Key是用戶加密密鑰;
            fp1是要加密的文件指針;
            fp2是加密后保存密文的文件指針;
            Nb是加密時明文的分組長度(以32bit為單位);
            Nk是密鑰的長度(以32bit為單位);
///////////////////////////////////////////////////            
*/

	public long AES_Encrypt(String OpenPath,String SavePath,String m_Key,int Nb,int Nk)
	throws IOException
	{

	     //以二進制讀的方式打開要加密的文件;
	     //以二進制寫的方式打開保存密文的文件;   
	     FileInputStream fp1 = new FileInputStream(OpenPath);
	     FileOutputStream fp2 = new FileOutputStream(SavePath,true); 
	        int Length = fp1.available();//得到要加密的文件的長度;
	     if(Length==0)return 0;
	        int  leave = Length%(4*Nb);                         //求剩余的字塊的字節數;
	        long rounds = Length/(4*Nb);                        //得到整塊的加密輪數;
	        if(leave!=0)rounds++;     
	     long copy_rounds = rounds;
	      
	        byte[] state = new byte[4*8]; //作為加密時存放要加密的明文塊;
	        byte[] copy = new byte[4*8];               //用來進行短塊處理時的緩存區;
	        int Nr=GetRounds(Nb,Nk);      //得到加密的輪數; 
	        KeyExpansion(m_Key,Nb,Nk,Nr); //生成各輪子密鑰;

	     if(copy_rounds==1&&rounds==1)
	        {
	          
	         if(leave==0) fp1.read(state,0,4*Nb);//明文的長度恰好等于分組長度;
	           else
	           {
	                 fp1.read(state,0,leave);//明文的長度小于八個字符;
	                 for(int i=leave;i<4*Nb;i++)
	                 state[i]=0;             //后面用空格補齊;
	           }

	        state = Transform(ByteToChar(state),Nb,Nr);                   //加密變換;  
	        fp2.write(state,0,4*Nb);//將加密后的密文塊寫入目標文件;
	           rounds--; 
	        }
	     else if(copy_rounds>1&&leave!=0)//如果明文的長度大于分組長度且字符數不是分組長度的整數倍              
	        {                               //時,需要進行短塊處理;
	                 fp1.read(state,0,4*Nb);
	                 state = Transform(ByteToChar(state),Nb,Nr);//先加密最前面的一塊;
	                 fp2.write(state,0,leave);//僅將余數個字符存入文件,而將后部分密文
	                                                      //與后面的明文合在一起加密;
	                    int j=0;
	                    for(int i=leave;i<4*Nb;i++)
	                     copy[j++]=state[i];
	                    fp1.read(copy,j,leave);
	                    copy = Transform(ByteToChar(copy),Nb,Nr);
	                    fp2.write(copy,0,4*Nb);
	                    rounds-=2;
	        }
	      while(rounds>0)//以下處理的明文是分組的整數倍的情況;
	        {          
	                    fp1.read(state,0,4*Nb);
	                    state = Transform(ByteToChar(state),Nb,Nr);
	                    fp2.write(state,0,4*Nb);
	                    rounds--;
	        }    
	        fp1.close();//關閉源文件和目標文件;
	        fp2.close();
	        return ((copy_rounds-1)*4*Nb+leave);//返回文件長度;
	    }
	/**
	* This method is used to de-encrypt cryptograph.
	* @param OpenPath the path of cryptograph.
	* @param SavePath the path to save the de-encrypted file.
	* @param m_Key the key to de-encrypt file.
	* @param Nb the length of file blocks(32bits)
	* @param Nk the length of key.
	* @return the length of data.(bytes)
	* @throws IOException
	////////////////////////////////////////////////////////
	    功能:    實現AES的解密
	    入口參數:m_Key是用戶加密密鑰;
	           fp1是要解密的文件指針;
	           fp2是解密后保存明文的文件指針;
	           Nb是解密時密文的分組長度(以32bit為單位);
	           Nk是密鑰的長度(以32bit為單位);
	    注意了,  解密時和加密時的分組長度要一致;
	/////////////////////////////////////////////////////////
	*/
	public     long AES_DeEncrypt(String OpenPath,String SavePath,String  m_Key, int Nb, int Nk)
	throws IOException
	{
	     //以二進制讀的方式打開要加密的文件;
	     //以二進制寫的方式打開保存密文的文件;   
	     FileInputStream fp1= new FileInputStream(OpenPath);
	     FileOutputStream fp2= new FileOutputStream(SavePath,true); 
	        int Length = fp1.available();//得到要加密的文件的長度;
	     if(Length==0)return 0;
	        int  leave=Length%(4*Nb);//求剩余的字塊的字節數;
	        long rounds=Length/(4*Nb);//得到整塊的加密輪數;
	        if(leave!=0)rounds++;     
	     long copy_rounds=rounds;

	        
	        byte []state = new byte[4*8];              //解密時存放密文塊;
	        int Nr = GetRounds(Nb,Nk);      //得到解密時循環輪數;
	        KeyExpansion(m_Key,Nb,Nk,Nr); //生成各輪子密鑰
	        byte[] copy = new byte[32];

	    if(leave!=0)//需要進行短塊處理
	        {
	        fp1.read(copy,0,leave);//先把余數個密文字符保存;
	        fp1.read(state,0,4*Nb);//讀取緊接著的一個密文塊;
	        state = ReTransform(ByteToChar(state),Nb,Nr);          //解密;
	           int j=0;
	           for(int i=leave;i<4*Nb;i++)        //把解密后的明文和前面的余數個合在一起組成一塊,
	               copy[i]=state[j++];            //一起解密;
	           copy = ReTransform(ByteToChar(copy),Nb,Nr);
	        //將解密后的明文寫入目標文件;
	           fp2.write(copy,0,4*Nb);
	           fp2.write(state,j,leave);//將余數個明文寫入目標文件;
	           rounds-=2;                         //已經完成了兩輪解密所以減二;
	        }
	        while(rounds>0)//對后面是分組長度的整數倍的密文塊解密;
	        {
	           fp1.read(state,0,4*Nb);//讀取密文塊;
	           copy = ReTransform(ByteToChar(state),Nb,Nr);          //解密變換;
	           fp2.write(copy,0,4*Nb);//將解密后的明文寫入目標文件;
	           rounds--;                           //輪數減一;
	        }
	        fp1.close();//關閉源文件和目標文件;
	        fp2.close();
	     return ((copy_rounds-1)*4*Nb+leave);//返回文件長度
	    }
	/**
	* This method is used to shift the data in array A.
	* @param A
	//////////////////////////////////////////////////////
	    功能:將數組A中的四個字節循環左移一個字節;
	//////////////////////////////////////////////////////
	*/
	public     void  RotWord(char[]A)
	{
	     char temp;
	        temp=A[0];
	        A[0] = A[1];
	        A[1] = A[2];
	        A[2] = A[3];
	        A[3] = temp;
	}
	/**
	* This method is used to do S-replace durying key-expansion.
	* @param A
	////////////////////////////////////////////////
	    功能:    密鑰擴展的時候進行S盒替換;
	    入口參數:A是存放四個字節的數組;
	////////////////////////////////////////////////
	*/
	public     void  SubWord(char []A)
	{
	    for(int i=0;i<4;i++)
	           A[i]=S_BOX[A[i]]; 
	}
	/**
	* This method is used to get rounds of  encrypt. 
	* @param Nb the length of file blocks(32bits)
	* @param Nk the length of key.
	* @return the rounds of encrypt.
	//////////////////////////////////////////////////
	    功能:返回加密的輪數;
	    入口參數:Nb以32bit為單位的待加密明文的長度;
	           Nk是以32bit為單位的初始密鑰的長度;
	    返回值:返回加密輪數(Nr);
	////////////////////////////////////////////////////
	*/
	public     int  GetRounds(int Nb, int Nk)
	{    
	        switch(Nb)
	        {
	        case 4:switch(Nk)
	               {
	                case 4:return 10;
	                case 6:return 12;
	                case 8:return 14;
	             default:return 0;
	               }
	     case 6:switch(Nk)
	               {
	                case 4:
	                case 6:return 12;
	                case 8:return 14;
	             default:return 0;
	               }
	     case 8:switch(Nk)
	               {
	                case 4:
	                case 6:
	                case 8:return 14;
	             default:return 0;
	               }
	        default:return 0;
	        }
	}
	/**
	* This method is used to build sub-keys used in each rounds。
	* @param m_Key  the key of user.
	* @param Nb the length of file blocks(32bits)
	* @param Nk the length of key.
	* @param Nr the rounds of encrypt in each block.
	////////////////////////////////////////////////////
	    入口參數:Nb以32bit為單位的待加密明文的長度;
	           Nk是以32bit為單位的初始密鑰的長度;
	           Nr是加密的輪數;
	           m_Key是用戶的密鑰;
	    返回值:擴展后的子密鑰存放在數組w中;
	*/
	public     void  KeyExpansion(String m_Key,int Nb, int Nk, int Nr)
	{
	        int i=0;
	        for(;i<4;i++)
	            for(int j=0;j<Nk;j++)
	            key[i*Nk+j]=m_Key.charAt(i*4+j);
	        i=0;
	        while(i<Nk)
	        {
	            w[i*4]=key[i*4];
	            w[i*4+1]=key[i*4+1];
	            w[i*4+2]=key[i*4+2];
	            w[i*4+3]=key[i*4+3];
	            i++;
	        }
	        i=Nk;
	        while(i<Nb*(Nr+1))
	        {
	            char []temp = new char[4];

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产欧美精品一区| 麻豆国产91在线播放| 国产aⅴ精品一区二区三区色成熟| 日韩一区国产二区欧美三区| 午夜精品久久一牛影视| 欧美日韩一二三| 蜜桃精品在线观看| 精品免费日韩av| 国产精品一区二区果冻传媒| 国产婷婷色一区二区三区四区| 欧美日韩免费电影| 成人欧美一区二区三区黑人麻豆 | 日本欧美在线观看| 69久久99精品久久久久婷婷| 免费在线观看视频一区| 久久综合999| 在线观看国产91| 日韩av一二三| 国产精品久久久久久福利一牛影视 | 欧美三级日韩三级| 日韩av一区二区三区四区| 久久综合九色综合欧美98| 91美女片黄在线观看91美女| 日本女优在线视频一区二区| 中文字幕成人在线观看| 精品视频在线看| 国产成人亚洲精品狼色在线| 五月婷婷另类国产| 国产精品私人影院| 精品久久久久久久一区二区蜜臀| 色呦呦日韩精品| 懂色av中文一区二区三区| 天堂成人免费av电影一区| 国产精品福利一区二区| 精品免费国产一区二区三区四区| 91福利精品视频| av一区二区三区黑人| 成人国产视频在线观看| 国产福利精品一区| 国产精品小仙女| 久久精品国产亚洲高清剧情介绍| 亚洲与欧洲av电影| 亚洲精品欧美二区三区中文字幕| 久久久国产精华| 国产亚洲一区二区三区在线观看| 8v天堂国产在线一区二区| 欧美主播一区二区三区美女| 91免费版pro下载短视频| 欧美电视剧在线看免费| 欧美videossexotv100| 久久久不卡影院| 久久女同互慰一区二区三区| 国产欧美日韩亚州综合| 亚洲国产成人一区二区三区| 中文一区在线播放| 亚洲欧洲国产专区| 亚洲一区在线观看免费| 三级不卡在线观看| 国产一区在线视频| 成人动漫精品一区二区| 91浏览器打开| 欧美一区二区精品| 国产欧美精品一区| 亚洲一区二区三区视频在线| 久久av资源网| 日韩av网站免费在线| 色94色欧美sute亚洲13| 日韩精品一区第一页| 中文字幕亚洲在| 日韩一区二区三区av| 91精品国产综合久久精品| 国产精品传媒入口麻豆| 国产精品1区2区3区| 欧美哺乳videos| 久久精品av麻豆的观看方式| 欧美一区二区三区白人| 精品一区二区三区免费播放| 欧美一区二区三区在线观看视频| 丝袜诱惑制服诱惑色一区在线观看| 欧美色图天堂网| 蜜臀99久久精品久久久久久软件| 欧美日免费三级在线| 中文字幕巨乱亚洲| 免费在线观看日韩欧美| 91小视频在线免费看| 2021久久国产精品不只是精品| 亚洲与欧洲av电影| 91久久精品国产91性色tv| 久久精品欧美日韩| 国内精品久久久久影院一蜜桃| 欧美在线观看一区| 亚洲自拍偷拍九九九| 99久久久无码国产精品| 国产婷婷色一区二区三区在线| 奇米影视一区二区三区小说| 欧美日韩国产首页| 一区二区三区成人| 91官网在线观看| 亚洲成人在线免费| 欧美日韩精品欧美日韩精品| 亚洲精品视频在线观看免费| 99麻豆久久久国产精品免费| 自拍偷拍国产精品| 91国偷自产一区二区开放时间| 樱桃国产成人精品视频| 欧美日韩亚洲另类| 日韩精品电影在线| 精品乱人伦小说| 粉嫩在线一区二区三区视频| 亚洲色图一区二区三区| 欧美在线一区二区| 国产在线播放一区三区四| 精品1区2区在线观看| 懂色av噜噜一区二区三区av| 亚洲视频在线观看一区| 欧美色电影在线| 国产成人精品网址| 亚洲一区在线观看免费观看电影高清| 51精品久久久久久久蜜臀| 日本va欧美va精品| 亚洲国产综合色| 国产精品每日更新在线播放网址 | 亚洲国产精品一区二区久久 | 精品国产免费人成电影在线观看四季| 菠萝蜜视频在线观看一区| 蜜臀av一级做a爰片久久| 亚洲免费看黄网站| 成人免费一区二区三区视频| 久久久精品人体av艺术| 精品国产乱码久久久久久久久| 色狠狠色噜噜噜综合网| av网站免费线看精品| 成人在线视频一区| 大陆成人av片| 成人av免费在线| 丁香婷婷综合激情五月色| 国产成人av电影| 国产91丝袜在线18| 国产成人精品免费在线| 国产自产高清不卡| 国产激情一区二区三区桃花岛亚洲| 国产一区二区美女诱惑| 国产a视频精品免费观看| 成人免费av网站| 在线免费一区三区| 91精品国产综合久久久久| 精品欧美乱码久久久久久| 国产欧美精品国产国产专区| 国产精品不卡一区| 视频一区欧美精品| 精品中文av资源站在线观看| 国产精品中文字幕日韩精品 | 亚洲天堂免费看| 亚洲一区二区三区四区的| 麻豆精品视频在线观看| 99精品偷自拍| 欧美一区二区三区色| 亚洲欧洲三级电影| 麻豆91小视频| 欧美一a一片一级一片| 久久久国产精华| 日韩电影免费在线看| 白白色亚洲国产精品| 日韩一本二本av| 99久久婷婷国产综合精品| 美女一区二区三区| 日本免费在线视频不卡一不卡二| 成人91在线观看| 国产精品久久久久久久浪潮网站| 精品一区二区三区影院在线午夜| 欧美伦理电影网| 久久精品99国产精品| 欧美成人午夜电影| 狠狠色丁香久久婷婷综合_中| 精品动漫一区二区三区在线观看| 久久精品国产99久久6| 久久久综合精品| 99久久国产免费看| 亚洲午夜激情av| 欧美一级搡bbbb搡bbbb| 韩国av一区二区三区在线观看| 7777精品伊人久久久大香线蕉的| 午夜精品视频一区| 欧美一级片在线| 国产精品一线二线三线精华| 久久久精品人体av艺术| a美女胸又www黄视频久久| 亚洲精品午夜久久久| 欧美图区在线视频| 日本v片在线高清不卡在线观看| 日韩欧美黄色影院| 成人av网址在线| 亚洲第一成年网| 久久色在线视频| 91麻豆国产福利在线观看| 亚洲成人精品在线观看| 国产精品沙发午睡系列990531| 国产成人免费视频一区| 一二三四社区欧美黄| 日韩欧美一区中文|