Java百度网盘创建链接,java获取百度网盘真实下载链接的方法
本文实例讲述了java获取百度网盘真实下载链接的方法。分享给大家供大家参考。具体如下:
目前还存在一个问题,同一ip在获取3次以后会出现验证码,会获取失败,感兴趣的朋友对此可以加以完善。
返回的List> 中的map包含:fileName( 文件名),url(实链地址)
dGkcZibTOb
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;
}
}
获取方法:
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> getUrl(String url) throws Exception {
List fs_id = new ArrayList();
List> list = new ArrayList>();
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("};");
JSONArray jsonArray = new JSONArray("[" + html.substring(a, b + 1)
+ "]");
JSONObject jsonObject = jsonArray.getJSONObject(0);
String uk = jsonObject.getString("uk");
String shareid = jsonObject.getString("shareid");
String path = URLEncoder.encode(jsonObject.getString("typicalPath"),
"utf-8");
jsonArray = new JSONArray("[" + jsonObject.getString("file_list") + "]");
jsonObject = jsonArray.getJSONObject(0);
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);
www.cppcns.com System.out.println(fileListJson);
jsonArray = new JSONArray("[http://www.cppcns.com" + fileListJson + "]");
jsonObject = jsonArray.getJSONObject(0);
jsonArray = new JSONArray(jsonObject.getString("list"));
}
final int size = jsonArray.length();
for (int i = 0; i < size; i++) {
Map map = new HashMap();
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");
JSONArray jsonArray2 = new JSONArray("[" + fileInfo + "]");
JSONObject json_data = jsonArray2.getJSONObject(0);
if (json_data.getString("errno").equals("0")) {
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;
}
}
希望本文所述对大家的java程序设计有所帮助。
本文标题: java获取百度网盘真实下载链接的方法
本文地址: http://www.cppcns.com/ruanjian/java/128186.html
Java百度网盘创建链接,java获取百度网盘真实下载链接的方法相关推荐
- 用批处理整理百度MP3上歌曲排行榜MP3及LRC文件的批量下载链接地址(含图文教程)
http://bbs.wuyou.com/viewthread.php?tid=192322 本文结构如下: 一.缘起:问题的提出 二.试探:徒劳而返 三.峰回路转:芝麻!开门! 四.万事俱备:xml ...
- =。= 好吧,获取优酷视频真实下载地址的后台完成了
=.= 好吧,获取优酷视频真实下载地址的后台完成了 Written by dreamfairy on 2011 年 02 月 28 日. Posted in DIARY, PHP, Working 这 ...
- php解析百度云真实地址吗,百度网盘怎么获取真实下载链接 百度云资源真实地址解析教程...
百度网盘是非常强大的,但是一些违规的资源禁止通过百度云下载,而且在百度云网盘中也不能查看,这就比较鸡肋了,除非找到资源的真实地址,将资源下载到本地,特此,小编为大家整理了一篇可以帮助你查找获取百度云资 ...
- 人物百度词条怎么创建,人物类百度百科创建更新
经常会有很多朋友遇到诸如人物百度词条不知道怎么创建的难题,其实这在日常生活中很常见,以为创建人物百度百科看似简单,实则比较难,下面洛希爱做百科网和大家一起来看看. 市场部的小张接到领导说帮公司创建百度 ...
- python seo百度_python与seo,python获取百度360
在百度输入关键词搜索出现的列表页,大约2013年开始点击目标链接,跳转的时候是百度地址,经过百度解析,才真的跳到目标页面.360相对简单很多,利用python略微处理就可以得到搜索结果的真实URL链接 ...
- 【Python】自动化办公-outlook邮箱处理(获取邮箱附件)/通过下载链接自动下载
outlook邮箱处理-获取邮箱附件 #先引入outlook import win32com.client outlook = win32com.client.Dispatch("Outlo ...
- [玩机] 如何获取Windows Store 商店应用下载链接
打开下面链接 https://store.rg-adguard.net/ 复制应用url到搜索框中,选择slow确定,在下方就会显示可用的下载链接地址,选择xxx.mixbundle 或 xxx.ap ...
- 【爬虫】Python3搜索并获取电影网站的迅雷下载链接
用到的python第三方库:bs4.requests.execjs(在python中调用js脚本) 目标网站: www.beiwo.tv 通过分析网页源码发现,网页通过调用一个加密JS脚本来加密网页源 ...
- 微信链接跳转浏览器 H5实现APP下载功能实现方法
由于微信的限制,应用文件在内置浏览器中下载全部被屏蔽掉,造成很多人用微信扫描二维码下载时点击下载按钮没反应,我想到的是做一个提示用户在浏览器中打开下载. 可以参考:微信打开网址添加在浏览器中打开提示 ...
最新文章
- ng-template、ng-container、ng-content和ngTemplateOutlet、ngProjectAs傻傻分不清!他们究竟是干啥的???
- java怎么统计字符串中各个字母的个数,人生转折!
- asp.net mysql 事务_ASP.NET里的事务处理(ado.net 数据库应用)
- 编译openwrt时报错:g++: internal compiler error: Killed (program cc1plus)
- C语言 二进制文件读取和写入
- smem – Linux 内存监视软件
- python面试题库——3数据库和缓存
- 在JBoss Fuse / Fabric8 / Karaf中使用Byteman
- 如何在SQL Server 2016中使用并行插入以提高查询性能
- 字节跳动斩获支付牌照欲建金融帝国,技术实力配得上野心吗?
- C语言——负数据强制类型转换注意事项
- 二十五、JAVA多线程(六、线程控制操作)
- jclasslib修改jar包中class文件 IDEA
- 在哪里可以查询汉语拼音音标?在线汉语拼音声调查询器
- vue前端页面素材代码大全
- 读书摘录---《李嘉诚成功语录 》
- Mutli-SG游戏 ——学习笔记
- Django 搜索结果分页的实现 以及点击下一页搜索条件丢失可能的原因分析
- F429的RTC当做stop模式下的唤醒源(FreeRTOS)
- 固定table中的TH的高度和TD的宽度