来自http发布请求的响应在中间被削减

时间:2018-08-03 07:05:49

标签: http dart flutter

我正在尝试连接到通过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

1 个答案:

答案 0 :(得分:0)

好的,我不知道该怎么做,但事实证明问题标题不正确。

是终端,当文本太大时会剪切文本...

dataserviceshttp 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_runnerjson_serializable

我很高兴找到了一个解决方案,但很抱歉,该解决方案与实际帖子完全无关。我希望这至少可以帮助某人。