URL 中出现两个问号会导致一些问题,主要取决于第二个问号的位置。
情况一:第二个问号在片段标识符(fragment identifier)中
如果第二个问号出现在#
后面,也就是片段标识符部分,则不会有任何问题。片段标识符用于指定页面中的特定位置,其内容由浏览器自行处理,并不会发送到服务器。因此,第二个问号会被视为片段标识符的一部分。
例如:https://www.example.com/page?param1=value1#section?param2=value2
在这个例子中,param2=value2
会被视为片段标识符的一部分,不会影响 URL 的其他部分。
情况二:第二个问号在查询字符串(query string)中
如果第二个问号出现在查询字符串中(?
和#
之间,或者 URL 末尾),则第二个问号及其之后的内容会被大多数服务器和客户端视为 URL 的一部分,但其解释方式取决于具体的服务器和客户端实现。
-
一些服务器/客户端可能会忽略第二个问号及其之后的内容。 它们可能只识别第一个问号和它后面的键值对。
-
一些服务器/客户端可能会将第二个问号及其之后的内容视为查询字符串的一部分,但不会将其解析为键值对。 例如,它们可能会将整个字符串
?param1=value1?param2=value2
视为一个键,其值为空。 -
一些服务器/客户端可能会将第二个问号编码为
%3F
。 这在某些情况下可以避免歧义。
使用 JavaScript 获取 URL 参数时的影响
使用 JavaScript 获取 URL 参数时,如果 URL 中存在两个问号(在查询字符串部分),可能会导致一些问题:
-
URLSearchParams
API:URLSearchParams
API 通常会正确处理第一个问号及其后的参数,但可能会忽略或错误解释第二个问号后的内容。 最好先对 URL 进行处理,例如,只保留第一个问号及其后的部分,或者将第二个问号编码为%3F
。 -
location.search
:location.search
属性返回查询字符串部分(包括第一个问号)。 你需要自己解析这个字符串来获取参数值,并且需要处理第二个问号的情况,例如使用正则表达式或字符串分割。
最佳实践
为了避免歧义和潜在的问题,最好避免在 URL 的查询字符串部分使用两个问号。如果需要传递多个参数,请使用 &
符号连接它们:
https://www.example.com/page?param1=value1¶m2=value2
示例代码 (JavaScript):
const url = new URL('https://www.example.com/page?param1=value1¶m2=value2?param3=value3');
const params = new URLSearchParams(url.search);
console.log(params.get('param1')); // Output: value1
console.log(params.get('param2')); // Output: value2
console.log(params.get('param3')); // Output: null (or undefined, depending on the browser)
const url2 = 'https://www.example.com/page?param1=value1?param2=value2';
const params2 = new URLSearchParams(url2.substring(url2.indexOf('?') + 1)); //手动截取
console.log(params2.get('param1')); // value1 (可能会根据浏览器实现不同)
console.log(params2.getAll('param1')); // 可能包含 value1?param2=value2,取决于浏览器如何处理
console.log(params2.get('param2')); // null (或 undefined,或 value2,取决于浏览器)
// 更健壮的解析方法 (使用正则表达式):
function getQueryParams(url) {
const params = {};
const regex = /[?&]([^=#]+)=([^&#]*)/g;
let match;
while ((match = regex.exec(url))) {
params[decodeURIComponent(match[1])] = decodeURIComponent(match[2]);
}
return params;
}
const params3 = getQueryParams(url2);
console.log(params3.param1); // value1
console.log(params3.param2); // undefined (因为正则表达式只匹配第一个问号后的参数)
总之,虽然在片段标识符中使用第二个问号不会造成问题,但在查询字符串中使用它可能会导致意外行为。为了确保代码的可靠性和可预测性,最好避免在查询字符串中使用多个问号,并使用标准的 URL 编码方法。
标签:value2,url,param1,URL,js,获取,param2,value1,问号 From: https://www.cnblogs.com/ai888/p/18604157