Fix bug
This commit is contained in:
parent
eb2b9137d7
commit
757a7390b8
|
|
@ -1,9 +1,16 @@
|
||||||
package com.github.catvod.bean.mqitv;
|
package com.github.catvod.bean.mqitv;
|
||||||
|
|
||||||
|
import com.github.catvod.net.OkHttp;
|
||||||
|
|
||||||
|
import java.util.Locale;
|
||||||
|
import java.util.regex.Matcher;
|
||||||
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
public class User {
|
public class User {
|
||||||
|
|
||||||
private String id;
|
private String id;
|
||||||
private String mac;
|
private String mac;
|
||||||
|
private String token;
|
||||||
|
|
||||||
public User(String id, String mac) {
|
public User(String id, String mac) {
|
||||||
this.id = id;
|
this.id = id;
|
||||||
|
|
@ -17,4 +24,16 @@ public class User {
|
||||||
public String getMac() {
|
public String getMac() {
|
||||||
return mac;
|
return mac;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getToken() {
|
||||||
|
return token == null ? "" : token;
|
||||||
|
}
|
||||||
|
|
||||||
|
public User getToken(String host) {
|
||||||
|
String result = OkHttp.string(String.format(Locale.getDefault(), "%s/HSAndroidLogin.ecgi?ty=json&net_account=%s&mac_address1=%s&_=%d", host, getId(), getMac(), System.currentTimeMillis()));
|
||||||
|
Pattern pattern = Pattern.compile("\"Token\"\\s*:\\s*\"(.*?)\"", Pattern.CASE_INSENSITIVE);
|
||||||
|
Matcher matcher = pattern.matcher(result);
|
||||||
|
token = matcher.find() ? matcher.group(1) : "";
|
||||||
|
return this;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -6,14 +6,12 @@ import android.net.Uri;
|
||||||
import com.github.catvod.bean.mqitv.Data;
|
import com.github.catvod.bean.mqitv.Data;
|
||||||
import com.github.catvod.bean.mqitv.User;
|
import com.github.catvod.bean.mqitv.User;
|
||||||
import com.github.catvod.crawler.Spider;
|
import com.github.catvod.crawler.Spider;
|
||||||
import com.github.catvod.crawler.SpiderDebug;
|
|
||||||
import com.github.catvod.net.OkHttp;
|
import com.github.catvod.net.OkHttp;
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream;
|
import java.io.ByteArrayInputStream;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Locale;
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.concurrent.ThreadLocalRandom;
|
import java.util.concurrent.ThreadLocalRandom;
|
||||||
import java.util.regex.Matcher;
|
import java.util.regex.Matcher;
|
||||||
|
|
@ -55,7 +53,7 @@ public class MQiTV extends Spider {
|
||||||
String port = params.get("port");
|
String port = params.get("port");
|
||||||
if (port == null) port = "5003";
|
if (port == null) port = "5003";
|
||||||
if (ip != null) ext = ip;
|
if (ip != null) ext = ip;
|
||||||
String token = getToken();
|
String token = getUser().getToken();
|
||||||
if (token.isEmpty()) {
|
if (token.isEmpty()) {
|
||||||
Map<String, String> header = new HashMap<>();
|
Map<String, String> header = new HashMap<>();
|
||||||
String playing = params.get("playing");
|
String playing = params.get("playing");
|
||||||
|
|
@ -69,7 +67,10 @@ public class MQiTV extends Spider {
|
||||||
} else {
|
} else {
|
||||||
String id = params.get("id");
|
String id = params.get("id");
|
||||||
String auth = authChannel(id, token);
|
String auth = authChannel(id, token);
|
||||||
SpiderDebug.log("id=" + id + ", token=" + token + ", auth=" + auth);
|
if (!"OK".equals(auth)) {
|
||||||
|
users.get(getHost()).clear();
|
||||||
|
return proxy(params);
|
||||||
|
}
|
||||||
Object[] result = new Object[3];
|
Object[] result = new Object[3];
|
||||||
result[0] = 200;
|
result[0] = 200;
|
||||||
result[1] = "application/vnd.apple.mpegurl";
|
result[1] = "application/vnd.apple.mpegurl";
|
||||||
|
|
@ -84,28 +85,24 @@ public class MQiTV extends Spider {
|
||||||
if (!users.containsKey(getHost())) users.put(getHost(), new ArrayList<>());
|
if (!users.containsKey(getHost())) users.put(getHost(), new ArrayList<>());
|
||||||
for (Data item : data) {
|
for (Data item : data) {
|
||||||
for (String userIp : item.getStat().getUserIpList()) {
|
for (String userIp : item.getStat().getUserIpList()) {
|
||||||
|
if (users.get(getHost()).size() >= 5) continue;
|
||||||
Matcher userMatcher = userPattern.matcher(userIp);
|
Matcher userMatcher = userPattern.matcher(userIp);
|
||||||
Matcher macMatcher = macPattern.matcher(userIp);
|
Matcher macMatcher = macPattern.matcher(userIp);
|
||||||
String user = userMatcher.matches() ? userMatcher.group(1) : "";
|
String user = userMatcher.matches() ? userMatcher.group(1) : "";
|
||||||
String mac = macMatcher.matches() ? macMatcher.group(1) : "";
|
String mac = macMatcher.matches() ? macMatcher.group(1) : "";
|
||||||
if (!user.isEmpty() && !mac.isEmpty()) users.get(getHost()).add(new User(user, mac));
|
if (!user.isEmpty() && !mac.isEmpty()) {
|
||||||
|
User u = new User(user, mac).getToken(getHost());
|
||||||
|
if (!u.getToken().isEmpty()) users.get(getHost()).add(u);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static User choose() {
|
private static User getUser() {
|
||||||
if (users == null) users = new HashMap<>();
|
if (users == null) users = new HashMap<>();
|
||||||
if (!users.containsKey(getHost())) users.put(getHost(), new ArrayList<>());
|
if (!users.containsKey(getHost())) users.put(getHost(), new ArrayList<>());
|
||||||
if (users.get(getHost()).isEmpty()) loadUser(Data.objectFrom(OkHttp.string(getHost() + "/api/post?item=itv_traffic")).getData());
|
if (users.get(getHost()).isEmpty()) loadUser(Data.objectFrom(OkHttp.string(getHost() + "/api/post?item=itv_traffic")).getData());
|
||||||
return users.get(getHost()).get(ThreadLocalRandom.current().nextInt(users.size()));
|
return users.get(getHost()).isEmpty() ? new User("", "") : users.get(getHost()).get(ThreadLocalRandom.current().nextInt(users.size()));
|
||||||
}
|
|
||||||
|
|
||||||
private static String getToken() {
|
|
||||||
User user = choose();
|
|
||||||
String result = OkHttp.string(String.format(Locale.getDefault(), "%s/HSAndroidLogin.ecgi?ty=json&net_account=%s&mac_address1=%s&_=%d", getHost(), user.getId(), user.getMac(), System.currentTimeMillis()));
|
|
||||||
Pattern pattern = Pattern.compile("\"Token\"\\s*:\\s*\"(.*?)\"", Pattern.CASE_INSENSITIVE);
|
|
||||||
Matcher matcher = pattern.matcher(result);
|
|
||||||
return matcher.find() ? matcher.group(1) : "";
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static String authChannel(String id, String token) {
|
private static String authChannel(String id, String token) {
|
||||||
|
|
@ -117,8 +114,9 @@ public class MQiTV extends Spider {
|
||||||
|
|
||||||
private static String getM3u8(String id, String port, String token) {
|
private static String getM3u8(String id, String port, String token) {
|
||||||
String base = "http://" + Uri.parse(getHost()).getHost() + ":" + port + "/";
|
String base = "http://" + Uri.parse(getHost()).getHost() + ":" + port + "/";
|
||||||
String m3u8 = base + id + ".m3u8?token=" + token;
|
String m3u8 = OkHttp.string(base + id + ".m3u8?token=" + token);
|
||||||
String[] lines = OkHttp.string(m3u8).split("\\r?\\n");
|
if (m3u8.contains("\"Reason\"")) return "";
|
||||||
|
String[] lines = m3u8.split("\\r?\\n");
|
||||||
StringBuilder sb = new StringBuilder();
|
StringBuilder sb = new StringBuilder();
|
||||||
for (String line : lines) {
|
for (String line : lines) {
|
||||||
if (!line.startsWith("#")) line = base + line;
|
if (!line.startsWith("#")) line = base + line;
|
||||||
|
|
|
||||||
Binary file not shown.
|
|
@ -1 +1 @@
|
||||||
3f4ac4a1200a2e49dc6dfeee44d6384e
|
1f6ad25d85981dd689b5534170cdcd42
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue