一种新的 Base64 算法

2018-05-19 11:44:38 +08:00
 Braid

最近看到了一种新的 base64 算法,各位大佬有可以写出 Base64Decode 方法的吗?语言不限

public class Base64New {
    private static final char[] Base64ByteToStr = null;
    private static final int RANGE = 255;
    private static byte[] StrToBase64Byte;

    static {
        Base64New.Base64ByteToStr = new char[]{'v', 'w', 'x', 'r', 's', 't', 'u', 'o', 'p', 'q', '3', '4', '5', '6', '7', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'y', 'z', '0', '1', '2', 'P', 'Q', 'R', 'S', 'T', 'K', 'L', 'M', 'N', 'O', 'Z', 'a', 'b', 'c', 'd', 'U', 'V', 'W', 'X', 'Y', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', '8', '9', '+', '/'};
        Base64New.StrToBase64Byte = new byte[128];
    }

    public Base64New() {
        super();
    }

    public String Base64Encode(byte[] arg9) {
        int v7 = 3;
        StringBuilder v3 = new StringBuilder();
        int v1;
        for(v1 = 0; v1 <= arg9.length - 1; v1 += 3) {
            byte[] v0 = new byte[4];
            byte v4 = 0;
            int v2;
            for(v2 = 0; v2 <= 2; ++v2) {
                if(v1 + v2 <= arg9.length - 1) {
                    v0[v2] = ((byte)((arg9[v1 + v2] & 255) >>> v2 * 2 + 2 | v4));
                    v4 = ((byte)(((arg9[v1 + v2] & 255) << (2 - v2) * 2 + 2 & 255) >>> 2));
                }
                else {
                    v0[v2] = v4;
                    v4 = 64;
                }
            }

            v0[v7] = v4;
            for(v2 = 0; v2 <= v7; ++v2) {
                if(v0[v2] <= 63) {
                    v3.append(Base64New.Base64ByteToStr[v0[v2]]);
                }
                else {
                    v3.append('=');
                }
            }
        }

        return v3.toString();
    }
}
3021 次点击
所在节点    程序员
21 条回复
janxin
2018-05-19 11:49:31 +08:00
base64 只是一种编码啊…结果不同的最多叫变形…
Braid
2018-05-19 11:59:51 +08:00
@janxin 嗯,对的,口误 唉~
xmadi
2018-05-19 12:01:07 +08:00
???? base64 是一种编码 生成的算法是固定的 算法实现的方式是多样的 楼主你这个只是实现的一种方式啊 随便找个 decoder 也能解析吧
Braid
2018-05-19 12:03:11 +08:00
不要在意这些文字细节,用上面的编码后的
5rFf7E2K6rqN7Hpiyush7E6S5fJg6rsi5NBf6NGT5rs=


请教明文,重谢~
xmadi
2018-05-19 12:03:27 +08:00
@xmadi 粗糙看了下这个不是 base64 啊 和楼上说的一样 是 base64 的变形 实现原理和 base64 一样的
e9e499d78f
2018-05-19 12:09:02 +08:00
我觉得可以给报价了
hundan
2018-05-19 12:09:55 +08:00
粗糙看了下,应该只是默认字符表被替换了。找个能自定义字符表的工具就可以解了,之前做过。
hundan
2018-05-19 12:10:39 +08:00
@hundan 等等……给钱的吗哈哈哈,报价?
lukefan
2018-05-19 12:12:54 +08:00
一个 md5 字符串, 楼主想搞什么......
mengzhuo
2018-05-19 12:16:25 +08:00
05397c42f9b6da593a3644162d******
??后面几位隐掉了
qq316107934
2018-05-19 12:17:17 +08:00
这是反编译啥软件呢,发到这里找大家要 decode 不好吧?
des
2018-05-19 12:19:40 +08:00
看着风格像是反编译出来的
你还是报个价吧,先
Braid
2018-05-19 12:37:13 +08:00
@mengzhuo 可以单发下我看看嘛?加个好友,哈哈
cairnechen
2018-05-19 12:48:41 +08:00
等于说想在 v2 找免费劳动力
Braid
2018-05-19 12:52:37 +08:00
@cairnechen v2 不支持报价吧?没怎么逛过 不太清楚
InternetExplorer
2018-05-19 12:58:18 +08:00
InternetExplorer
2018-05-19 12:58:53 +08:00
不就是这个换了个码表吗
dartabe
2018-05-19 13:03:39 +08:00
楼主基本上就是个骗子了? 哈哈 标题起的就是骗子的风格
feiyuanqiu
2018-05-19 13:25:34 +08:00
05397c42f9b6da593a3644162d36eb01
EyreFree
2018-05-19 17:25:50 +08:00
V2 不支持报价?外包节点了解一下...

https://www.v2ex.com/go/outsourcing

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/456099

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX