Compare commits

...

5 Commits

Author SHA1 Message Date
3832d5a326 Merge pull request 'samu_masken' (#9) from samu_masken into master
Reviewed-on: #9
2023-12-20 09:56:31 +01:00
456e55a66e GSON works 2023-12-20 09:28:32 +01:00
bf9c99672d GSON Test 2023-12-18 09:25:08 +01:00
db26bca5a3 GSON dependency 2023-12-18 09:12:03 +01:00
71c2c5d005 @author changes 2023-12-18 08:50:46 +01:00
4 changed files with 68 additions and 12 deletions

View File

@ -38,6 +38,11 @@
<version>${junit.version}</version> <version>${junit.version}</version>
<scope>test</scope> <scope>test</scope>
</dependency> </dependency>
<dependency>
<groupId>com.google.code.gson</groupId>
<artifactId>gson</artifactId>
<version>2.10.1</version>
</dependency>
</dependencies> </dependencies>
<build> <build>

View File

@ -5,9 +5,12 @@ import java.util.ArrayList;
public class Kind { public class Kind {
// region Felder // region Felder
private transient int id;
private String name; private String name;
private String vorname; private String vorname;
private int id; private int bid;
// TODO Zutat implementieren! // TODO Zutat implementieren!
private ArrayList<Zutat> filter; private ArrayList<Zutat> filter;
// endregion // endregion
@ -37,6 +40,14 @@ public class Kind {
this.id = id; this.id = id;
} }
public int getBid() {
return bid;
}
public void setBid(int bid) {
this.bid = bid;
}
// TODO Zutat implementieren! // TODO Zutat implementieren!
public ArrayList<Zutat> getFilter() { public ArrayList<Zutat> getFilter() {
@ -49,10 +60,12 @@ public class Kind {
// endregion // endregion
// region Konstruktoren // region Konstruktoren
public Kind(String name, String vorname) { public Kind(String name, String vorname, int bid) {
this.name = name; this.name = name;
this.vorname = vorname; this.vorname = vorname;
this.bid = bid;
} }
// endregion // endregion

View File

@ -1,9 +1,3 @@
/**
* @author Samuel Wolff
* noch nicht getestet
* TODO FERTIG MACHEN
*/
package RestAPISchnittstelle; package RestAPISchnittstelle;
import java.net.URI; import java.net.URI;
@ -11,22 +5,38 @@ import java.net.http.HttpClient;
import java.net.http.HttpRequest; import java.net.http.HttpRequest;
import java.net.http.HttpResponse; import java.net.http.HttpResponse;
import java.nio.charset.StandardCharsets; import java.nio.charset.StandardCharsets;
import java.nio.file.WatchEvent;
import Logik.Kind;
import com.google.gson.Gson;
/**
* noch nicht getestet
* TODO FERTIG MACHEN
* @author Samuel Wolff
*/
public class RestApiClient implements IRestAPI{ public class RestApiClient implements IRestAPI{
private final String urlBase = "https://pbg2h22awo.web.pb.bib.de/VPR_Schnittstelle/VPR_Schnittstelle/restAPI.php"; private final String urlBase = "https://pbg2h22awo.web.pb.bib.de/VPR_Schnittstelle/VPR_Schnittstelle/restAPI.php";
private final HttpClient client; private final HttpClient client;
private final Gson gson;
public RestApiClient(){ public RestApiClient(){
client = HttpClient.newHttpClient(); client = HttpClient.newHttpClient();
gson = new Gson();
} }
public static void main(String[] args){ public static void main(String[] args){
new RestApiClient().get("Kind", 2); Kind kind = new Kind("Klein", "Kevin", 2);
String json = new Gson().toJson(kind);
new RestApiClient().post("Kind", json);
} }
@ -46,9 +56,11 @@ public class RestApiClient implements IRestAPI{
// Send the request and get the response // Send the request and get the response
HttpResponse<String> httpResponse = client.send(httpRequest, HttpResponse.BodyHandlers.ofString()); HttpResponse<String> httpResponse = client.send(httpRequest, HttpResponse.BodyHandlers.ofString());
Kind test = gson.fromJson(httpResponse.body(), Kind.class);
// Print the response status code and body // Print the response status code and body
System.out.println("Status Code: " + httpResponse.statusCode()); System.out.println("Status Code: " + httpResponse.statusCode());
System.out.println("Response Body: " + httpResponse.body()); System.out.println("Response Body: " + test.getName());
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); e.printStackTrace();
} }
@ -71,9 +83,14 @@ public class RestApiClient implements IRestAPI{
// Send the request and get the response // Send the request and get the response
HttpResponse<String> httpResponse = client.send(httpRequest, HttpResponse.BodyHandlers.ofString()); HttpResponse<String> httpResponse = client.send(httpRequest, HttpResponse.BodyHandlers.ofString());
Kind[] test = gson.fromJson(httpResponse.body(), Kind[].class);
// Print the response status code and body // Print the response status code and body
System.out.println("Status Code: " + httpResponse.statusCode()); System.out.println("Status Code: " + httpResponse.statusCode());
System.out.println("Response Body: " + httpResponse.body()); for(Kind i : test){
System.out.println(i.getVorname());
}
//System.out.println("Response Body: " + test);
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); e.printStackTrace();
} }
@ -137,7 +154,26 @@ public class RestApiClient implements IRestAPI{
*/ */
@Override @Override
public void post(String controllerName, String jsonData) { public void post(String controllerName, String jsonData) {
URI apiUri = URI.create(String.format("%s/%s", urlBase,controllerName));
System.out.println(apiUri);
HttpRequest httpRequest = HttpRequest.newBuilder()
.uri(apiUri)
.header("Content-Type", "application/json")
.POST(HttpRequest.BodyPublishers.ofString(jsonData, StandardCharsets.UTF_8))
.build();
try {
// Send the request and get the response
HttpResponse<String> httpResponse = client.send(httpRequest, HttpResponse.BodyHandlers.ofString());
// Print the response status code and body
System.out.println("Status Code: " + httpResponse.statusCode());
System.out.println("Response Body: " + httpResponse.body());
} catch (Exception e) {
e.printStackTrace();
}
} }
/** /**

View File

@ -2,8 +2,10 @@ module de.subway_surfers.vpr_app {
requires javafx.controls; requires javafx.controls;
requires javafx.fxml; requires javafx.fxml;
requires java.net.http; requires java.net.http;
requires com.google.gson;
opens de.subway_surfers.vpr_app to javafx.fxml; opens de.subway_surfers.vpr_app to javafx.fxml, com.google.gson;
opens Logik to com.google.gson;
exports de.subway_surfers.vpr_app; exports de.subway_surfers.vpr_app;
} }