首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > JAVA > J2EE开发 >

如何避免字符串截取半个汉字

2012-01-18 
如何处理字符串截取半个汉字我要弄一个加密算法,但是会有汉字的加密,对于加密的字符串是进行字节处理的,但

如何处理字符串截取半个汉字
我要弄一个加密算法,但是会有汉字的加密,对于加密的字符串是进行字节处理的,但是会有中文加密,要如何处理那截取出来的半个中文,每次截取半个中文都是一个? 解析之后都是63 不管什么中文 处理之后都是这样,求个解决的办法

[解决办法]
不懂,帮顶。祝楼主好运
[解决办法]
这里有一个加密算法,也许能激发你的灵感


好像是火龙果大侠的杰作:

Java code
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源程序
[解决办法]
下面的程序是 网络上流传的面试题,他就是对字节数组加密和解密的(根据自己的方法)
我对他进行了简单解释

把精力放在如何对 字节数组 加密 <---> 解密

可以仿照下面的做法 

Java code
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: 搜狗浏览器是目前速度最快、最稳定、最安全、功能最强大的“双核”浏览器!!!!! */ 

热点排行