欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。