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

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

?? des.java

?? DES算法JAVA實現
?? JAVA
?? 第 1 頁 / 共 2 頁
字號:
				for(x=0;x<16;x++)
				{
					ming_make(x);
					
				}
				af_16=after_16();
				ming_string=ming_string+(char)af_16[0]+(char)af_16[1]+(char)af_16[2]+(char)af_16[3];
			}
			cbcjat.setText(ming_string);
			
		}
		
		
		private void ebcje() {
			short [] temp_s=new short [4];
			 int i;                           
			  String screat_string="";
			                
			for(i=0;i< screat.length;)
			{
				temp_s[0]=screat[i];//選取64bit
				temp_s[1]=screat[i+1];
				temp_s[2]=screat[i+2];
				temp_s[3]=screat[i+3];
				i=i+4;
				int x;
				ming(temp_s);//每64bit初始化一次
				for(x=15;x>=0;x--)
				{
					ming_make(x);
					
				}
				short [] af_16;
				af_16=after_16();

				screat_string=screat_string+(char)af_16[0]+(char)af_16[1]+(char)af_16[2]+(char)af_16[3];
			}
			
			ebcjet.setText(screat_string);

			
		}
		private void ebcja() {
			short [] temp_ming=new short [4];//每次輸入64BIT的明文
			String ming_string="";//最后作為輸出的密文字符
			short [] ming_short;//保存明文的數組
			int leng;//SHORT數組長度

			
			int i=mingword.length()/4;
			if((mingword.length()%4)!=0)
			{
				leng=i*4+4;
			ming_short=new short[leng];
			int t=0;
			for(;t<mingword.length();t++)
				ming_short[t]=(short)mingword.charAt(t);
			}
			else 
				{
				leng=i*4;
				ming_short=new short [leng];
				int t=0;
				for(;t<mingword.length();t++)
					ming_short[t]=(short)mingword.charAt(t);
				}
			                            
			   
			                              
			for(i=0;i<leng;)
			{
				temp_ming[0]=ming_short[i];//選取64bit
				temp_ming[1]=ming_short[i+1];
				temp_ming[2]=ming_short[i+2];
				temp_ming[3]=ming_short[i+3];
				i=i+4;
				int x;
				ming(temp_ming);//每64bit初始化一次
				for(x=0;x<16;x++)
				{
					ming_make(x);
					
				}
				short [] af_16;
				af_16=after_16();
				ming_string=ming_string+(char)af_16[0]+(char)af_16[1]+(char)af_16[2]+(char)af_16[3];
			}
			ebcjat.setText(ming_string);

		}
		
		
		//把字符串對應的每位0或1狀態反映到數組bit里
		public static int[] changebit(short [] income,int size) {
			int i=0;
			int [] state=new int[size];
			for(;i<size;i++) 
			{
				if(testbit(income[i/16],bittest[i%16])==true) state[i]=1;
				else state[i]=0;
			}
			
			return state;
		}

		//測試字符某一位是0還是1
		private static boolean testbit(short c,int testnum) {
			if((c&testnum)==0)  return false;
			else return true;
		}
		
		
		//根據所給位狀態組裝到字符里
		public static short[] shortmaker(int [] state,int size) {
			short [] c=new short[size/16];
			int i=0;
			for(;i<=size-1;i++)
			{
				if(state[i]==1)
				c[i/16]=(short)((c[(i/16)])|(bittest[(i%16)]));
			}
			return c;
		}
		
		
		
		//置換擴展
		public static int[] ip_extend(int [] state,int [] list,int size)
		{
			int i=0;
			int [] temp=new int [size];
			for(;i<size;i++)
			{
				temp[i]=state[list[i]-1];//擴展置換表從1開始,所以要減1
			}
			
			return temp;
		}
		
		
		//S盒選擇:輸入Short數組,返回32比特的狀態
		public static int[] Sbox(short [] income) {
			int [] S_bitState=new int [48];
			int [] Sbit=new int [32];
			S_bitState=changebit(income,48);
			int i=0,row,column,temp;
			for(;i<8;i++)
			{
				row=row(i,S_bitState);
				column=column(i,S_bitState);
				temp=S[i][row][(column)];
				Sbit[i*4+3]=temp%2;
				Sbit[i*4+2]=(temp/2)%2;
				Sbit[i*4+1]=(temp/4)%2;
				Sbit[i*4]=(temp/8)%2;
			}
			return Sbit;
		}
	
		//計算S盒中的行號
		private static int row(int i,int []S_bitState) {
			if((S_bitState[i*6]==0)&(S_bitState[i*6+5]==0)) return 0;
			else if((S_bitState[i*6]==0)&(S_bitState[i*6+5]==1)) return 1;
			else if((S_bitState[i*6]==1)&(S_bitState[i*6+5]==0)) return 2;
			else return 3;
		}
		
		//計算S盒中的列號
		private static int column(int i,int [] S_bitState) {
			int colunm=0,n=0;
			for(n=1;n<5;n++)
			{
				colunm*=2;
				if(S_bitState[i*6+n]==1)	colunm++;
			}
			return colunm;
		}
		
		//左循環移位
		private static int[] move(int [] income,int i)
		{
			int time=Keymove[i];
			int n=0;
			int [] temp=new int[28];
			for(;n<28;n++)
			temp[n]=income[(n+time)%28];
			return temp;
		}
		
		public static int []key_right =new int [28];
		public static int []key_left=new int [28];
		
		//將KEY分解出狀態并轉換分為左右兩部分。
		public static void  key() {
			int [] keystate=new int [64];
			keystate=changebit(keyword,64);//分解為位狀態
			keystate=ip_extend(keystate,PC_1,56);//置換
			int n=0;
			for(;n<28;n++)//分左右部分
			{
				key_left[n]=keystate[n];
				key_right[n]=keystate[n+28];
			}
		}
		
		
		//輸入第一次產生的左右部分KEY和需要產生的第i輪生成SHORT數組狀態的48位KEY
		public static short[]  keymaker(int i) {
			
			int [] key_right_temp =new int [28];
			int [] key_left_temp=new int [28];
			key_right_temp=move(key_right,i);//移位
			key_left_temp=move(key_left,i);//移位
			int [] temp=new int[56];
			int [] temp2=new int [48];
			int n=0;
			for(;n<28;n++)//移位后組合為56BIT
				{
				temp[n]=key_left_temp[n];				
				temp[28+n]=key_right_temp[n];
				}
			
			temp2=ip_extend(temp,PC_2,48);//轉換為48BIT
			
			short [] Kshort=new short [3];
			Kshort=shortmaker(temp2,48);//整合成為SHORT數組
			
			return Kshort;
	}
		

		
		public  static int [] m_right_bit =new int [32];
		public  static int [] m_left_bit =new int [32];
		
		public static short [] rightm=new short[2];		
		public static short [] leftm=new short[2];
		
		
		//分解輸入的明文,并分為左右部分狀態
		public static void ming(short []income) {
			int [] temp=new int [64];
			
			temp=changebit(income,64);// 轉換為位狀態
			temp=ip_extend(temp,IP,64);//IP轉換
			
			int i=0;//分左右部分
			for(;i<32;i++) {
				m_left_bit[i]=temp[i];
				m_right_bit[i]=temp[32+i];
			}		
			
			rightm=shortmaker(m_right_bit,32);
			leftm=shortmaker(m_left_bit,32);
			
		}

		
		//生成每輪的左右密文short數組(修改rigntm,leftm)
		public  void ming_make(int time) {
			short [] temp=new short[2];

			
			short [] lefttemp=new short[2];//備份LEFTM
			lefttemp[0]=leftm[0];
			lefttemp[1]=leftm[1];
			
			
			//leftm=shortmaker(temp,m_right_bit,32);//右變左產生下一次的左部
			leftm[0]=rightm[0];
			leftm[1]=rightm[1];
			
			
			int [] ex=new int[48];
			int [] sbit =new int [32];
			short [] exshort=new short[3];
			
			ex=ip_extend(m_right_bit,Extend,48);//擴展
			
			exshort=shortmaker(ex,48);//轉換為Shotr數組方便異或
			int i=0;
			for(;i<3;i++)//與生成的KEY異或
				exshort[i]=(short)(exshort[i]^keymaker(time)[i]);
			
			
			sbit=Sbox(exshort);//s盒選擇
			sbit=ip_extend(sbit,P,32);//P置換
			temp=shortmaker(sbit,32);//整合為SHORT數組
			for(i=0;i<2;i++)//與左部分異或產生下一輪的右部
				rightm[i]=(short)(lefttemp[i]^temp[i]);
			
		//更變左右部分的位狀態數組
			m_left_bit=changebit(leftm,32);
			m_right_bit=changebit(rightm,32);
		}
		
		
		public short[] after_16() {

			int i=0;
			int [] state=new int [64];
			for(;i<32;i++)
			{
				state[i]=m_right_bit[i];
				state[i+32]=m_left_bit[i];
			}
			state=ip_extend(state,IP_1,64);
			
			short [] ming=new short[4];
			ming=shortmaker(state,64);
			return ming;
			
		}

	}
		
	

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久草av在线| 欧美巨大另类极品videosbest| 91网址在线看| 91精品中文字幕一区二区三区| 中文字幕在线不卡国产视频| 婷婷久久综合九色综合伊人色| 国产.欧美.日韩| 欧美人与z0zoxxxx视频| 国产精品久久久久久久裸模| 热久久久久久久| 欧美在线观看一二区| 久久综合狠狠综合久久综合88| 亚洲福利一二三区| 一区二区三区日韩欧美精品| 精品久久久久久最新网址| 樱花草国产18久久久久| 国产精品99久久久久久久女警| 91麻豆精品国产91久久久使用方法 | 久久 天天综合| 欧美日韩一级二级| 一区二区三区蜜桃| 99这里只有久久精品视频| 欧美电影免费观看高清完整版在线 | 久久久.com| 久久99国产精品久久99果冻传媒| 91麻豆精品国产自产在线观看一区 | 国产精品天天摸av网| 久久99日本精品| 亚洲观看高清完整版在线观看 | 亚洲人妖av一区二区| 国产主播一区二区| 久久精品人人做人人爽人人| 国产中文字幕一区| 久久蜜臀中文字幕| 极品少妇xxxx偷拍精品少妇| 亚洲成av人在线观看| 色婷婷综合久久| 亚洲自拍偷拍九九九| 精品视频一区二区不卡| 亚洲女同ⅹxx女同tv| 91国偷自产一区二区开放时间 | 日本韩国精品一区二区在线观看| 日韩理论在线观看| 91色综合久久久久婷婷| 一区二区三区中文在线观看| 欧美在线你懂得| 五月天中文字幕一区二区| 欧美三级电影网站| 精品一区二区三区蜜桃| 精品国产乱码久久久久久牛牛| 狠狠色狠狠色综合系列| 国产午夜精品久久久久久免费视| 99精品在线免费| 亚洲五月六月丁香激情| 91精品欧美久久久久久动漫| 久久不见久久见免费视频1| 国产婷婷色一区二区三区四区| 国产91精品欧美| 亚洲最新在线观看| 欧美一区二区免费观在线| 国产麻豆一精品一av一免费| 国产精品卡一卡二| 欧美日韩国产小视频| 激情亚洲综合在线| 日韩一区日韩二区| 欧美一区二区日韩| av激情亚洲男人天堂| 日韩精品电影在线观看| 国产精品欧美经典| 这里只有精品视频在线观看| 国产白丝精品91爽爽久久| 一区二区三区在线观看动漫| 精品国产乱码久久久久久浪潮| 97精品国产露脸对白| 久久99精品国产91久久来源| 亚洲欧美日韩小说| 国产午夜精品在线观看| 亚洲天堂成人在线观看| 日韩免费高清电影| 在线精品视频一区二区三四| 久久成人精品无人区| 亚洲精品国产一区二区三区四区在线 | 精品国产一区二区在线观看| 一本色道久久综合亚洲aⅴ蜜桃| 激情六月婷婷久久| 五月天一区二区| 综合分类小说区另类春色亚洲小说欧美 | 精品国产乱码久久| 欧美午夜免费电影| 成人午夜激情在线| 另类小说图片综合网| 亚洲成人一二三| 亚洲欧洲精品一区二区三区| 精品成人一区二区| 欧美精品tushy高清| 一本色道久久综合狠狠躁的推荐 | 天天操天天干天天综合网| 中文字幕乱码一区二区免费| 日韩视频免费观看高清在线视频| 欧美色中文字幕| 99久久精品一区| 成人深夜福利app| 国产精品一区二区在线看| 首页国产丝袜综合| 午夜久久久影院| 亚洲成人自拍网| 亚洲成人动漫在线观看| 亚洲欧美日韩电影| 亚洲品质自拍视频网站| 国产精品传媒视频| 国产精品三级在线观看| 国产精品视频免费看| 中文字幕 久热精品 视频在线 | 亚洲另类中文字| 亚洲免费毛片网站| 一区二区免费视频| 亚洲国产一二三| 香蕉加勒比综合久久| 亚洲国产精品影院| 欧美伊人久久久久久久久影院 | 久久综合国产精品| 久久亚洲精华国产精华液| 久久久影视传媒| 久久精品在线观看| 国产精品亲子乱子伦xxxx裸| 国产欧美日韩麻豆91| 亚洲人成人一区二区在线观看 | 成人免费一区二区三区视频| 国产精品灌醉下药二区| 亚洲男同性恋视频| 亚洲丶国产丶欧美一区二区三区| 午夜精品福利一区二区蜜股av | 91网站黄www| 在线亚洲人成电影网站色www| 日本高清无吗v一区| 在线播放国产精品二区一二区四区 | 亚洲成av人片在线| 日本欧洲一区二区| 成人黄色网址在线观看| 91精品福利视频| 欧美一区二区三区色| 国产日韩欧美在线一区| 一区二区免费看| 免费成人美女在线观看.| 国产老妇另类xxxxx| 91浏览器入口在线观看| 91精品国产色综合久久不卡电影| 久久婷婷成人综合色| 亚洲女同ⅹxx女同tv| 理论电影国产精品| 91麻豆自制传媒国产之光| 69p69国产精品| 国产精品免费人成网站| 性欧美大战久久久久久久久| 丁香网亚洲国际| 欧美精品在线一区二区| 国产三级三级三级精品8ⅰ区| 亚洲女人的天堂| 精品中文av资源站在线观看| 国产精品国产三级国产普通话三级 | 91精品国产乱码| 国产成人综合在线观看| 日韩一区二区三区视频在线| 中文在线免费一区三区高中清不卡| 亚洲九九爱视频| 狠狠狠色丁香婷婷综合激情| 欧美伊人久久久久久久久影院| 久久美女高清视频| 日韩综合在线视频| 91女厕偷拍女厕偷拍高清| 精品国产乱码久久| 日韩成人一级片| 91在线观看成人| 精品国产乱码久久久久久夜甘婷婷 | 久久电影网电视剧免费观看| 欧美性大战久久久久久久蜜臀 | 亚洲成人黄色影院| 9i看片成人免费高清| 久久久久国色av免费看影院| 亚洲bt欧美bt精品777| 色婷婷av久久久久久久| 国产精品久久久爽爽爽麻豆色哟哟| 久久成人羞羞网站| 91精品国产综合久久久蜜臀图片| 一区二区三区高清在线| 成人毛片视频在线观看| 久久精品男人天堂av| 久久精品国产澳门| 欧美精品乱人伦久久久久久| 国产日产精品1区| 欧美激情一区二区三区蜜桃视频| 欧美国产综合色视频| 久久99国产精品尤物| 在线观看日韩毛片| 91精品国模一区二区三区| 99re热视频精品| 国产精品久久久久婷婷| 丁香婷婷综合五月| 国产精品色哟哟网站| 不卡一卡二卡三乱码免费网站|