Java实现迅雷地址转成普通地址实例代码
程序员文章站
2024-03-05 18:44:19
原理分析:迅雷的thunder://地址就是将普通url地址加前缀‘aa'、后缀‘zz',再base64编码后得到的字符串
实现:
步骤1,添加工具类base64 编码...
原理分析:迅雷的thunder://地址就是将普通url地址加前缀‘aa'、后缀‘zz',再base64编码后得到的字符串
实现:
步骤1,添加工具类base64 编码和解码:base64.java
package th; import java.io.*; /** * base64 编码和解码。 * * @author 宋立君 * @date 2014年07月03日 */ public class base64 { public base64() { } /** * 功能:编码字符串 * * @author 宋立君 * @date 2014年07月03日 * @param data * 源字符串 * @return string */ public static string encode(string data) { return new string(encode(data.getbytes())); } /** * 功能:解码字符串 * * @author 宋立君 * @date 2014年07月03日 * @param data * 源字符串 * @return string */ public static string decode(string data) { return new string(decode(data.tochararray())); } /** * 功能:编码byte[] * * @author 宋立君 * @date 2014年07月03日 * @param data * 源 * @return char[] */ public static char[] encode(byte[] data) { char[] out = new char[((data.length + 2) / 3) * 4]; for (int i = 0, index = 0; i < data.length; i += 3, index += 4) { boolean quad = false; boolean trip = false; int val = (0xff & (int) data[i]); val <<= 8; if ((i + 1) < data.length) { val |= (0xff & (int) data[i + 1]); trip = true; } val <<= 8; if ((i + 2) < data.length) { val |= (0xff & (int) data[i + 2]); quad = true; } out[index + 3] = alphabet[(quad ? (val & 0x3f) : 64)]; val >>= 6; out[index + 2] = alphabet[(trip ? (val & 0x3f) : 64)]; val >>= 6; out[index + 1] = alphabet[val & 0x3f]; val >>= 6; out[index + 0] = alphabet[val & 0x3f]; } return out; } /** * 功能:解码 * * @author 宋立君 * @date 2014年07月03日 * @param data * 编码后的字符数组 * @return byte[] */ public static byte[] decode(char[] data) { int templen = data.length; for (int ix = 0; ix < data.length; ix++) { if ((data[ix] > 255) || codes[data[ix]] < 0) { --templen; // ignore non-valid chars and padding } } // calculate required length: // -- 3 bytes for every 4 valid base64 chars // -- plus 2 bytes if there are 3 extra base64 chars, // or plus 1 byte if there are 2 extra. int len = (templen / 4) * 3; if ((templen % 4) == 3) { len += 2; } if ((templen % 4) == 2) { len += 1; } byte[] out = new byte[len]; int shift = 0; // # of excess bits stored in accum int accum = 0; // excess bits int index = 0; // we now go through the entire array (not using the 'templen' value) for (int ix = 0; ix < data.length; ix++) { int value = (data[ix] > 255) ? -1 : codes[data[ix]]; if (value >= 0) { // skip over non-code accum <<= 6; // bits shift up by 6 each time thru shift += 6; // loop, with new bits being put in accum |= value; // at the bottom. if (shift >= 8) { // whenever there are 8 or more shifted in, shift -= 8; // write them out (from the top, leaving any out[index++] = // excess at the bottom for next iteration. (byte) ((accum >> shift) & 0xff); } } } // if there is still something wrong we just have to throw up now! if (index != out.length) { throw new error("miscalculated data length (wrote " + index + " instead of " + out.length + ")"); } return out; } /** * 功能:编码文件 * * @author 宋立君 * @date 2014年07月03日 * @param file * 源文件 */ public static void encode(file file) throws ioexception { if (!file.exists()) { system.exit(0); } else { byte[] decoded = readbytes(file); char[] encoded = encode(decoded); writechars(file, encoded); } file = null; } /** * 功能:解码文件。 * * @author 宋立君 * @date 2014年07月03日 * @param file * 源文件 * @throws ioexception */ public static void decode(file file) throws ioexception { if (!file.exists()) { system.exit(0); } else { char[] encoded = readchars(file); byte[] decoded = decode(encoded); writebytes(file, decoded); } file = null; } // // code characters for values 0..63 // private static char[] alphabet = "abcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyz0123456789+/=" .tochararray(); // // lookup table for converting base64 characters to value in range 0..63 // private static byte[] codes = new byte[256]; static { for (int i = 0; i < 256; i++) { codes[i] = -1; // loggerutil.debug(i + "&" + codes[i] + " "); } for (int i = 'a'; i <= 'z'; i++) { codes[i] = (byte) (i - 'a'); // loggerutil.debug(i + "&" + codes[i] + " "); } for (int i = 'a'; i <= 'z'; i++) { codes[i] = (byte) (26 + i - 'a'); // loggerutil.debug(i + "&" + codes[i] + " "); } for (int i = '0'; i <= '9'; i++) { codes[i] = (byte) (52 + i - '0'); // loggerutil.debug(i + "&" + codes[i] + " "); } codes['+'] = 62; codes['/'] = 63; } private static byte[] readbytes(file file) throws ioexception { bytearrayoutputstream baos = new bytearrayoutputstream(); byte[] b = null; inputstream fis = null; inputstream is = null; try { fis = new fileinputstream(file); is = new bufferedinputstream(fis); int count = 0; byte[] buf = new byte[16384]; while ((count = is.read(buf)) != -1) { if (count > 0) { baos.write(buf, 0, count); } } b = baos.tobytearray(); } finally { try { if (fis != null) fis.close(); if (is != null) is.close(); if (baos != null) baos.close(); } catch (exception e) { system.out.println(e); } } return b; } private static char[] readchars(file file) throws ioexception { chararraywriter caw = new chararraywriter(); reader fr = null; reader in = null; try { fr = new filereader(file); in = new bufferedreader(fr); int count = 0; char[] buf = new char[16384]; while ((count = in.read(buf)) != -1) { if (count > 0) { caw.write(buf, 0, count); } } } finally { try { if (caw != null) caw.close(); if (in != null) in.close(); if (fr != null) fr.close(); } catch (exception e) { system.out.println(e); } } return caw.tochararray(); } private static void writebytes(file file, byte[] data) throws ioexception { outputstream fos = null; outputstream os = null; try { fos = new fileoutputstream(file); os = new bufferedoutputstream(fos); os.write(data); } finally { try { if (os != null) os.close(); if (fos != null) fos.close(); } catch (exception e) { system.out.println(e); } } } private static void writechars(file file, char[] data) throws ioexception { writer fos = null; writer os = null; try { fos = new filewriter(file); os = new bufferedwriter(fos); os.write(data); } finally { try { if (os != null) os.close(); if (fos != null) fos.close(); } catch (exception e) { e.printstacktrace(); } } } }
步骤2,编写迅雷地址转普通地址的类及方法:thundersiteconverutil.java
package th; /** * 迅雷地址转普通地址 * <p>title: thundersiteconverutil</p> * <p>description: </p> * <p>company: www.itcast.com</p> * @author 入云龙 * @date 2017年3月6日下午2:11:32 * @version 1.0 */ public class thundersiteconverutil { /** * 迅雷thunder://地址与普通url地址转换 其实迅雷的thunder://地址就是将普通url地址加前缀‘aa'、后缀‘zz',再base64编码后得到的字符串 * <p>title: t1</p> * <p>description: </p> * @param url * @return */ public string conver(string url){ string newurl=""; //s=s.substring(int begin,int end);截取s中从begin开始至end结束时的字符串,并将其赋值给s; //去掉迅雷地址前缀 url=url.substring(10, url.length()); //解密 newurl=base64.decode(url); //去掉头aa,尾zz newurl=newurl.substring(2, newurl.length()-2); return newurl; } }
步骤3,建立测试类:testth.java
package th; import org.junit.test; /* * 迅雷地址转普通地址测试 */ public class testth { @test public void test1(){ string url="thunder://qufodhrwoi8vdg9vbc5sds90zxn0lnppcfpa"; system.out.println("迅雷地址:"+url); url=new thundersiteconverutil().conver(url); system.out.println("普通地址:"+url); } }
运行junit测试test1,控制台输出:
迅雷地址:thunder://qufodhrwoi8vdg9vbc5sds90zxn0lnppcfpa
普通地址:http://tool.lu/test.zip
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: php 微信开发获取用户信息如何实现