一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - java多線程抓取鈴聲多多官網的鈴聲數據

java多線程抓取鈴聲多多官網的鈴聲數據

2020-04-21 11:43bobo_ll JAVA教程

很容易就能發現通過改變 listId和page就能從服務器獲取鈴聲的json數據, 通過解析json數據, 可以看到都帶有{"hasmore":1,"curpage":1}這樣子的指示,通過判斷hasmore的值,決定是否進行下一頁的抓取。 但是通過上面這個鏈接返回的json中不

一直想練習下java多線程抓取數據。

有天被我發現,鈴聲多多的官網(http://www.shoujiduoduo.com/main/)有大量的數據。

通過觀察他們前端獲取鈴聲數據的ajax

java多線程抓取鈴聲多多官網的鈴聲數據

http://www.shoujiduoduo.com/ringweb/ringweb.php?type=getlist&listid={類別ID}&page={分頁頁碼}

很容易就能發現通過改變 listId和page就能從服務器獲取鈴聲的json數據, 通過解析json數據,

可以看到都帶有{"hasmore":1,"curpage":1}這樣子的指示,通過判斷hasmore的值,決定是否進行下一頁的抓取。

但是通過上面這個鏈接返回的json中不帶有鈴聲的下載地址

很快就可以發現,點擊頁面的“下載”會看到

通過下面的請求,就可以獲取鈴聲的下載地址了

http://www.shoujiduoduo.com/ringweb/ringweb.php?type=geturl&act=down&rid={鈴聲ID}

java多線程抓取鈴聲多多官網的鈴聲數據

所以,他們的數據是很容易被偷的。于是我就開始...

源碼已經發在github上。如果感興趣的童鞋可以查看

github:https://github.com/yongbo000/DuoduoAudioRobot

上代碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
<pre class="brush:java;">package me.yongbo.DuoduoRingRobot;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.URL;
import java.net.URLConnection;
import java.util.Iterator;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import com.google.gson.Gson;
import com.google.gson.JsonArray;
import com.google.gson.JsonElement;
import com.google.gson.JsonParser;
/* * @author yongbo_ * @created 2013/4/16 * * */
public class DuoduoRingRobotClient implements Runnable {
public static String GET_RINGINFO_URL = "http://www.shoujiduoduo.com/ringweb/ringweb.php?type=getlist&listid=%1$d&page=%2$d";
public static String GET_DOWN_URL = "http://www.shoujiduoduo.com/ringweb/ringweb.php?type=geturl&act=down&rid=%1$d";
public static String ERROR_MSG = "listId為 %1$d 的Robot發生錯誤,已自動停止。當前page為 %2$d";public static String STATUS_MSG = "開始抓取數據,當前listId: %1$d,當前page: %2$d";
public static String FILE_DIR = "E:/RingData/";public static String FILE_NAME = "listId=%1$d.txt";private boolean errorFlag = false;private int listId;private int page;
private int endPage = -1;private int hasMore = 1;
private DbHelper dbHelper;
/** * 構造函數 * @param listId 菜單ID * @param page 開始頁碼 * @param endPage 結束頁碼 * */
public DuoduoRingRobotClient(int listId, int beginPage, int endPage)
 {this.listId = listId;this.page = beginPage;this.endPage = endPage;this.dbHelper = new DbHelper();}
/** * 構造函數 * @param listId 菜單ID * @param page 開始頁碼 * */
public DuoduoRingRobotClient(int listId, int page) {this(listId, page, -1);}
/** * 獲取鈴聲 * */public void getRings() {String url = String.format(GET_RINGINFO_URL, listId, page);String responseStr = httpGet(url);hasMore = getHasmore(responseStr);
page = getNextPage(responseStr);
ringParse(responseStr.replaceAll("\\{\"hasmore\":[0-9]*,\"curpage\":[0-9]*\\},", "").replaceAll(",]", "]"));}/** * 發起http請求 * @param webUrl 請求連接地址 * */public String httpGet(String webUrl){URL url;URLConnection conn;StringBuilder sb = new StringBuilder();String resultStr = "";try {url = new URL(webUrl);conn = url.openConnection();conn.connect();InputStream is = conn.getInputStream();InputStreamReader isr = new InputStreamReader(is);BufferedReader bufReader = new BufferedReader(isr);String lineText;while ((lineText = bufReader.readLine()) != null) {sb.append(lineText);}resultStr = sb.toString();} catch (Exception e) {errorFlag = true;//將錯誤寫入txtwriteToFile(String.format(ERROR_MSG, listId, page));}return resultStr;}/** * 將json字符串轉化成Ring對象,并存入txt中 * @param json Json字符串 * */public void ringParse(String json) {Ring ring = null;JsonElement element = new JsonParser().parse(json);JsonArray array = element.getAsJsonArray();// 遍歷數組Iterator<JsonElement> it = array.iterator();
Gson gson = new Gson();while (it.hasNext() && !errorFlag) {JsonElement e = it.next();// JsonElement轉換為JavaBean對象ring = gson.fromJson(e, Ring.class);ring.setDownUrl(getRingDownUrl(ring.getId()));if(isAvailableRing(ring)) {System.out.println(ring.toString());
//可選擇寫入數據庫還是寫入文本//writeToFile(ring.toString());writeToDatabase(ring);}}}
/** * 寫入txt * @param data 字符串 * */public void writeToFile(String data)
 {String path = FILE_DIR + String.format(FILE_NAME, listId);File dir = new File(FILE_DIR);File file = new File(path);FileWriter fw = null;if(!dir.exists()){dir.mkdirs();
}try {if(!file.exists()){file.createNewFile();}fw = new FileWriter(file, true);
fw.write(data);fw.write("\r\n");fw.flush();} catch (IOException e) {
// TODO Auto-generated catch blocke.printStackTrace();
}finally {try {if(fw != null){fw.close();}} catch (IOException e) {
// TODO Auto-generated catch blocke.printStackTrace();}}}/** * 寫入數據庫 * @param ring 一個Ring的實例 * */
public void writeToDatabase(Ring ring) {dbHelper.execute("addRing", ring);}
@Overridepublic void run() {while(hasMore == 1 && !errorFlag){if(endPage != -1){if(page > endPage) { break; }}System.out.println(String.format(STATUS_MSG, listId, page));
getRings();System.out.println(String.format("該頁數據寫入完成"));}System.out.println("ending...");}
private int getHasmore(String resultStr){Pattern p = Pattern.compile("\"hasmore\":([0-9]*),\"curpage\":([0-9]*)");
 Matcher match = p.matcher(resultStr); 
 if (match.find()) {  return Integer.parseInt(match.group(1));
  }  return 0;
}
private int getNextPage(String resultStr){Pattern p = Pattern.compile("\"hasmore\":([0-9]*),\"curpage\":([0-9]*)");Matcher match = p.matcher(resultStr);if (match.find()) {return Integer.parseInt(match.group(2));}return 0;}
/** * 判斷當前Ring是否滿足條件。當Ring的name大于50個字符或是duration為小數則不符合條件,將被剔除。 * @param ring 當前Ring對象實例 * */private boolean isAvailableRing(Ring ring){Pattern p = Pattern.compile("^[1-9][0-9]*$");
Matcher match = p.matcher(ring.getDuration());
if(!match.find()){return false;}if(ring.getName().length() > 50 || ring.getArtist().length() > 50 || ring.getDownUrl().length() == 0){return false;}return true;}
/** * 獲取鈴聲的下載地址 * @param rid 鈴聲的id * */
public String getRingDownUrl(String rid){String url = String.format(GET_DOWN_URL, rid);
String responseStr = httpGet(url);return responseStr;}}</pre>

 

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产在线视频在线观看 | 国产精品久久久久不卡绿巨人 | 欧美激情影音先锋 | 日本zzzzwww大片免费 | 国产微拍精品一区 | 视频一区国产精戏刘婷30 | 吻戏辣妞范1000免费体验 | 欧美a级完整在线观看 | 欧美精品日韩 | 美女gif趴跪式抽搐动态图 | 国产一区二区不卡视频 | 欧美久久久久久久一区二区三区 | 女女同性做爰xxoo亲吻 | 天天草b| 乌克兰肥熟 | 亚洲高清视频在线 | 很很草 | 欧美日韩免费一区二区在线观看 | 日本黄色一区 | 日韩a无吗一区二区三区 | 天天摸天天碰色综合网 | 欧美一级xxxx俄罗斯一级 | 久久久久久久久a免费 | 亲爱的客栈第二季免费观看完整版 | 亚洲欧洲日产国码无码av | 日本欧美强乱视频在线 | 逼中极品| 午夜理论片YY4399影院 | 二次元美女内裤凹陷太深 | 好男人资源大全免费观看 | sxx免费看观看美女 sss亚洲国产欧美一区二区 | 狠狠色狠狠色综合曰曰 | 四虎最新紧急更新地址 | 动漫美女被褥吸奶漫画漫画 | 日本高清视频一区二区 | 超级乱淫伦短篇小说做车 | 99久久九九| 欧美性xxxxxx爱| 我的绝色岳每雯雯 | 国产精品人人视频 | 亚飞与亚基国语1080p在线观看 |