URL中传参带有等特殊字

用URL传参带特殊字符,特殊字符丢失,比如传参的时候,用&符号连接,如果其中的一个参数中含有 # $ ^ & * + - 这些符号的时候,在另一个页面getParameter就会取不到穿过来的参数。

比如在a.jsp中,我要跳转到b.jsp,在a.jsp中这样写:
b.jsp?Parameter1=wks&Parameter2=happycosn。
如果Parameter1中含有"#$ ^ & * + =“这些特殊字符,在b.jsp中就得不到。并且,我在a.jsp中已经通过encode编码了,
在b.jsp中也用decode 进行了解码。这时候,只要
所传入的参数没有特殊字符都可以在b.jsp页面取到,但是有特殊字符就取不到了。 像这样:
b.jsp?Parameter1=wks#bamboo&Parameter2=happycosn+#zl
这时候,所取到的参数就不会有bamboo和zl。
解决问题如下:
有些符号在URL中是不能直接传递的,如果要在URL中传递这些特殊符号,那么就要使用他们的编码了。
编码的格式为:%加字符的ASCII码,即一个百分号%,后面跟对应字符的ASCII(16进制)码值。例如 空格的编码值是”%20"。
如果不使用转义字符,这些编码就会当URL中定义的特殊字符处理。
下表中列出了一些URL特殊符号及编码 十六进制值
1.+ URL 中+号表示空格 %2B
2.空格 URL中的空格可以用+号或者编码 %20
3./ 分隔目录和子目录 %2F
4.? 分隔实际的 URL 和参数 %3F
5.% 指定特殊字符 %25
6.# 表示书签 %23
7.& URL 中指定的参数间的分隔符 %26
8.= URL 中指定参数的值 %3D

### 解析 URL 查询符串 为了实现 `parseQueryString` 函数来解析 URL 中的查询符串并将其转换为 JavaScript 对象,可以遵循以下逻辑: 当遇到查询符串时,会先判断是否存在问号(?),这标志着查询符串的开始[^1]。接着通过解码和分割操作处理这些参数。 对于给定的 URL 查询符串部分,可以通过如下方式构建一个能够解析其参数的方法: ```javascript function parseQueryString(queryString) { const queryObj = {}; // 去除开头可能存在的'?' queryString =queryString.charAt(0) === '?' ? queryString.slice(1): queryString; // 使用'&'拆分各个键对 const pairs = queryString.split('&'); for (let pair of pairs) { let [key, value] = pair.split('='); if(key){ key = decodeURIComponent(key); // 处理特殊符 if(value !== undefined && value!==null){ value = decodeURIComponent(value); // 处理特殊符 // 如果已经存在相同键,则转为数组存储多个 if (!queryObj[key]) { queryObj[key] = value; } else if(Array.isArray(queryObj[key])){ queryObj[key].push(value); } else{ queryObj[key]=[queryObj[key],value]; } } } } return queryObj; } ``` 上述代码考虑到了重复键的情况,并能妥善处理它们;同时也支持对带有百分号编码(%xx形式) 的特殊符进行正确解读[^2]。 此外,在实际应用中还需要注意一些细节问题,比如某些浏览器可能会自动去掉哈希(#)之后的内容而不发送至服务器端,所以在开发过程中应当测试不同环境下的行为差异。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值