ChatGPT解决这个技术问题 Extra ChatGPT

如何在查询字符串中传递数组?

是否有通过查询字符串传递数组的标准方法?

需要明确的是,我有一个包含多个值的查询字符串,其中一个是数组值。我希望将该查询字符串值视为一个数组 - 我不希望该数组被分解,使其与其他查询字符串变量无法区分。

此外,根据此post answer,作者建议未定义对数组的查询字符串支持。这是准确的吗?

编辑:

根据@Alex的回答,没有标准的方法可以做到这一点,所以我的后续行动是一种简单的方法来识别我正在读取的参数是PHP和Javascript中的数组?

将多个参数命名为相同的名称是否可以接受,这样我就会知道它们属于一个数组?例子:

?myarray=value1&myarray=value2&myarray=value3...

或者这是一个不好的做法?

你用的是什么框架?一些框架具有帮助将数组传递给查询字符串的方法。
@keyboardP- PHP 和 Javascript,取决于用例
当您可以这样做时,为什么要这样做:?myarray=value1,value2,value3
@seroids:如果他必须传递逗号、问号、等号和不可打印字符怎么办?

Y
Yarin

这是我发现的:

提交多值表单字段,即通过 GET/POST vars 提交数组,可以通过几种不同的方式完成,因为标准不一定要详细说明。

发送多值字段或数组的三种可能方法是:

?cars[]=Saab&cars[]=Audi (最好的方法——PHP 将它读入一个数组)

?cars=Saab&cars=Audi (不好的方式 - PHP 只会注册最后一个值)

?cars=Saab,Audi (没试过这个)

表单示例

在表单上,多值字段可以采用设置为多个的选择框的形式:

<form> 
    <select multiple="multiple" name="cars[]"> 
        <option>Volvo</option> 
        <option>Saab</option> 
        <option>Mercedes</option> 
    </select>
</form>

(注意:在这种情况下,将选择控件命名为 some_name[] 很重要,以便 PHP 将生成的请求变量注册为数组)

...或作为具有相同名称的多个隐藏字段:

<input type="hidden" name="cars[]" value="Volvo">
<input type="hidden" name="cars[]" value="Saab">
<input type="hidden" name="cars[]" value="Mercedes">

注意:field[] 用于多个值的记录确实很差。我在 Query string - Wikipedia 中的多值键部分或处理多选输入的 W3C docs 中没有看到任何提及。

更新

正如评论者所指出的,这在很大程度上是特定于框架的。一些例子:

请求参数:

?list_a=1&list_a=2&list_a=3&list_b[]=1&list_b[]=2&list_b[]=3&list_c=1,2,3

导轨:

"list_a": "3", 
"list_b":[
    "1",
    "2",
    "3"
  ], 
"list_c": "1,2,3"

角度:

 "list_a": [
    "1",
    "2",
    "3"
  ],
  "list_b[]": [
    "1",
    "2",
    "3"
  ],
  "list_c": "1,2,3"

