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

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

?? sha256.java

?? Sha256 Algorithm. The SHA hash functions are a set of cryptographic hash functions designed by the N
?? JAVA
字號:
import java.math.BigInteger;public class sha256 {	/**	 * @param args	 *///	public static void main(String[] args) {////		//al multiplicar por 8 en el L, hay que ponerle que sea de tipo long para que no se pase y que ocupe los 64 que tiene que ocupar//		byte[] patata = new byte[]{0x61,0x62,0x63};//		byte[] patata1 = new byte[]{0x61,0x62,0x63,0x64,0x62,0x63,0x64,0x65,0x63,0x64,0x65,0x66,0x64,0x65,0x66,0x67,0x65,0x66,0x67,0x68,0x66,0x67,0x68,0x69,0x67,0x68,0x69,0x6a,0x68,0x69,0x6a,0x6b,0x69,0x6a,0x6b,0x6c,0x6a,0x6b,0x6c,0x6d,0x6b,0x6c,0x6d,0x6e,0x6c,0x6d,0x6e,0x6f,0x6d,0x6e,0x6f,0x70,0x6e,0x6f,0x70,0x71};//		byte[] patata3 = new byte[1000000];//		for (int i = 0; i < patata3.length; i++) {//			patata3[i] = 0x61;//		}////		System.out.println(patata[0]);////		System.out.println(Byte.valueOf(Integer.toString(patata[0]), 16));////		System.out.println(patata1[0]);//		//		//Byte b = (byte) 0x80;//		//System.out.println(Integer.toHexString(b));//		//		//		//System.out.println(Byte.parseByte(b.toString(), 16));//		BigInteger finale = hash(patata3);//		//System.out.println(finale);////		int a=45;////		int b=3;////		String f;////		f = Integer.toBinaryString(a);////		int c = NOT(a);////		String h = Integer.toBinaryString(c);////		System.out.println(f);////		System.out.println(h);//		//	}				public static BigInteger hash (byte[] M){							int[] k = new int[]{0x428a2f98,0x71374491,0xb5c0fbcf,0xe9b5dba5,0x3956c25b,0x59f111f1,0x923f82a4,0xab1c5ed5,							0xd807aa98,0x12835b01,0x243185be,0x550c7dc3,0x72be5d74,0x80deb1fe,0x9bdc06a7,0xc19bf174,							0xe49b69c1,0xefbe4786,0x0fc19dc6,0x240ca1cc,0x2de92c6f,0x4a7484aa,0x5cb0a9dc,0x76f988da,							0x983e5152,0xa831c66d,0xb00327c8,0xbf597fc7,0xc6e00bf3,0xd5a79147,0x06ca6351,0x14292967,							0x27b70a85,0x2e1b2138,0x4d2c6dfc,0x53380d13,0x650a7354,0x766a0abb,0x81c2c92e,0x92722c85,							0xa2bfe8a1,0xa81a664b,0xc24b8b70,0xc76c51a3,0xd192e819,0xd6990624,0xf40e3585,0x106aa070,							0x19a4c116,0x1e376c08,0x2748774c,0x34b0bcb5,0x391c0cb3,0x4ed8aa4a,0x5b9cca4f,0x682e6ff3,							0x748f82ee,0x78a5636f,0x84c87814,0x8cc70208,0x90befffa,0xa4506ceb,0xbef9a3f7,0xc67178f2};		int[] H = new int[]{0x6a09e667, 0xbb67ae85, 0x3c6ef372, 0xa54ff53a, 0x510e527f, 0x9b05688c, 0x1f83d9ab, 0x5be0cd19};		int[] W = new int[64];		int a,b,c,d,e,f,g,h;		int T1,T2;				int bytespadding = padding(M);		byte[] sha = new byte[M.length+9+bytespadding];		//copiamos en sha el mensaje entero		for (int i = 0; i < M.length; i++) {//			sha[i] = Byte.valueOf(Integer.toString(M[i]), 16);			sha[i] = M[i];		}		//a朼dimos el byte inicial de padding		sha[M.length] = (byte) 0x80;		//a朼dimos el resto del padding		for (int j = 0; j < bytespadding; j++) {			sha[M.length+j+1] = (byte) 0x00;			}										//a朼dimos tama杘 del mensaje		long tammsg = (M.length * 8);		int tmp = (int)(tammsg >>> 32);				sha[M.length+bytespadding+1]=(byte) (tmp>>>24);//		sha[M.length+bytespadding+1]=(byte) Integer.parseInt((Integer.toHexString((tmp>>>24))));				sha[M.length+bytespadding+2]=(byte)((tmp>>>16) & 0x00ff);//		sha[M.length+bytespadding+2]=(byte) Integer.parseInt((Integer.toHexString(((tmp>>>16) & 0x00ff))));				sha[M.length+bytespadding+3]=(byte)((tmp>>>8) & 0x00ff);//		sha[M.length+bytespadding+3]=(byte) Integer.parseInt((Integer.toHexString(((tmp>>>8) & 0x00ff))));				sha[M.length+bytespadding+4]=(byte)((tmp) & 0x00ff);//		sha[M.length+bytespadding+4]=(byte) Integer.parseInt((Integer.toHexString(((tmp) & 0x00ff))));				tmp = (int)tammsg;		sha[M.length+bytespadding+5]=(byte) (tmp>>>24);//		sha[M.length+bytespadding+5]=(byte) Integer.parseInt((Integer.toHexString((tmp>>>24))));				sha[M.length+bytespadding+6]=(byte)((tmp>>>16) & 0x00ff);//		sha[M.length+bytespadding+6]=(byte) Integer.parseInt((Integer.toHexString(((tmp>>>16) & 0x00ff))));				sha[M.length+bytespadding+7]=(byte)((tmp>>>8) & 0x00ff);//		sha[M.length+bytespadding+7]=(byte) Integer.parseInt((Integer.toHexString(((tmp>>>8) & 0x00ff))));				sha[M.length+bytespadding+8]=((byte)((tmp) & 0x00ff));//		sha[M.length+bytespadding+8]=(byte) Integer.parseInt((Integer.toHexString(((tmp) & 0x00ff))));						//En este punto, tenemos en sha todo el mensaje		//		System.out.println("El tama杘 de todo el mensaje es: "+sha.length);						//Ahora tratamos cada palabra de 512 bits por separado		for(int i=0;i<sha.length;i=i+64)		{			int palabra=0;			//inicializamos las primeras 16 partes de M			for(int j=0;j<64;j= j+4)			{//				System.out.println(Integer.parseInt((String.valueOf(sha[i+j])+String.valueOf(sha[i+j+1])+String.valueOf(sha[i+j+2])+String.valueOf(sha[i+j+3]))));				int word = (int)((sha[i+j] & 0x0ff) << 24)|(int)((sha[i+j+1] & 0x0ff) << 16)|(int)((sha[i+j+2] & 0x0ff) << 8)|(int)((sha[i+j+3] & 0x0ff));				//System.out.println("word: "+Integer.toHexString(word));				W[palabra] = word;//				W[palabra] = Integer.parseInt((String.valueOf(sha[i+j])+String.valueOf(sha[i+j+1])+String.valueOf(sha[i+j+2])+String.valueOf(sha[i+j+3])));				palabra++;			}			//ahora el resto			for(int j=16;j<64;j++)			{				W[j] = o1(W[j-2]) + W[j-7] + o0(W[j-15]) + W[j-16];//				System.out.println(o1(W[j-2]));//				System.out.println(W[j-7]);//				System.out.println(o0(W[j-15]));//				System.out.println(Integer.toHexString());//				System.out.println("W[16]: "+Integer.toHexString(W[16]));			}						//			System.out.println("W[0]: "+Integer.toHexString(W[0]));//			System.out.println("W[16]: "+Integer.toHexString(W[16]));									//En este punto ya tengo montado el W						a = H[0];			b = H[1];			c = H[2];			d = H[3];			e = H[4];			f = H[5];			g = H[6];			h = H[7];						for(int it=0;it<64;it++)			{				T1 = h + Sum1(e) + CH(e, f, g) + k[it] + W[it];				T2 = Sum0(a) + Maj(a, b, c);				h = g;				g = f;				f = e;				e = d + T1;				d = c;				c = b;				b = a;				a = T1 + T2;				//				System.out.println("----------------"+it+"--------------");//				//				System.out.println("a: "+Integer.toHexString(a));//				System.out.println("b: "+Integer.toHexString(b));//				System.out.println("c: "+Integer.toHexString(c));//				System.out.println("d: "+Integer.toHexString(d));//				System.out.println("e: "+Integer.toHexString(e));//				System.out.println("f: "+Integer.toHexString(f));//				System.out.println("g: "+Integer.toHexString(g));//				System.out.println("h: "+Integer.toHexString(h));//				System.out.println("T1: "+Integer.toHexString(T1));//				System.out.println("T2: "+Integer.toHexString(T2));//				//				//				System.out.println("---------FIN----"+it+"--------------");															}									H[0]+=a;			H[1]+=b;			H[2]+=c;			H[3]+=d;			H[4]+=e;			H[5]+=f;			H[6]+=g;			H[7]+=h;								}//		System.out.println("---------H------------------");//		//		System.out.println("0: "+Integer.toHexString(H[0]));//		System.out.println("1: "+Integer.toHexString(H[1]));//		System.out.println("2: "+Integer.toHexString(H[2]));//		System.out.println("3: "+Integer.toHexString(H[3]));//		System.out.println("4: "+Integer.toHexString(H[4]));//		System.out.println("5: "+Integer.toHexString(H[5]));//		System.out.println("6: "+Integer.toHexString(H[6]));//		System.out.println("7: "+Integer.toHexString(H[7]));//		//		System.out.println("---------FIN------------------");				//System.out.println("el tama杘 del mensaje es: "+tammsg);				//String size = long.toBinaryString(tammsg);	//	String sizeok = rellenar_ceros(size,64);//System.out.println("sizeok: "+sizeok);		//ahora lo pasamos a Hexa	//	int hexa= Integer.parseInt(sizeok,2);//		System.out.println(hexa+" es el valor de hexa");		//String hexString = Integer.toHexString(hexa);//		System.out.println(hexString+" es el tama杘 de sizebyte");//		System.out.println(Integer.parseInt(hexString,16));		//		System.out.println(hexString.length()+" es el tama杘 de string");		//String correcthexString = "0";		//if(hexString.length()%2!=0)			//correcthexString+=hexString;		//else			//correcthexString=hexString;		//		System.out.println(correcthexString);				//int ceros = (8-(correcthexString.length()/2));//		System.out.println(ceros+" es numero de ceros");		//rellenamos de ceros lo que no hace falta		//for (int z = 0; z < ceros; z++) {			//sha[M.length+bytespadding+1+z] = (byte) 0x00;	//			System.out.println(z);		//}		//rellenamos las casillas que nos faltan		//int n = correcthexString.length()/2;		//for (int i = 0; i < n; i++) {		//	sha[M.length+bytespadding+1+ceros+i] = Byte.valueOf(correcthexString.substring(2*i, 2*i+2));		//}						//printeamos la array//		mostrar_array(sha);			byte sha256[] = new byte[32];				for (int i=0;i<8;i++){			tmp = H[i];		sha256[i*4]=(byte) (tmp>>>24);		sha256[i*4+1]=(byte)((tmp>>>16) & 0x00ff);			sha256[i*4+2]=(byte)((tmp>>>8) & 0x00ff);			sha256[i*4+3]=(byte)((tmp) & 0x00ff);		}																BigInteger result = new BigInteger(1,sha256);		return result;	}		static String rellenar_ceros(String value,int i){		int j = i-value.length();		String s = "0";		for (int j2 = 0; j2 < j-1; j2++) {			s+="0";		}		s+=value;		return s;			}			private static int padding (byte[] M){				int bytesM,bytesK;		//cogemos los bytes del mensaje		bytesM = M.length;		//le aplicamos la formula para sabes en bytesK cuantos bytes de ceros necesitamos		bytesK = (55- bytesM)%64;				//si es menor que 0 lo convertimos en positivo		if(bytesK<0)			bytesK+=64;		//devolvemos el numero de bytes		return bytesK;	}				private static int ShR (int X, int rot){			return X>>>rot;	}		private static int RotR (int X, int rot){				int Y = X;		return (X>>>rot)+(Y<<32-rot);	}		private static int AND (int a, int b){		return a & b;	}	private static int XOR (int a, int b){		return a ^ b;	}		private static int NOT (int a){		return ~a;	}		private static int CH(int a, int b, int c){				return XOR(AND(a,b),AND(NOT(a),c));	} 		private static int Maj(int a, int b, int c){				return XOR(XOR(AND(a,b),AND(a,c)),AND(b,c));	} 		private static int Sum0 (int a){				return XOR(XOR(RotR(a,2),RotR(a,13)),RotR(a,22));			}		private static int Sum1 (int a){				return XOR(XOR(RotR(a,6),RotR(a,11)),RotR(a,25));			}		private static int o0 (int a){				return XOR(XOR(RotR(a,7),RotR(a,18)),ShR(a,3));			}	private static int o1 (int a){				return XOR(XOR(RotR(a,17),RotR(a,19)),ShR(a,10));			}		static void mostrar_array(byte[] array){		System.out.println("Iniciamos el printeo de la array");		for (int i = 0; i < array.length; i++) {			System.out.println(array[i]);		}		System.out.println("Finalizamos de printear la array");	}}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美国产综合色视频| 激情五月播播久久久精品| 日韩国产精品久久久| 国产精品综合久久| 91精品国产品国语在线不卡| 国产精品免费aⅴ片在线观看| 调教+趴+乳夹+国产+精品| 成人伦理片在线| 久久亚区不卡日本| 亚洲电影中文字幕在线观看| 成人黄色在线视频| 欧美精品一区二区在线播放| 午夜精品福利一区二区三区蜜桃| youjizz国产精品| 久久综合久久久久88| 日韩高清一级片| 欧美吻胸吃奶大尺度电影| 亚洲欧洲一区二区在线播放| 久久精品国产免费看久久精品| 欧美日本一区二区三区| 亚洲欧美视频一区| www.亚洲国产| 国产精品蜜臀av| 国产电影精品久久禁18| 精品少妇一区二区三区在线播放| 偷窥国产亚洲免费视频| 日本韩国欧美国产| 亚洲欧美综合色| 91影院在线观看| 亚洲视频在线一区观看| 97久久人人超碰| 中文字幕中文乱码欧美一区二区 | √…a在线天堂一区| 国产成人综合网| 日本一区二区综合亚洲| 国产suv精品一区二区6| 中文字幕成人av| av亚洲精华国产精华| 亚洲欧洲在线观看av| 欧美成人猛片aaaaaaa| 五月天激情综合| 欧美一级日韩一级| 极品瑜伽女神91| 国产日韩欧美激情| 色综合婷婷久久| 亚洲综合在线五月| 88在线观看91蜜桃国自产| 久久er精品视频| 国产女同性恋一区二区| 成人激情午夜影院| 亚洲精选视频免费看| 欧美日韩在线播放三区| 日韩电影免费在线看| 欧美精品一区在线观看| jlzzjlzz欧美大全| 亚洲综合在线观看视频| 7777精品伊人久久久大香线蕉| 麻豆国产一区二区| 国产精品剧情在线亚洲| 欧美性欧美巨大黑白大战| 蜜臀99久久精品久久久久久软件| 久久久影视传媒| 91麻豆蜜桃一区二区三区| 三级一区在线视频先锋 | 日韩在线一二三区| 精品久久久久久久久久久久久久久久久| 国产一区二区三区香蕉| 国产精品蜜臀在线观看| 欧美日韩在线播放三区四区| 国产在线不卡一区| 亚洲女人****多毛耸耸8| 欧美一级欧美一级在线播放| 国产成人福利片| 午夜精品久久久久久久久久| 国产欧美一区二区在线观看| 欧美日韩精品一区二区天天拍小说 | 亚洲精品一线二线三线| 色网综合在线观看| 蜜桃视频免费观看一区| 亚洲女同一区二区| 2017欧美狠狠色| 欧美影院一区二区| 国产69精品久久99不卡| 日韩国产欧美一区二区三区| 亚洲婷婷在线视频| 久久午夜色播影院免费高清| 欧美高清视频www夜色资源网| a在线欧美一区| 久久99精品久久久久久| 亚洲国产wwwccc36天堂| 亚洲日韩欧美一区二区在线| 精品播放一区二区| 欧美挠脚心视频网站| 色哟哟国产精品| 成人精品电影在线观看| 久久成人精品无人区| 五月天一区二区三区| 亚洲美女免费在线| 国产精品久久综合| 国产亚洲精久久久久久| 精品嫩草影院久久| 欧美一区二区在线看| 欧美日韩国产综合一区二区| 91一区二区在线| 99这里都是精品| 成人精品一区二区三区中文字幕| 国产一区二区三区免费播放| 免费观看久久久4p| 青青国产91久久久久久| 午夜电影一区二区三区| 亚洲图片自拍偷拍| 亚洲成人资源网| 一区二区三区在线视频观看| 亚洲欧美国产高清| 亚洲欧美乱综合| 亚洲综合在线电影| 亚洲小少妇裸体bbw| 亚洲永久免费视频| 亚洲国产婷婷综合在线精品| 亚洲综合激情小说| 亚洲bt欧美bt精品| 日韩一区精品字幕| 久久国产精品99精品国产| 久草中文综合在线| 国产成人精品一区二区三区四区| 国产成人午夜精品影院观看视频 | 欧美mv日韩mv国产网站app| 日韩亚洲欧美在线| 精品欧美乱码久久久久久1区2区| 日韩精品一区二区三区中文不卡 | 国产精品沙发午睡系列990531| 欧美激情一区二区三区全黄| 国产精品嫩草久久久久| 亚洲精品欧美综合四区| 亚洲国产精品久久不卡毛片| 免费美女久久99| 国产乱淫av一区二区三区| 成人黄色片在线观看| 欧美综合视频在线观看| 日韩三级视频在线观看| 国产三级欧美三级日产三级99 | 亚洲一本大道在线| 免费av网站大全久久| 国产在线精品国自产拍免费| 97成人超碰视| 91精品国产综合久久福利软件| 久久婷婷成人综合色| 亚洲乱码精品一二三四区日韩在线| 亚洲亚洲精品在线观看| 国产在线播放一区二区三区| 99精品视频一区二区三区| 欧美日韩一区二区三区在线| 精品91自产拍在线观看一区| 亚洲欧美在线aaa| 蜜桃av一区二区在线观看| 不卡的av网站| 日韩欧美成人一区二区| 亚洲欧美激情在线| 极品美女销魂一区二区三区免费 | 亚洲欧美在线视频| 日本视频一区二区三区| 99久久夜色精品国产网站| 欧美久久久久久久久| 国产精品女主播av| 青青青爽久久午夜综合久久午夜| 丰满岳乱妇一区二区三区| 在线不卡一区二区| 国产精品第四页| 国内精品国产三级国产a久久| 日本精品视频一区二区三区| 久久久久久亚洲综合影院红桃| 亚洲电影欧美电影有声小说| 成人激情黄色小说| 亚洲精品在线免费播放| 三级久久三级久久| 91麻豆免费看| 国产精品视频一区二区三区不卡| 青青草一区二区三区| 91福利社在线观看| 国产精品每日更新| 国产一区二区在线观看视频| 91精品国产综合久久香蕉的特点| 亚洲美女偷拍久久| 99久久伊人精品| 中文字幕av资源一区| 国产老妇另类xxxxx| 欧美大胆一级视频| 日韩精品三区四区| 欧美区在线观看| 亚洲国产婷婷综合在线精品| 色哟哟国产精品| 亚洲黄色片在线观看| 99久久99精品久久久久久| 国产精品素人一区二区| 成人久久18免费网站麻豆 | 欧美猛男男办公室激情| 亚洲精品视频在线观看网站| 91香蕉视频在线| 亚洲人成伊人成综合网小说| 99久久精品国产毛片|