GalaxyPilot —— D.S


        生命不熄,战斗不止
数据加载中……

技术挑战——根据编码函数写出解码函数

第一个粘出解码函数的人将得到价值几百美元的混淆工具,据评价也是目前最好的混淆器。当然,前题是你想要:)。

public class Base64Coder
{

    public static void main(String[] args)
    {
     String a = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";//这里不技持中文
     String ru;
     char[] ch;
     try{
      byte[] bt= a.getBytes("UTF-8");
      ch = encrypt(bt);
      //ru = new String(decrypt(ch));
      System.out.println(ru);
     }catch(Exception e){}
    }
    public static char[] encrypt(byte abyte0[])
    {
        int i = abyte0.length;
        int j = (i * 4 + 2) / 3;
        int k = ((i + 2) / 3) * 4;
        char ac[] = new char[k];
        int l = 0;
        for(int i1 = 0; l < i; i1++)
        {
            int j1 = abyte0[l++] & 0xff;
            int k1 = l >= i ? 0 : abyte0[l++] & 0xff;
            int l1 = l >= i ? 0 : abyte0[l++] & 0xff;
            int i2 = j1 >>> 2;
            int j2 = (j1 & 3) << 4 | k1 >>> 4;
            int k2 = (k1 & 0xf) << 2 | l1 >>> 6;
            int l2 = l1 & 0x3f;
            ac[i1++] = cChar[i2];
            ac[i1++] = cChar[j2];
            ac[i1] = i1 >= j ? '=' : cChar[k2];
            i1++;
            ac[i1] = i1 >= j ? '=' : cChar[l2];
        }

        return ac;
    }

    private static char cChar[];
    private static byte bByte[];

    static
    {
        cChar = new char[64];
        int i = 0;
        for(char c = 'A'; c <= 'Z'; c++)
            cChar[i++] = c;

        for(char c1 = 'a'; c1 <= 'z'; c1++)
            cChar[i++] = c1;

        for(char c2 = '0'; c2 <= '9'; c2++)
            cChar[i++] = c2;

        cChar[i++] = '+';
        cChar[i++] = '/';
        bByte = new byte[128];
        for(int j = 0; j < bByte.length; j++)
            bByte[j] = -1;

        for(int k = 0; k < 64; k++)
            bByte[cChar[k]] = (byte)k;

    }
}

posted on 2007-10-12 09:49 舵手 阅读(2096) 评论(10)  编辑  收藏

评论

# re: 技术挑战——根据编码函数写出解码函数  回复  更多评论   

不容易哦
2007-10-12 09:57 | 千里冰封

# re: 技术挑战——根据编码函数写出解码函数  回复  更多评论   

看代码比较类,还是把代码的原理写出来.
2007-10-12 12:28 | KF.咖啡

# re: 技术挑战——根据编码函数写出解码函数  回复  更多评论   

哈哈,写出来那个挑个什么啊!过两天发布解码函数
2007-10-12 13:13 | 舵手 QQ:8117892

# re: 技术挑战——根据编码函数写出解码函数  回复  更多评论   

呵呵 解码 G_G
这也被你整出来 !·#¥%……

仔细看了下
// 这好说 与 111.... 到时候 不变 到 j1
// 还真玩人
int j1 = abyte0[l++] & 0xff;

//k1 ,l1 得到 0 或 abyte0[l++]
int k1 = l >= i ? 0 : abyte0[l++] & 0xff;
int l1 = l >= i ? 0 : abyte0[l++] & 0xff;

// >>> ??什么东西 难道是 j1>> (>>2) ?
//>> 是 和 除 /2 有点同 1101 >> 0110 : 1
int i2 = j1 >>> 2;

// ....... (无语)
int j2 = (j1 & 3) << 4 | k1 >>> 4;
int k2 = (k1 & 0xf) << 2 | l1 >>> 6;
int l2 = l1 & 0x3f;
//静态块中定义的 cChar 定义的 什么 A..Z 9..0 a..z
ac[i1++] = cChar[i2];
ac[i1++] = cChar[j2];
// ..... 外头的 l1 还是 不好好一步一步走的 !·#¥%……
ac[i1] = i1 >= j ? '=' : cChar[k2];
i1++;
ac[i1] = i1 >= j ? '=' : cChar[l2];

