base32

转载 2016年08月30日 14:38:30
package com.frogs.googleauthdemo.util;


public class Base32New {


public static void main(String[] args) {
String secret = "zuDc7o1B";  

byte[] result = Base32New.decode(secret);
for(byte obj : result){
System.out.println(obj);
}
}

private static final String base32Chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZ234567"; 
private static final int[] base32Lookup = { 
0xFF, 0xFF, 0x1A, 0x1B, 0x1C, 0x1D, 0x1E, 0x1F, // '0', '1', '2', '3', '4', '5', '6', '7' 
0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, // '8', '9', ':', ';', '<', '=', '>', '?' 
0xFF, 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, // '@', 'A', 'B', 'C', 'D', 'E', 'F', 'G' 
0x07, 0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, // 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O' 
0x0F, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, // 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W' 
0x17, 0x18, 0x19, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, // 'X', 'Y', 'Z', '[', '\', ']', '^', '_' 
0xFF, 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, // '`', 'a', 'b', 'c', 'd', 'e', 'f', 'g' 
0x07, 0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, // 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o' 
0x0F, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, // 'p', 'q', 'r', 's', 't', 'u', 'v', 'w' 
0x17, 0x18, 0x19, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF // 'x', 'y', 'z', '{', '|', '}', '~', 'DEL' 
}; 

public static String encode( 
final byte[] bytes) { 
int i = 0, index = 0, digit = 0; 
int currByte, nextByte; 
StringBuffer base32 = new StringBuffer((bytes.length + 7) * 8 / 5); 

while (i < bytes.length) { 
currByte = (bytes[i] >= 0) ? bytes[i] : (bytes[i] + 256); // unsign 

/* Is the current digit going to span a byte boundary? */ 
if (index > 3) { 
if ((i + 1) < bytes.length) { 
nextByte = (bytes[i + 1] >= 0) ? bytes[i + 1] : (bytes[i + 1] + 256); 
} else { 
nextByte = 0; 


digit = currByte & (0xFF >> index); 
index = (index + 5) % 8; 
digit <<= index; 
digit |= nextByte >> (8 - index); 
i++; 
} else { 
digit = (currByte >> (8 - (index + 5))) & 0x1F; 
index = (index + 5) % 8; 
if (index == 0) { 
i++; 


base32.append(base32Chars.charAt(digit)); 


return base32.toString(); 


public static byte[] decode( 
final String base32) { 
int i, index, lookup, offset, digit; 
byte[] bytes = new byte[base32.length() * 5 / 8]; 

for (i = 0, index = 0, offset = 0; i < base32.length(); i++) { 
lookup = base32.charAt(i) - '0'; 

/* Skip chars outside the lookup table */ 
if (lookup < 0 || lookup >= base32Lookup.length) { 
continue; 


digit = base32Lookup[lookup]; 

/* If this digit is not in the table, ignore it */ 
if (digit == 0xFF) { 
continue; 


if (index <= 3) { 
index = (index + 5) % 8; 
if (index == 0) { 
bytes[offset] |= digit; 
offset++; 
if (offset >= bytes.length) { 
break; 

} else { 
bytes[offset] |= digit << (8 - index); 

} else { 
index = (index + 5) % 8; 
bytes[offset] |= (digit >>> index); 
offset++; 

if (offset >= bytes.length) { 
break; 

bytes[offset] |= digit << (8 - index); 


return bytes; 



}

相关文章推荐

base32解码器

  • 2017年11月02日 19:02
  • 8KB
  • 下载

Base-12.5.25.win32-py2.7.exe

  • 2012年05月29日 22:44
  • 26.46MB
  • 下载

磁力链接的BASE32编码向HEX编码的转换

动漫爱好者在“花园”使用磁链时,会发现有些网盘无法识别其提供的磁链。本文介绍了传统格式的磁链与花园使用的变种磁链的转换方法。...
  • sugar13
  • sugar13
  • 2016年03月02日 19:35
  • 1509

无聊写的base32编码

  • 2011年02月23日 10:39
  • 2KB
  • 下载

Base32编码

分类: 开发心得2004-09-07 14:10 7741人阅读 评论(11) 收藏 举报 bytenullexceptionstringmodulesystem 0、写在前面...

Base32加密

  • 2012年11月25日 21:47
  • 27KB
  • 下载

Base32_加密例子

  • 2017年08月31日 14:07
  • 21KB
  • 下载

Base32加解密算法与实战

通过孤水绕城大牛的推荐,小菜我在玩某一黑客游戏时,其中一关碰到一个密文,看样子很像base64的编码,但通过base64解码出现乱码。后来考虑是Md5(base64),于是又通过base64解码再转1...

Base32加解密算法与实战

来源:http://www.bhst.org作者:瘋吇ぺx[BHST]BLOG:http://hi.baidu.com/hacker_fengzi转载请保留此段文字   通过孤水绕城大牛的推荐,小菜我...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:base32
举报原因:
原因补充:

(最多只允许输入30个字)