百度云盘的多选下载怎么实现的啊?

流星划过_泪痕 2015-08-19 01:07:03



再问一下,在搜索框里面填入数据然后搜索,然后点击进入当中的一个结果,当我使用history.go(-1)时QQ、谷歌浏览器都可以返回原来的搜索的结果界面,而IE返回的是搜索的最初界面!!用history.back()也是一样!!这个问题什么解决啊??
...全文
1161 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
renjianxin0554 2015-08-19
  • 打赏
  • 举报
回复
获取方法
import java.net.URLEncoder;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.json.JSONArray;
import org.json.JSONObject;
import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
public class BaiduNetDisk {
    public static List<Map<String, Object>> getUrl(String url) throws Exception {
        List<String> fs_id = new ArrayList<String>();
        List<Map<String, Object>> list = new ArrayList<Map<String, Object>>();
        Document doc = Jsoup.connect(url).get();
        String html = doc.toString();
        int a = html.indexOf("{\"typicalPath");
        int b = html.indexOf("yunData.getCon");
        int sign_head = html.indexOf("yunData.SIGN = \"");
        int sign_foot = html.indexOf("yunData.TIMESTAMP");
        int time_head = html.indexOf("yunData.TIMESTAMP = \"");
        int time_foot = html.indexOf("yunData.SHARE_UK");
        int share_id_head = html.indexOf("yunData.SHARE_ID = \"");
        int share_id_foot = html.indexOf("yunData.SIGN ");
        String sign = html.substring(sign_head, sign_foot);
        sign = sign.substring(sign.indexOf("\"") + 1, sign.indexOf("\";"));
        String time = html.substring(time_head, time_foot);
        time = time.substring(time.indexOf("\"") + 1, time.indexOf("\";"));
        String share_id = html.substring(share_id_head, share_id_foot);
        share_id = share_id.substring(share_id.indexOf("\"") + 1,
                share_id.indexOf("\";"));
        System.out.println(share_id);
        html = html.substring(a, b);
        a = html.indexOf("{\"typicalPath");
        b = html.indexOf("};");
        JSONObject jsonObject = new JSONObject(html.substring(a, b + 1));
        String uk = jsonObject.getString("uk");
        String shareid = jsonObject.getString("shareid");
        String path = URLEncoder.encode(jsonObject.getString("typicalPath"),
                "utf-8");
        jsonObject = new JSONObject(jsonObject.getString("file_list"));
        JSONArray jsonArray = new JSONArray(jsonObject.getString("list"));
        jsonObject = jsonArray.getJSONObject(0);
        String app_id = jsonObject.getString("app_id");
        if (jsonObject.getString("isdir").equals("1")) {
            String url1 = "http://pan.baidu.com/share/list?uk="
                    + uk
                    + "&shareid="
                    + shareid
                    + "&page=1&num=100&dir="
                    + path
                    + "&order=time&desc=1&_="
                    + time
                    + "&bdstoken=c51077ce0e0e313a16066612a13fbcd4&channel=chunlei&clienttype=0&web=1&app_id="
                    + app_id;
            String fileListJson = HttpRequest.getData(url1);
            System.out.println(fileListJson);
            jsonObject =new JSONObject(fileListJson);
            jsonArray = new JSONArray(jsonObject.getString("list"));
        }
        final int size = jsonArray.length();
        for (int i = 0; i < size; i++) {
            Map<String, Object> map = new HashMap<String, Object>();
            jsonObject = jsonArray.getJSONObject(i);
            String fileName = jsonObject.getString("server_filename");
            //储存文件名
            map.put("fileName", fileName);
            fs_id.add(jsonObject.getString("fs_id"));
            String fileInfo = HttpRequest
                    .getData("http://pan.baidu.com/api/sharedownload?sign="
                            + sign
                            + "×tamp="
                            + time
                            + "&bdstoken=c51077ce0e0e313a16066612a13fbcd4&channel=chunlei&clienttype=0&web=1&app_id=250528&encrypt=0&product=share&uk="
                            + uk + "&primaryid=" + share_id + "&fid_list=%5B"
                            + fs_id.get(i) + "%5D");
            JSONObject json_data = new JSONObject(fileInfo);
            if (json_data.getString("errno").equals("0")) {
                JSONArray jsonArray2 = new JSONArray(json_data.getString("list"));
                json_data = jsonArray2.getJSONObject(0);
                //储存文件下载实链
                map.put("url", json_data.getString("dlink"));
            } else if (json_data.getString("errno").equals("-20")) {
                return null;
                // String getVerCode();
            } else {
                return null;
            }
            list.add(map);
        }
        return list;
    }
}
HttpRequest.java:
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.RandomAccessFile;
import java.lang.reflect.Method;
import java.net.HttpURLConnection;
import java.net.URL;
public class HttpRequest {
    public static String getData(String u) throws Exception {
        String re="";
                URL url = new URL(u);
        HttpURLConnection httpURLConnection = (HttpURLConnection) url
                .openConnection();
        httpURLConnection.setRequestMethod("GET");
        httpURLConnection.setDoInput(true);
        httpURLConnection.setDoOutput(true);
        InputStream is = httpURLConnection.getInputStream();
        InputStreamReader isr = new InputStreamReader(is);
        BufferedReader bufferedReader = new BufferedReader(isr);
        String iL = "";
        while ((iL = bufferedReader.readLine()) != null) {
            re += iL + "\n";
        }
          
        return re;
    }
}
问题,我是学易语言的。大神发给我了这个java代码。请问,他是怎么实现获取sign和timestamp的? 我好方便转换为易语言程序语言
  • 打赏
  • 举报
回复
引用 1 楼 shijing266 的回复:
多文件应该也是通过你的文件的ID来实现的,多个ID同时下载 返回上一页的话,每个浏览器的实现方式不同
返回我知道每个浏览器都一样啊,但是要通过什么方式实现呢???我在网上找的都不行
  • 打赏
  • 举报
回复
多文件应该也是通过你的文件的ID来实现的,多个ID同时下载 返回上一页的话,每个浏览器的实现方式不同

81,091

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