ajax传递参数中带“#”时,数据丢失问题解决

问题:

在使用jQuery的ajax进行参数传递时,因为其中一个参数的值含有#,导致#号后面的参数丢失。

问题代码:

$.ajax({
        type: "post",
        contentType: false,
        processData: false,
        url: " save/saveData?id=" + id + "&headNum=" + headNum + "&selectedfileTitles=" + encodeURI(encodeURI(keys)),
        dataType: "json",
        success: function (data) {
            // console.log("数据提交后返回:", data);
           
        }
        
    });

原因:

使用ajax向后台提交的时候 由于参数中含有#  默认会被截断 只保留#之前的字符  json格式的字符串则不会被请求到后台的action

可以使用encodeURIComponent在前台进行编码,

java后端接收后  data= java.net.URLDecoder.decode(selectedfileTitles, "UTF-8");进行解码

修改后代码:

$.ajax({
        type: "post",
        contentType: false,
        processData: false,
        url: " save/saveData?id=" + id + "&headNum=" + headNum + "&selectedfileTitles=" + encodeURIComponent(encodeURIComponent(keys)),
        dataType: "json",
        success: function (data) {
            // console.log("数据提交后返回:", data);
           
        }
        
    });

这样就可以保证参数不会被#截断了。

这里需要注意的是encodeURIComponent(encodeURIComponent(keys))。这里是有encodeURIComponent两次编码的,

为什么要两次编码的原因:后台java代码给searchtext赋值的时候,本身已经使用了一次解码,不过解码的结果依然不对。所以我们可以在页 面上进行两次编码操作,这样后台自动的那次就可以抵消掉一次,然后在使用 searchtext=java.net.URLDecoder.decode(searchtext,"UTF-8");进行一次解码就好了。


另外附上js编码解码的几种方法(参考w3school:  http://www.w3school.com.cn/jsref/jsref_obj_global.asp):

编码函数 escape  encodeURI  encodeURIComponent  对应解码函数  unescape  decodeURI  decodeURIComponent

escape():

采用unicode字符集对指定的字符串除0-255以外进行编码。所有的空格符、标点符号、特殊字符以及更多有联系非ASCII字符都将被转化成%xx格式的字符编码(xx等于该字符在字符集表里面的编码的16进制数字) 
比如: 空格符对应的编码是%20。

该方法不会对 ASCII 字母和数字进行编码(0-9,a-z,A-Z),也不会对下面这些 ASCII 标点符号进行编码: * @ - _ + . / 。其他所有的字符都会被转义序列替换。

也就是说escape不编码字符有69个:*,+,-,.,/,@,_,0-9,a-z,A-Z

encodeURI():

采用UTF-8编码格式把字符串作为 URI 进行编码。 该方法不会对 ASCII 字母和数字进行编码(0-9,a-z,A-Z),也不会对这些 ASCII 标点符号进行编码: - _ . ! ~ * ' ( )

该方法的目的是对 URI 进行完整的编码,因此对以下在 URI 中具有特殊含义的 ASCII 标点符号,encodeURI() 函数是不会进行转义的:;/?:@&=+$,#

也就是说encodeURI不编码字符有82个:!,#,$,&,',(,),*,+,,,-,.,/,:,;,=,?,@,_,~,0-9,a-z,A-Z

提示:如果 URI 组件中含有分隔符,比如 ? 和 #,则应当使用 encodeURIComponent() 方法分别对各组件进行编码。

encodeURIComponent() :

采用UTF-8编码格式把字符串作为 URI 组件进行编码。

该方法不会对 ASCII 字母和数字进行编码(0-9,a-z,A-Z),也不会对这些 ASCII 标点符号进行编码: - _ . ! ~ * ' ( )

其他字符(比如 :;/?:@&=+$,# 这些用于分隔 URI 组件的标点符号),都是由一个或多个十六进制的转义序列替换的。

也就是说encodeURIComponent不编码字符有71个:!, ',(,),*,-,.,_,~,0-9,a-z,A-Z

提示:请注意 encodeURIComponent() 函数 与 encodeURI() 函数的区别之处,前者假定它的参数是 URI 的一部分(比如协议、主机名、路径或查询字符串)。因此 encodeURIComponent() 函数将转义用于分隔 URI 各个部分的标点符号。

注意: encodeURI和encodeURIComponent会把字符串编码成UTF-8的格式。

总结:

1 传递参数时 使用 encodeURIComponent
2 进行url跳转时可以整体使用encodeURI
3 js使用数据时使用escape

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值