(角度 discussion

有关 node.js、Wordpress、ASP.net 中的示例,请参见注释

维护顺序:要考虑的另一件事是,如果您需要维护项目的顺序(即数组作为有序列表),您实际上只有一个选项,即传递一个分隔的值列表,并将其显式转换为自己一个数组。


我认为此功能未在 Wiki 或 W3C 等一般资源中记录的原因是 Web 框架通常不支持它。 PHP 和我认为 Rails 会自动将多个“key[]”查询参数转换为一个数组。其他人没有。
nodejs 查询字符串模块使用 ?cars=Saab&cars=Audi 形式
在 express (node.js) 中,?cars=Saab&cars=Audi?cars[]=Saab&cars[]=Audi 都变成了数组。但是,?cars=Saab 以字符串形式结束,而 ?cars[]=Saab 是具有单个元素的数组。
您可以使用这种方法设置密钥吗?那么多维数组呢?
ASP.NET MVC 似乎没有读取格式 ?cars[]=Saab&cars[]=Audi 没有方括号或方括号需要索引/
A
Alex K.

查询字符串携带文本数据,因此别无选择,只能分解数组,正确编码并以您选择的表示格式传递:

p1=value1&pN=valueN...
data=[value1,...,valueN]
data={p1:value1,...,pN:valueN}

然后在您的服务器端代码中对其进行解码。


好的,谢谢你的澄清。您能看到我修改后的问题吗?是否有必要为键执行 p1...pn,或者我可以只将多个键命名为“p”,这样我就知道它们都属于同一个数组?
您可以使用相同的名称; stackoverflow.com/questions/2203430/… 或只是 p=aa,bb,cc 这是 Serodis 评论的最明显的方式。
JSON.stringifyJSON.parse 非常有用!
一种简单且常见的表示格式是 JSON,在 PHP 中使用 json_encode,然后在另一个页面上使用 rawurlencodejson_decode
C
Community

我认为没有标准。每个网络环境都为这些事情提供了自己的“标准”。此外,该 url 通常对于任何内容都太短(某些浏览器限制为 256 字节)。当然,可以使用 POST 请求发送更长的数组/数据。

但是,有一些方法:

有一种 PHP 方式,它在 URL 查询中使用方括号 ([,])。例如 ?array_name[]=item&array_name[]=item_2 之类的查询据说可以工作,尽管文档记录很差,PHP 会自动将其转换为数组。来源:https://stackoverflow.com/a/9547490/3787376 对象数据交换格式(例如 JSON - 官方网站,PHP 文档)也可以使用,如果它们具有像 JSON 那样在字符串之间转换变量的方法。 HTTP get 请求还需要一个 url 编码器(适用于大多数编程语言)才能正确编码字符串数据。

“方括号法”虽然简单有效,但仅限于 PHP 和数组。如果需要其他类型的变量,例如类或在非 PHP 语言的查询字符串中传递变量,则建议使用 JSON 方法。

JSON方法的PHP示例(方法2):

$myarray = array(2, 46, 34, "dfg");
$serialized = json_encode($myarray)
$data = 'myarray=' . rawurlencode($serialized);
// Send to page via cURL, header() or other service.

接收页面代码(PHP):

$myarray = json_decode($_GET["myarray"]); // Or $_POST["myarray"] if a post request.

Express.js 还支持方括号表示法,在 4.13.4 上进行了测试。
如果您要使用 json_encode,最好在将字符串作为 get 参数传递时对字符串进行 base64_encode 和解码
A
Alia Anis

这对我有用:

在链接中, to 属性具有值:

to="/filter/arr?fruits=apple&fruits=banana"

路线可以处理这个:

path="/filter/:arr"

对于多个数组:

to="filter/arr?fruits=apple&fruits=banana&vegetables=potato&vegetables=onion"

路线保持不变。

截屏

https://i.stack.imgur.com/ub7UM.png

更新:为了实现这种字符串结构,query-string 是最好的包。

例如:

import { stringify, parse } from 'query-string';

const queryParams={
   fruits:['apple','banana'],
   vegetables:['potato','onion']
}
//arrayFormat can be bracket or comma 
stringify(queryParams, { arrayFormat: 'bracket' });

J
João Haas

尽管 URL 部分没有标准,但 JavaScript 有一个标准。如果您将包含数组的对象传递给 URLSearchParams,并对其调用 toString(),它会将其转换为逗号分隔的项目列表:

let data = {
  str: 'abc',
  arr: ['abc', 123]
}

new URLSearchParams(data).toString();
// ?str=abc&arr=abc,123 (with escaped comma characters)

准确地说,它会产生转义结果:"str=abc&arr=abc%2C123"
事实上,我会更新代码以显示它。重点仍然相同,即 js 的“标准”在数组中使用逗号。
arr=abc&arra=123 相比,逗号分隔是否更好/兼容?
@DimitriKopriwa 猜你的意思是 arr=abc&arr=123。我想说 JS 做的稍微好一点,因为它使用更少的字符,前端代码会更简单,它会保持项目的顺序,但只要使用你的后端框架(django、PHP、laravel 等) ) 支持。如果我自己实现解析,我可能会采用逗号分隔的方法。
URLSearchParams 只接受字符串参数,不接受数组!任何非字符串都只是通过正常的 toString 行为自动转换为字符串。 JavaScript 通过使用逗号连接条目将数组转换为字符串这一事实不应被视为 JavaScript 在 URL 中编码数组数据的标准方式。这就是 JavaScript 在整个语言中将数组转换为字符串的简单方式。
v
vimal1083

我觉得这对于正在寻找将查询字符串中的数组传递给 servlet 的人会有所帮助。我在查询字符串下面进行了测试,并且能够使用 req.getgetParameterValues(); 获取数组值;方法。下面是我通过浏览器传递的查询字符串。

  http://localhost:8080/ServletsTutorials/*.html? 
  myname=abc&initial=xyz&checkbox=a&checkbox=b

复选框是我的参数数组。


W
Will59

请注意,查询字符串模块列出了它支持的不同类型的数组编码 (https://www.npmjs.com/package/query-string):

例如 {foo: ['1', '2', '3']} 可以编码为:

'foo[]=1&foo[]=2&foo[]=3'
'foo[0]=1&foo[1]=2&foo[3]=3'
'foo=1,2,3'
'foo=1&foo=2&foo=3'
// Any custom separator can be used:
'foo=1|2|3'
// ... and more custom formats

这表明那里采用了许多解决方案......


L
Lini

我使用 React 和 Rails。我做了:

js

  let params = {
    filter_array: ['A', 'B', 'C']
  }

  ...

  //transform params in URI

  Object.keys(params).map(key => {
    if (Array.isArray(params[key])) {
      return params[key].map((value) => `${key}[]=${value}`).join('&')
    }
  }
  //filter_array[]=A&filter_array[]=B&filter_array[]=C

C
Community

您在问题中提到了 PHP 和 Javascript,但在标签中没有提到。我遇到这个问题的目的是将数组传递给 MVC.Net 操作。

我找到了我的问题 here 的答案:预期格式是您在问题中提出的格式,多个参数具有相同的名称。


虽然此链接可能会回答问题,但最好在此处包含答案的基本部分并提供链接以供参考。如果链接页面发生更改,仅链接答案可能会失效。
@Andrew这不是仅链接的答案。 “预期的格式是您在问题中提出的格式,多个参数具有相同的名称。”
k
keyboardP

您可以使用 http_build_query 从 PHP 中的数组生成 URL 编码的查询字符串。虽然生成的查询字符串将被扩展,但您可以决定您想要的唯一分隔符作为 http_build_query 方法的参数,因此在解码时,您可以检查使用的分隔符。如果它是您选择的唯一一个,那么它将是数组查询字符串,否则它将是正常的查询字符串。


D
Dan Murfitt

检查 parse_string 函数 http://php.net/manual/en/function.parse-str.php

它将返回查询字符串中的所有变量,包括数组。

来自 php.net 的示例:

<?php
$str = "first=value&arr[]=foo+bar&arr[]=baz";
parse_str($str);
echo $first;  // value
echo $arr[0]; // foo bar
echo $arr[1]; // baz

parse_str($str, $output);
echo $output['first'];  // value
echo $output['arr'][0]; // foo bar
echo $output['arr'][1]; // baz

?>