如何处理字符串截取半个汉字
我要弄一个加密算法,但是会有汉字的加密,对于加密的字符串是进行字节处理的,但是会有中文加密,要如何处理那截取出来的半个中文,每次截取半个中文都是一个? 解析之后都是63 不管什么中文 处理之后都是这样,求个解决的办法
[解决办法]
不懂,帮顶。祝楼主好运
[解决办法]
这里有一个加密算法,也许能激发你的灵感
好像是火龙果大侠的杰作:
import java.security.Key;import java.util.Arrays;import javax.crypto.Cipher;import javax.crypto.SecretKeyFactory;import javax.crypto.spec.DESedeKeySpec;import javax.crypto.spec.IvParameterSpec;import sun.misc.BASE64Decoder;import sun.misc.BASE64Encoder;import test.temp23;//http://topic.csdn.net/u/20101112/11/906A2C5D-5F3B-4284-9DE8-DDB3A18B0BA0.htmlpublic class Des { public static void main(String[] args) throws Exception { byte[] key=new BASE64Decoder().decodeBuffer("YWJjZGVmZ2hpamtsbW5vcHFyc3R1dnd4"); byte[] keyiv = { 1, 2, 3, 4, 5, 6, 7, 8 }; byte[] data="中国ABCabc123".getBytes("UTF-8"); System.out.println("ECB加密解密"); byte[] str3 = des3EncodeECB(key,data ); byte[] str4 = ees3DecodeECB(key, str3); System.out.println(new BASE64Encoder().encode(str3)); System.out.println(new String(str4, "UTF-8")); System.out.println(); System.out.println("CBC加密解密"); byte[] str5 = des3EncodeCBC(key, keyiv, data); byte[] str6 = des3DecodeCBC(key, keyiv, str5); System.out.println(new BASE64Encoder().encode(str5)); System.out.println(new String(str6, "UTF-8")); } /** * ECB加密,不要IV * @param key 密钥 * @param data 明文 * @return Base64编码的密文 * @throws Exception */ public static byte[] des3EncodeECB(byte[] key, byte[] data) throws Exception { Key deskey = null; DESedeKeySpec spec = new DESedeKeySpec(key); SecretKeyFactory keyfactory = SecretKeyFactory.getInstance("desede"); deskey = keyfactory.generateSecret(spec); Cipher cipher = Cipher.getInstance("desede" + "/ECB/PKCS5Padding"); cipher.init(Cipher.ENCRYPT_MODE, deskey); byte[] bOut = cipher.doFinal(data); return bOut; } /** * ECB解密,不要IV * @param key 密钥 * @param data Base64编码的密文 * @return 明文 * @throws Exception */ public static byte[] ees3DecodeECB(byte[] key, byte[] data) throws Exception { Key deskey = null; DESedeKeySpec spec = new DESedeKeySpec(key); SecretKeyFactory keyfactory = SecretKeyFactory.getInstance("desede"); deskey = keyfactory.generateSecret(spec); Cipher cipher = Cipher.getInstance("desede" + "/ECB/PKCS5Padding"); cipher.init(Cipher.DECRYPT_MODE, deskey); byte[] bOut = cipher.doFinal(data); return bOut; } /** * CBC加密 * @param key 密钥 * @param keyiv IV * @param data 明文 * @return Base64编码的密文 * @throws Exception */ public static byte[] des3EncodeCBC(byte[] key, byte[] keyiv, byte[] data) throws Exception { Key deskey = null; DESedeKeySpec spec = new DESedeKeySpec(key); SecretKeyFactory keyfactory = SecretKeyFactory.getInstance("desede"); deskey = keyfactory.generateSecret(spec); Cipher cipher = Cipher.getInstance("desede" + "/CBC/PKCS5Padding"); IvParameterSpec ips = new IvParameterSpec(keyiv); cipher.init(Cipher.ENCRYPT_MODE, deskey, ips); byte[] bOut = cipher.doFinal(data); return bOut; } /** * CBC解密 * @param key 密钥 * @param keyiv IV * @param data Base64编码的密文 * @return 明文 * @throws Exception */ public static byte[] des3DecodeCBC(byte[] key, byte[] keyiv, byte[] data) throws Exception { Key deskey = null; DESedeKeySpec spec = new DESedeKeySpec(key); SecretKeyFactory keyfactory = SecretKeyFactory.getInstance("desede"); deskey = keyfactory.generateSecret(spec); Cipher cipher = Cipher.getInstance("desede" + "/CBC/PKCS5Padding"); IvParameterSpec ips = new IvParameterSpec(keyiv); cipher.init(Cipher.DECRYPT_MODE, deskey, ips); byte[] bOut = cipher.doFinal(data); return bOut; }}
[解决办法]
加密算法之md5算法java源程序
[解决办法]
下面的程序是 网络上流传的面试题,他就是对字节数组加密和解密的(根据自己的方法)
我对他进行了简单解释
把精力放在如何对 字节数组 加密 <---> 解密
可以仿照下面的做法
public class TestEncryptAndDecrypt { // 原理:a^(a^b) = b public static void encode(byte[] in, byte[] out, int password) { int len = in.length; int seed = password ^ 0xb1c0796; System.out.println(seed); for (int i = 0; i < len; ++i) { // in[i]与seed异或后,向右移动3位,高三位右移变成低3位,有效位范围:第0位到第2位 //总的看来,只剩下原来字节的第5位到第7位,放到现在字节a的第0位到第2位 byte a = (byte) ((in[i] ^ seed) >>> 5); // in[i]与seed异或后,向右移动3位,高三位右移变成低3位,把原来的高5位置0 // in[i]与seed的第21位开始异或后,把异或结果右移17位,即把异或后in[i]的低五位变成了高五位 //-------------------------------------------------------------- //1.先将8个二进制位扩展为32个二进制位,高24位补0:有效位范围:第0位到第7位 //2.将32个二进制位向左移动二十位,低位补0,有效位范围:第20位到第27位 //3.异或,有效位范围:第20位到第27位 //4.向右移动17位高位补0,有效位范围:第3位到第10位 //5.先将32个二进制位向下强制转为8个二进制位,只剩下低8位,有效位范围:第3位到第7位 //总的看来,只剩下原来字节的第0位到第4位,放到现在字节b的第3位到第7位 byte b = (byte) (((((int) in[i]) << 20) ^ seed) >>> (20 - 3)); //--------------------------------------------------------------- //16进制的0x7相当于二进制的00000111,与a中的8个二进制为进行"按位与"操作,相当于将a中的第3位到第7位置0 //a中的第3位到第7位存放的是无效位,也就是将无效位置0, 有效位范围:第0位到第2位不受影响 a &= 0x7; // //---------------------------------------------------------------- //16进制的0xf8相当于二进制的11111000,与b中的8个二进制为进行"按位与"操作,相当于将b中的第0位到第2位置0 //b中的第0位到第2位存放的是无效位,也就是将无效位置0 有效位范围:第3位到第7位不受影响 b &= 0xf8; //--------------------------------------------------------------- //a与b进行"按位或"操作 , //a中的无效位(第3位到第7位)已经为0,所以结果的第3位到第7位是由b中的第3位到第7位决定 //b中的无效位(第0位到第2位)已经为0,所以结果的第0位到第2位是由a中的第0位到第2位决定 //总的看来;又是将a中5位有效位,和b中3位有效位组合在一起,组成8位有效位 out[i] = (byte) (a | b); //-------------------------------------------------------------------- //---原来的in[i]与seed先异或再循环右移5位。变为out[i],---------- //每一次都要改变seed,改变后的seed只依赖于前一个in[i]和常量48475829(最前头seed是依赖于0xb1c07965和password) seed = ((seed ^ in[i]) * 48475829 + in[i]); } } public static void decode(byte[] in, byte[] out, int password) { int len = in.length; int seed = password ^ 0xb1c07965;//最前头seed是依赖于0xb1c07965和password System.out.println("hhhh:" + seed); for (int i = 0; i < len; ++i) { // fill the code here //-------------------------------------------------------- // //可以利用字节变量a中第5位到第7位临时存放第0位到第2位,b中第0位到第4位临时存放第3位到第7位 //第3位到第7位置0,左移5位,a中第5位到第7位是有效位 byte a = (byte) ((in[i] & 0x07) << 5); // 把密文的第三位变成高三位 //第0位到第2位置0,右移3位,b中第0位到第4位是有效位 byte b = (byte) ((in[i] & 0xf8) >>> 3); // 把密文的高五位变成低五位 //--------------------------------------------------------- a = (byte) (a ^ seed); // 还原 a &= 0xe0; //无效位再次置0,因为有可能,经过异或之后变成1了 b = (byte) (((((int) b) << 20) ^ seed) >>> 20); // 还原 b &= 0x1f; ////无效位再次置0,因为有可能,经过异或之后变成1了 out[i] = (byte)(a | b); //将临时变量中的数据串接,保存到out[i],这是真实的数据来了, //每一次循环seed是不一样的,利用真实数据out[i]和常量48475829求出seed seed = ((seed ^ out[i]) * 48475829 + out[i]); } } public static void main(String[] args) throws Exception { String string = "123\r\n456"; //System.out.println(string); //string = string.replaceAll("\\r\\n",""); //string = string.replaceAll("\\r",""); //string = string.replaceAll("\\n",""); string = string.substring(0,2); char [] tempArray = string.toCharArray(); for(int i= 0; i<tempArray.length; i++){ System.out.print((int)tempArray[i] + " "); } int password = 0x38431c82; byte[] buf1 = { 29, 11, 94, -88, -120, -59, -45, 124, 64, -109, -44, 87, 12, -92, -18, 76, -11, -88, 126, -44, 72, 85, -16, -84, 73, -34, -15, 104, -114, 112, -4, -47, 25, 52, 6, -80, 124, 41, 34, -55, -99, 31, 12, -1, -28, 49, 124, -7, -18, 105, -42, -105, 1, 50, }; byte[] buf2 = new byte[buf1.length]; decode(buf1, buf2, password); System.out.println(new String(buf2)); }}/*output: 搜狗浏览器是目前速度最快、最稳定、最安全、功能最强大的“双核”浏览器!!!!! */