我正在尝试连接到通过POST
请求提供一些客户数据的Web服务,但是响应在中间被切断(或者触发函数可能没有等待响应完成) )。
这是在不稳定的环境中完成的,initState()
触发了请求。
我有一个data service
供客户使用,CustomerDataService
扩展了DataService
,其中包含一些常见的内容,例如发送请求等。
因此,简而言之,initState()
调用CustomerDataService.getCustomers(request)
,而后者依次调用并等待DataService.post(endpoint, request)
。
Http包:import 'package:http/http.dart' as http;
initState()
这是起点:
final CustomerDataService _dataService =
new CustomerDataServiceProvider().getCustomerDataService();
@override
void initState() {
_getCustomers();
super.initState();
}
void _getActors() async {
_dataService.getCustomers(
request: new GetCustomersRequest(
navigations: _dataService.suggestedNavigations
),
).then((response) {
_customersResponse = response;
/// Set the state
refresh();
});
}
然后我们有CustomerDataService
:
class _CustomerDataService extends DataService implements CustomerDataService
@override
Future<GetCustomersResponse> getCustomers(
{@required GetCustomersRequest request}) async {
String endpoint = createEndpoint(<String>[
App.appContext.identityInstance.rootUrl,
_CUSTOMERS_CONTROLLER,
_GET_CUSTOMERS_ENDPOINT
]);
http.Response res = await post(endpoint: endpoint, request: request.toJson());
if (res.body == null) {
return null;
}
try {
/// This prints an invalid JSON that is cut in the middle
print(res.body);
/// This one naturally throws an exception since res.body isn't valid.
dynamic json = jsonDecode(res.body);
return new GetCustomersResponse.fromJson(json);
} catch (e) {
print("Exception caught when trying to get customers");
print(e);
}
return null;
}
jsonDecode的异常是
状态错误:无元素
然后我们有DataService
:
Future<http.Response> post(
{@required String endpoint,
Map<String, String> header,
Map<String, dynamic> request}) async {
if (header == null) {
header = _getHeader();
} else {
header.putIfAbsent(_AUTHORIZATION_KEY, () => _headerAuthorizationValue());
}
http.Response res = await http.post(Uri.parse(endpoint), headers: header);
_validateReponse(res);
return res;
}
我显然做错了,但看不到...
DataService.post中的请求未在此代码中添加正文(request
参数),这是我将对其进行更多研究后将提交的另一张票据,目前的解决方法是更改服务不期望有身体。
我已验证该服务在邮递员中的行为与预期相同。
我希望有人可以看到我的错误在哪里。
谢谢!
编辑1:
我稍微更改了代码,以使initState()
不使用我创建的DataService,而是直接使用http程序包。
http.post('http://localhost:50140/api/customer/getcustomers').then((res) {
if(res == null) {
print('Response is empty');
}
print('Status code ${res.statusCode}');
print(res.body);
});
super.initState();
}
发生了完全相同的事情,因此我认为这至少不是由于数据服务引起的。
修改2: 在有人深入研究之前,我只想说这似乎不是来自服务,http包或dataservices的响应。
我发现Bad state: no element
异常的原因后,就会立即更新此 blog 。
答案 0 :(得分:0)
好的,我不知道该怎么做,但事实证明问题标题不正确。
是终端,当文本太大时会剪切文本...
在dataservices
或http package
中没有错误,但是在从响应主体到我的强类型模型的转换中,在模型树的深处都没有错误。
“客户”模型的关联属性有一个服务器端和客户端两个枚举。
该服务使用索引序列化枚举,我用于映射的库尝试按名称获取枚举(区分大小写)。
有问题的实体
@JsonSerializable()
class Item extends Object with _$ItemSerializerMixin
自动生成的映射
json['itemType'] == null
? null
: /// I could probably just remove the singleWhere and add [(int)json['itemType']] instead but that would cause some hassle when I run build_runner again.
ItemType.values
.singleWhere((x) => x.toString() == "ItemType.${json['itemType']}")
因此,一旦我在服务器端进行了一些更改(忽略枚举的序列化并添加了另一个返回枚举字符串值(以小写形式)的属性),它便开始工作。我想进一步研究这个问题,以便我可以序列化枚举索引而不是字符串值,并以这种方式映射它,但是不幸的是,我现在没有时间这样做。
用于自动映射的软件包为build_runner
和json_serializable
。
我很高兴找到了一个解决方案,但很抱歉,该解决方案与实际帖子完全无关。我希望这至少可以帮助某人。