java獲取百度網(wǎng)盤真實(shí)下載鏈接的方法
本文實(shí)例講述了java獲取百度網(wǎng)盤真實(shí)下載鏈接的方法。分享給大家供大家參考。具體如下:
目前還存在一個(gè)問(wèn)題,同一ip在獲取3次以后會(huì)出現(xiàn)驗(yàn)證碼,會(huì)獲取失敗,感興趣的朋友對(duì)此可以加以完善。
返回的List<Map<String, Object>> 中的map包含:fileName( 文件名),url(實(shí)鏈地址)
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<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("};"); 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); System.out.println(fileListJson); jsonArray = new JSONArray("[" + fileListJson + "]"); jsonObject = jsonArray.getJSONObject(0); 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"); 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; } }
希望本文所述對(duì)大家的java程序設(shè)計(jì)有所幫助。
- 手把手搭建Java共享網(wǎng)盤的方法步驟
- Python 一鍵獲取百度網(wǎng)盤提取碼的方法
- Linux下使用nextcloud搭建個(gè)人網(wǎng)盤代碼實(shí)例
- SpringBoot開(kāi)發(fā)案例之打造私有云網(wǎng)盤的實(shí)現(xiàn)
- VPS搭建離線下載服務(wù)器(后網(wǎng)盤時(shí)代)
- 利用docker部署nextcloud 網(wǎng)盤的方法步驟
- 使用electron實(shí)現(xiàn)百度網(wǎng)盤懸浮窗口功能的示例代碼
- JS實(shí)現(xiàn)百度網(wǎng)盤任意文件強(qiáng)制下載功能
- Java如何搭建一個(gè)個(gè)人網(wǎng)盤
相關(guān)文章
EasyExcel工具讀取Excel空數(shù)據(jù)行問(wèn)題的解決辦法
EasyExcel是阿里巴巴開(kāi)源的一個(gè)excel處理框架,以使用簡(jiǎn)單,節(jié)省內(nèi)存著稱,下面這篇文章主要給大家介紹了關(guān)于EasyExcel工具讀取Excel空數(shù)據(jù)行問(wèn)題的解決辦法,需要的朋友可以參考下2022-08-08Springcloud RestTemplate服務(wù)調(diào)用代碼實(shí)例
這篇文章主要介紹了Springcloud RestTemplate服務(wù)調(diào)用代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08如何讀取properties或yml文件數(shù)據(jù)并匹配
這篇文章主要介紹了如何讀取properties或yml文件數(shù)據(jù)并匹配方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12淺談Java隨機(jī)數(shù)的原理、偽隨機(jī)和優(yōu)化
這篇文章主要介紹了淺談Java隨機(jī)數(shù)的原理、偽隨機(jī)和優(yōu)化,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-01-01Java基于Javafaker生成測(cè)試數(shù)據(jù)
這篇文章主要介紹了Java基于Javafaker生成測(cè)試數(shù)據(jù)的方法,幫助大家更好的理解和使用Java,感興趣的朋友可以了解下2020-12-12IDEA自動(dòng)生成TestNG的testng.xml的插件方法
這篇文章主要介紹了IDEA自動(dòng)生成TestNG的testng.xml的插件方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04