mirror of
https://github.com/plan-player-analytics/Plan.git
synced 2025-01-24 16:14:26 +08:00
Fixed WebAPI variable parsing by replacing split symbol: & -> ;&
This commit is contained in:
parent
ad23d1e60d
commit
c7b2523fec
@ -17,11 +17,9 @@ import java.io.IOException;
|
||||
import java.io.InputStream;
|
||||
import java.nio.charset.StandardCharsets;
|
||||
import java.sql.SQLException;
|
||||
import java.util.Arrays;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.UUID;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
/**
|
||||
* Handles choosing of the correct API response to an API request.
|
||||
@ -71,7 +69,7 @@ public class APIResponseHandler {
|
||||
return PageCache.loadPage(error, () -> new BadRequestResponse(error));
|
||||
}
|
||||
|
||||
Map<String, String> variables = readVariables(requestBody);
|
||||
Map<String, String> variables = WebAPI.readVariables(requestBody);
|
||||
String sender = variables.get("sender");
|
||||
Log.debug("Received WebAPI Request" + target + " from " + sender);
|
||||
if (!checkKey(sender)) {
|
||||
@ -128,13 +126,4 @@ public class APIResponseHandler {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
private Map<String, String> readVariables(String requestBody) {
|
||||
String[] variables = requestBody.split("&");
|
||||
|
||||
return Arrays.stream(variables)
|
||||
.map(variable -> variable.split("=", 2))
|
||||
.filter(splitVariables -> splitVariables.length == 2)
|
||||
.collect(Collectors.toMap(splitVariables -> splitVariables[0], splitVariables -> splitVariables[1], (a, b) -> b));
|
||||
}
|
||||
}
|
@ -26,9 +26,11 @@ import java.net.SocketTimeoutException;
|
||||
import java.net.URL;
|
||||
import java.security.KeyManagementException;
|
||||
import java.security.NoSuchAlgorithmException;
|
||||
import java.util.Arrays;
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
import java.util.UUID;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
/**
|
||||
* @author Rsl1122
|
||||
@ -93,17 +95,11 @@ public abstract class WebAPI {
|
||||
|
||||
connection.setRequestProperty("charset", "ISO-8859-1");
|
||||
|
||||
StringBuilder parameters = new StringBuilder();
|
||||
String serverUUID = MiscUtils.getIPlan().getServerUuid().toString();
|
||||
parameters.append("sender=").append(serverUUID).append("&");
|
||||
for (Map.Entry<String, String> entry : variables.entrySet()) {
|
||||
parameters.append("&").append(entry.getKey()).append("=").append(entry.getValue());
|
||||
}
|
||||
String params = parameters.toString();
|
||||
String parameters = parseVariables();
|
||||
|
||||
connection.setRequestProperty("Content-Length", Integer.toString(params.length()));
|
||||
connection.setRequestProperty("Content-Length", Integer.toString(parameters.length()));
|
||||
|
||||
byte[] toSend = params.getBytes();
|
||||
byte[] toSend = parameters.getBytes();
|
||||
int length = toSend.length;
|
||||
|
||||
// connection.setRequestProperty("Content-Length", Integer.toString(length));
|
||||
@ -149,7 +145,7 @@ public abstract class WebAPI {
|
||||
return sc.getSocketFactory();
|
||||
}
|
||||
|
||||
static TrustManager[] trustAllCerts = new TrustManager[]{
|
||||
private static TrustManager[] trustAllCerts = new TrustManager[]{
|
||||
new X509TrustManager() {
|
||||
public java.security.cert.X509Certificate[] getAcceptedIssuers() {
|
||||
return null;
|
||||
@ -176,4 +172,23 @@ public abstract class WebAPI {
|
||||
protected Response badRequest(String error) {
|
||||
return PageCache.loadPage(error, () -> new BadRequestResponse(error));
|
||||
}
|
||||
|
||||
private String parseVariables() {
|
||||
StringBuilder parameters = new StringBuilder();
|
||||
String serverUUID = MiscUtils.getIPlan().getServerUuid().toString();
|
||||
parameters.append("sender=").append(serverUUID);
|
||||
for (Map.Entry<String, String> entry : variables.entrySet()) {
|
||||
parameters.append(";&").append(entry.getKey()).append("=").append(entry.getValue());
|
||||
}
|
||||
return parameters.toString();
|
||||
}
|
||||
|
||||
public static Map<String, String> readVariables(String requestBody) {
|
||||
String[] variables = requestBody.split(";&");
|
||||
|
||||
return Arrays.stream(variables)
|
||||
.map(variable -> variable.split("=", 2))
|
||||
.filter(splitVariables -> splitVariables.length == 2)
|
||||
.collect(Collectors.toMap(splitVariables -> splitVariables[0], splitVariables -> splitVariables[1], (a, b) -> b));
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user