首页 > 解决方案 > 如何将查询参数添加到 Dart http 请求中?

问题描述

如何正确地将查询参数添加到 Dart http get 请求中?尝试将 '?param1=one¶m2=two' 附加到我的网址时,我无法让我的请求正确响应,但它在 Postman 中正常工作。这是我的代码的要点:

    final String url = "https://www.myurl.com/api/v1/test/";
    String workingStringInPostman = "https://www.myurl.com/api/v1/test/123/?param1=one&param2=two";

    Map<String, String> qParams = {
     'param1': 'one',
     'param2': 'two',
    };


   var res = await http
      .get(Uri.encodeFull("$url${widget.pk}/"),
      headers: {HttpHeaders.authorizationHeader: "Token $token", 
        HttpHeaders.contentTypeHeader: "application/json"},
);

${widget.pk} 只是一个被传递的整数值(参见 workingStringInPostman 变量中的值 123。

qParams 是为了方便,以防需要 Uri 参数。

欢迎提供代码示例。

标签: httpgetdartflutterurl-parameters

解决方案


您将要构造 aUri并将其用于请求。就像是

final queryParameters = {
  'param1': 'one',
  'param2': 'two',
};
final uri =
    Uri.https('www.myurl.com', '/api/v1/test/${widget.pk}', queryParameters);
final response = await http.get(uri, headers: {
  HttpHeaders.authorizationHeader: 'Token $token',
  HttpHeaders.contentTypeHeader: 'application/json',
});

https://api.dartlang.org/stable/2.0.0/dart-core/Uri/Uri.https.html


推荐阅读