`

JavaScript 直接使用get方式提交存在特殊字符【例如加号】的解决方法

阅读更多

最近开发时碰到这样的问题,在一个项目中查询字符“C++规范”时尽然查询不出结果。

当时一碰到问题还以为是代码问题,就一行行的echo【php语言】发现js提交过来的C++竟然变成呢C。上网找资料有三种解决方案

1 、改用 p ost 方法  

2 、在 js 对相应字段进行编码 ,后台再解码一次

3 、将参数里的加号进行转换

      data = data.replace(/\+/g, "%2B");

   //data = data.replace(/\&/g, "%26")

页面编码流程如下gb2312->gb2312

我采用的为第二种方法。

先将URL中可能存在值进行编码为uft8而不使用整个URL编码,编码函数为encodeURIComponent()

例如xxx.php?name=encodeURIComponent( xxx );

后台解码将utf8转换为gbk

$name = iconv("UTF-8", "GB2312", $name);

 

附录JavaScript三中URL编码方式(escape(),encodeURI(),以及encodeURIComponent())

escape() 方法:

采用ISO Latin字符集对指定的字符串进行编码。所有的空格符、标点符号、特殊字符以及其他非ASCII字符都将被转化成%xx格式的字符编码(

xx等于该字符在字符集表里面的编码的16进制数字)。比如,空格符对应的编码是%20。

不会被此方法编码的字符: @ * / +

encodeURI() 方法:

把URI字符串采用UTF-8编码格式转化成escape格式的字符串。

不会被此方法编码的字符:! @ # $& * ( ) = : / ; ? + '

encodeURIComponent() 方法:

把URI字符串采用UTF-8编码格式转化成escape格式的字符串。与encodeURI()相比,这个方法将对更多的字符进行编码,比如 / 等字符。所以

如果字符串里面包含了URI的几个部分的话,不能用这个方法来进行编码,否则 / 字符被编码之后URL将显示错误。

不会被此方法编码的字符:! * ( ) '

因此,对于中文字符串来说,如果不希望把字符串编码格式转化成UTF-8格式的(比如原页面和目标页面的charset是一致的时候),只需要使用 escape。如果你的页面是GB2312或者其他的编码,而接受参数的页面是UTF-8编码的,就要采用encodeURI或者 encodeURIComponent。

 

 

分享到:
评论
1 楼 zhuzhuaijq 2011-09-22  
学习了!~!!!

相关推荐

    js的form表单提交url传参数(包含+等特殊字符)的两种解决方法

    这篇文章将介绍两种在JavaScript中处理表单提交时URL参数包含特殊字符(如"+")的解决方法。 首先,需要了解在URL中常用的特殊字符及其编码形式,这是因为这些字符如果直接出现在URL参数中,可能会被浏览器误解为...

    GET 方式提交的含有特殊字符的参数

    在Web开发中,GET请求是HTTP协议中一种常见的数据提交方式,它通过URL来传递参数。然而,当这些参数包含特殊字符时,可能会引发解析问题,导致服务器无法正确解析请求。本文将深入探讨如何处理GET方式提交的含有特殊...

    URL的参数中有加号传值变为空格的问题(URL特殊字符)

    3. **方法三**:在服务器端,不直接使用`request.getParameter()`获取参数,而是先获取整个查询字符串(`request.getQueryString()`),然后自行解析。这适用于更复杂的场景,需要手动解析URL以处理所有可能的编码...

    完美解决js传递参数中加号和&号自动改变的方法

    在JavaScript中,当我们使用GET方法传递参数时,可能会遇到加号"+"和"&"字符被自动转换的问题。这是因为HTTP协议在解析URL时,会对特定字符进行编码,以避免它们与URL的结构产生冲突。"+"通常会被解析为空格,"&"则...

    Javascript考试题目选择题.docx

    8. 字符串拼接:JavaScript中,使用加号`+`可以进行字符串拼接,但不会自动进行计算。所以B选项`"a1+a2=" + a1 + a2`会显示`"a1+a2=1020"`。 9. 字符串转换:要将字符串中的所有字母转为小写,应该使用`toLowerCase...

    js的base64和base32加密函数

    在本文中,我们将深入探讨这两种编码方法以及如何在JavaScript中实现它们,同时解决在Ajax请求中传递包含特殊字符或中文参数时可能出现的乱码问题。 首先,让我们了解Base64和Base32的基本概念: 1. **Base64**:...

    JS中三种编码方式(escape,encodeURI,encodeURIComponent)

    最后,`encodeURIComponent()` 方法比`encodeURI()` 更加严格,它会编码更多字符,包括所有的标点符号和保留字符。这意味着`encodeURIComponent()` 可以用于编码URL中的查询字符串部分,确保每个字符都安全地转换为...

    解决ASP.NET中的各种乱码问题总结

    传统的做法是使用JavaScript的escape()函数对特殊字符进行编码。但这种方法存在局限性,如例子中提到的加号丢失的问题。解决此问题的一个好办法是使用JQuery的$.param()函数进行数据编码。它不仅编码方式更符合标准...

    Javascript 获取链接(url)参数的方法[正则与截取字符串]

    如果不存在参数,函数将直接返回空字符串。接着,它获取URL参数部分,即问号后面的所有内容。然后,通过“&”符号将参数对拆分成数组。接下来,遍历这个参数数组,找到与指定名称匹配的参数,将等号右侧的值提取出来...

    jq的get传参数在utf-8中乱码问题的解决php版

    标题中的“jq的get传参数在utf-8中乱码问题的解决php版”涉及到的是JavaScript的jQuery库(jq)通过GET方式发送请求时,遇到的URL编码与UTF-8字符集不兼容导致的乱码问题,以及如何在后端使用PHP来处理这个问题。...

    jQuery实现随机数字字母验证码插件特效源码.zip

    在JavaScript中,可以使用加号(+)将多个字符串连接起来。 3. **DOM操作**:jQuery库提供了一系列方便的API来操作DOM元素,如`$()`用于选择元素,`.html()`用于设置或获取元素的HTML内容,`.append()`或`.prepend()`...

    Base64算法完整源码与调用方法

    如上所述,Python使用`base64.b64encode()`和`base64.b64decode()`,Java使用`Base64.getEncoder().encode()`和`Base64.getDecoder().decode()`,JavaScript使用全局函数`btoa()`和`atob()`。在C#中,可以使用`...

    JavaScript正则表达式(总结篇)

    在表单验证方面,可以直接使用JavaScript的正则表达式对象的`test()`方法来检查一个字符串是否符合某规则,或者使用`exec()`方法来进行更详细的检查。 最后,文章中还提到了如何限制输入框只接受数字和英文字符的...

    js实现计算器功能

    根据给定文件的内容,我们可以了解到如何使用JavaScript(js)实现一个简单的计算器功能。下面详细阐述相关的知识点。 首先,关于JavaScript中的eval()函数,这个函数允许我们计算一个字符串表达式,并执行其中的...

    关于axios返回空对象的问题解决

    为了解决这个问题,正确的做法是使用逗号 (,) 而不是加号 (+) 来分隔字符串和对象,以便在控制台中正确显示对象内容。这样,`console.log("返回的数据是:", res.data)` 将会分别打印出文本和对象,而不是尝试将它们...

    一点平常工作下积累的小知识点

    例如,将逗号分隔的字符串切割成数组,然后遍历每个元素并再次切割加号分隔的部分。 11. **动态添加DOM元素**: `addInputFile`函数演示了如何使用JavaScript动态创建`input`元素并将其插入到指定的`div`下。 12....

Global site tag (gtag.js) - Google Analytics