看来 我 好好当代码工人把 (有点不干啊 )
2007-10-12 17:03 | G_G

# re: 技术挑战——根据编码函数写出解码函数  回复  更多评论   

等 等
java 好象是 16 为是吧
那第一句的
int j1 = abyte0[l++] & 0xff;
只 给 后 面 8位与 前面的补0 也与
!@#$%
这怎么反 啊
等结果
2007-10-12 17:16 | G_G

# re: 技术挑战——根据编码函数写出解码函数  回复  更多评论   

貌似对了,大家帮忙测试一下吧。代码写的有点乱!
private static byte[] decrypt(char[] ch) {

int len = ch.length / 4 * 3;
if(ch[ch.length - 1] == '=') len--;
if(ch[ch.length - 2] == '=') len--;
byte[] result = new byte[++len];
for(int i = 0, j = 0; i < len; ) {

int a = bByte[ch[j++]] & 0x3f;
int b = bByte[ch[j++]] & 0x3f;
result[i++] = (byte)(a << 2 | b >>> 4);
if(ch[j] == '=') break;
int c = bByte[ch[j++]] & 0x3f;
result[i++] = (byte)(b << 4 | c >>> 2);
if(ch[j] == '=') break;
int d = bByte[ch[j++]] & 0x3f;
result[i++] = (byte)(c << 6 | d);
}

return result;
}
2007-10-12 19:19 | lmatt

# re: 技术挑战——根据编码函数写出解码函数  回复  更多评论   

编码的过程,应该是把3个字节转成了4个字节。
2007-10-12 19:28 | lmatt

# re: 技术挑战——根据编码函数写出解码函数  回复  更多评论   

lmatt果然很牛,试了一下是通过了。可以和我联系一下,混淆器需要的话发给你。

下面是我的解码函数
public static byte[] decrypt(char ac[])
{
int i = ac.length;
if(i % 4 != 0)
throw new IllegalArgumentException("Length of Base64 encoded input string is not a multiple of 4.");
for(; i > 0 && ac[i - 1] == '='; i--);
int j = (i * 3) / 4;
byte abyte0[] = new byte[j];
int k = 0;
int l = 0;
do
{
if(k >= i)
break;
char c = ac[k++];
char c1 = ac[k++];
char c2 = k >= i ? 'A' : ac[k++];
char c3 = k >= i ? 'A' : ac[k++];
if(c > '\177' || c1 > '\177' || c2 > '\177' || c3 > '\177')
throw new IllegalArgumentException("Illegal character in Base64 encoded data.");
byte byte0 = bByte[c];
byte byte1 = bByte[c1];
byte byte2 = bByte[c2];
byte byte3 = bByte[c3];
if(byte0 < 0 || byte1 < 0 || byte2 < 0 || byte3 < 0)
throw new IllegalArgumentException("Illegal character in Base64 encoded data.");
int i1 = byte0 << 2 | byte1 >>> 4;
int j1 = (byte1 & 0xf) << 4 | byte2 >>> 2;
int k1 = (byte2 & 3) << 6 | byte3;
abyte0[l++] = (byte)i1;
if(l < j)
abyte0[l++] = (byte)j1;
if(l < j)
abyte0[l++] = (byte)k1;
} while(true);
return abyte0;
}
2007-10-13 08:44 | 舵手 QQ:8117892

# re: 技术挑战——根据编码函数写出解码函数  回复  更多评论   

在qq上加你为好友了
2007-10-13 10:39 | lmatt

# re: 技术挑战——根据编码函数写出解码函数  回复  更多评论   

哇!是不容易也,lmatt就是牛!
2007-10-20 02:00 | bigboy

只有注册用户登录后才能发表评论。


网站导航: