gpt4 book ai didi

java - 将 Angular JS 中的数据作为表单数据发布到 Java REST Web 服务时出现问题

转载 作者:行者123 更新时间:2023-11-30 11:06:28 25 4
gpt4 key购买 nike

我正在尝试在 Java 中创建一个 Web 服务,它接受两个列表作为 FormData 参数。

我使用了 this answer 中提到的 Angualr JS http 服务.

var queryRequest = $http({
method:'POST',
url:'services/test/testPath',
data:$.param({"listA":myList1,"listB":myList2}),
headers: {'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8'}
});

我的对象myList1

var myList1=[];
var obj={};
obj["val1"]=1
obj["val2"]=2
myList1.push(obj);

我的对象myList2

var myList2=[];

var obj={};
obj["val11"]=3
obj["val12"]=4
myList2.push(obj);

var obj={};
obj["val11"]=5
obj["val12"]=6
myList2.push(obj);

我正在使用 javax.ws.rs.* 作为其余服务

我接受数据的 Java 服务器端点是-

@Path("testPath")
@POST
@Consumes("application/x-www-form-urlencoded;charset=UTF-8")
@Produces("application/json")
public DataDTO addIssuancesForFP(@FormParam("listA") List<TypeA> list1, @FormParam("listB") List<TypeB> list2) {

System.out.println("Service is called correctly");
return service.getDTO(list1,list2);
}

我的类(class)“TypeA”

 private Integer val1;
private Integer val2;
//getters and setters, and default constructor

我的类(class)'TypeB'

 private Integer val11;
private Integer val12;
//getters and setters, and default constructor

端点正确命中,但我在两个列表中都得到了 null。请求结构为:

Request Type

    Accept:application/json, text/plain, */*
Content-Type:application/x-www-form-urlencoded;charset=UTF-8

Form Data

    listA[0][val1]:1
listA[0][val2]:2

listB[0][val11]:3
listB[0][val12]:4
listB[1][val11]:5
listB[1][val12]:6

似乎是正确的,我认为错误在服务器部分。如何解决?

谢谢

注意:这只是模拟数据,格式完全相同

最佳答案

是的,所以我认为使用表单编码数据行不通。原因是它主要针对键值对,形式为

key1=value7&key2=value2&key3=value3...

您所做的只是使用两个键,listAlistB。所以想象一下这些值需要是什么样子才能发送整个列表。它不漂亮。对于复杂的数据,以 JSON 等格式发送数据更为可行。对于您的特定用例,问题在于需要发送两个不相关的对象(或数组)。为此,解决方案是使用 multipart。你很幸运,因为我刚刚发布了 late answer昨天,关于如何使用 Angular 处理这个问题。

我不会在这里对代码进行解释。一切都在该链接中进行了解释。请在阅读此答案时通读它。我将像 JAX-RS 实现一样使用 Jersey(就像链接中的示例一样 - 但它也提供其他替代实现)

资源

import java.util.List;
import javax.ws.rs.Consumes;
import javax.ws.rs.POST;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import org.glassfish.jersey.media.multipart.FormDataParam;

@Path("/form")
public class FormResource {

@POST
@Consumes("multipart/form-data")
@Produces("text/plain")
public String addIssuancesForFP(@FormDataParam("listA") List<TypeA> list1,
@FormDataParam("listB") List<TypeB> list2) {

StringBuilder response = new StringBuilder();
for(TypeA a: list1) {
response.append(a.toString()).append("; ");
}

for (TypeB b: list2) {
response.append(b.toString()).append("; ");
}

System.out.println("Service is called correctly");
return response.toString();
}
}

有 Angular 的

<!DOCTYPE html>
<html ng-app="formApp">
<head>
<title>TODO supply a title</title>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<script src="js/libs/jquery/jquery.js"></script>
<script src="js/libs/angular.js/angular.js"></script>
<script>
angular.module("formApp", [])
.controller("defaultCtrl", function($scope, $http) {
$scope.sendData = function() {
var myList1 = [];
var obj = {};
obj["val1"] = "value1";
obj["val2"] = "value2";
myList1.push(obj);

var myList2 = [];

var obj = {};
obj["val11"] = "value11";
obj["val12"] = "value12";
myList2.push(obj);

var obj = {};
obj["val11"] = "value211";
obj["val12"] = "value212";
myList2.push(obj);

var list1 = JSON.stringify(myList1);
var list2 = JSON.stringify(myList2);

var boundary = Math.random().toString().substr(2);
var header = "multipart/form-data; charset=utf-8; boundary=" + boundary;

$http({
url: "/api/form",
headers: {"Content-Type": header},
data: createRequest(list1, list2, boundary),
method: "POST"
}).then(function(response) {
$scope.result = response.data;
});

function createRequest(list1, list2, boundary) {
var multipart = "";
multipart += "--" + boundary
+ "\r\nContent-Disposition: form-data; name=listA"
+ "\r\nContent-type: application/json"
+ "\r\n\r\n" + list1 + "\r\n";
multipart += "--" + boundary
+ "\r\nContent-Disposition: form-data; name=listB"
+ "\r\nContent-type: application/json"
+ "\r\n\r\n" + list2 + "\r\n";
multipart += "--" + boundary + "--\r\n";
return multipart;
}
};
});
</script>
</head>
<body>
<div ng-controller="defaultCtrl">
<button ng-click="sendData()">Send</button>
<p>{{result}}
</div>
</body>
</html>

结果

TypeA{val1=value1, val2=value2}; 
TypeB{val1=value11, val2=value12};
TypeB{val1=value211, val2=value212};

这是预期的,因为我刚刚从 toString() 方法构建了一个字符串,我在 TypeATypeB 类中实现了该方法.

public class TypeA {
public String val1;
public String val2;
@Override
public String toString() {
return "TypeA{" + "val1=" + val1 + ", val2=" + val2 + '}';
}
}

public class TypeB {
public String val11;
public String val12;
@Override
public String toString() {
return "TypeB{" + "val1=" + val11 + ", val2=" + val12 + '}';
}
}

希望这对您有所帮助。

关于java - 将 Angular JS 中的数据作为表单数据发布到 Java REST Web 服务时出现问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29297197/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com