url 特殊字符 传递参数解决方法


Posted in Javascript onJanuary 01, 2010

十六进制值
1. + URL 中+号表示空格 %2B
2. 空格 URL中的空格可以用+号或者编码 %20
3. / 分隔目录和子目录 %2F
4. ? 分隔实际的 URL 和参数 %3F
5. % 指定特殊字符 %25
6. # 表示书签 %23
7. & URL 中指定的参数间的分隔符 %26
8. = URL 中指定参数的值 %3D

解决的方法:
replace() 方法如果直接用str.replace("-","!") 只会替换第一个匹配的字符.
而str.replace(/\-/g,"!")则可以替换掉全部匹配的字符(g为全局标志)。
replace()
js中替换字符变量如下:

 data2=data2.replace(/\%/g,"%25");
 data2=data2.replace(/\#/g,"%23");
 data2=data2.replace(/\&/g,"%26");

其他一些资料。。。仅供参考。。。

在使用url进行参数传递时,经常会传递一些中文名(或含有特殊字符)的参数或URL地址,在后台处理时会发生转换错误。在有些传递页面使用GB2312,而在接收页面使用UTF8,这样接收到的参数就可能会与原来发生不一致。使用服务器端的urlEncode函数编码的URL,与使用客户端java的encodeURI函数编码的URL,结果就不一样。

java对文字进行编码涉及3个函数:escape,encodeURI,encodeURIComponent,相应3个解码函数:unescape,decodeURI,decodeURIComponent

java中的编码方法:
escape() 方法:采用ISO Latin字符集对指定的字符串进行编码。所有的空格符、标点符号、特殊字符以及其他非ASCII字符都将被转化成%xx格式的字符编码(xx等于该字符在字符集表里面的编码的16进制数字)。比如,空格符对应的编码是%20。unescape方法与此相反。不会被此方法编码的字符: @ * / +

encodeURI()方法:把URI字符串采用UTF-8编码格式转化成escape格式的字符串。不会被此方法编码的字符:! @ # $& * ( ) = : / ; ? + '

encodeURIComponent ()方法:把URI字符串采用UTF-8编码格式转化成escape格式的字符串。与encodeURI()相比,这个方法将对更多的字符进行编码,比如 / 等字符。所以如果字符串里面包含了URI的几个部分的话,不能用这个方法来进行编码,否则 / 字符被编码之后URL将显示错误。不会被此方法编码的字符:! * ( )

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

另外,encodeURI/encodeURIComponent是在java1.5之后引进的,escape则在java1.0版本就有。
1、  传递参数时需要使用encodeURIComponent,这样组合的url才不会被#等特殊字符截断。

   例如:< language="java">write('<a href="http://passport.baidu.com/?logout&aid=7&u='+encodeURIComponent("http://cang.baidu.com/bruce42")+'">退出</a>');</>

2、  进行url跳转时可以整体使用encodeURI

例如:Location.href=encodeURI("http://cang.baidu.com/do/s?word=百度&ct=21");

3、  js使用数据时可以使用escape

例如:搜藏中history纪录。

4、  escape对0-255以外的unicode值进行编码时输出%u****格式,其它情况下escape,encodeURI,encodeURIComponent编码结果相同。

最多使用的应为encodeURIComponent,它是将中文、韩文等特殊字符转换成utf-8格式的url编码,所以如果给后台传递参数需要使用encodeURIComponent时需要后台解码对utf-8支持(form中的编码方式和当前页面编码方式相同)

escape不编码字符有69个:*,+,-,.

Javascript 相关文章推荐
PageSwitch插件实现100种不同图片切换效果
Jul 28 Javascript
使用JQuery在线制作ppt并在线演示源码特效
Sep 08 Javascript
在JavaScript中call()与apply()区别
Jan 22 Javascript
JCrop+ajaxUpload 图像切割上传的实例代码
Jul 20 Javascript
Vue实现双向数据绑定
May 03 Javascript
Angular 4 指令快速入门教程
Jun 07 Javascript
jQuery Datatables表头不对齐的解决办法
Nov 27 jQuery
微信小程序判断页面是否从其他页面返回的实例代码
Jul 03 Javascript
微信小程序通过一个json实现分享朋友圈图片
Sep 03 Javascript
vue中使用element组件时事件想要传递其他参数的问题
Sep 18 Javascript
vue中使用WX-JSSDK的两种方法(推荐)
Jan 18 Javascript
Vue Element-ui表单校验规则实现
Jul 09 Vue.js
JavaScript 数组循环引起的思考
Jan 01 #Javascript
javascript eval和JSON之间的联系
Dec 31 #Javascript
js下用gb2312编码解码实现方法
Dec 31 #Javascript
JavaScript 学习笔记(七)字符串的连接
Dec 31 #Javascript
JavaScript 学习笔记(六)
Dec 31 #Javascript
JavaScript 学习笔记(五)
Dec 31 #Javascript
JavaScript 学习笔记(四)
Dec 31 #Javascript
You might like
如何在PHP中使用Oracle数据库(4)
2006/10/09 PHP
php利用iframe实现无刷新文件上传功能的代码
2011/09/29 PHP
Laravel5.1自定义500错误页面示例
2016/10/09 PHP
简短几句 通俗解释javascript的闭包
2011/01/17 Javascript
jquery显示和隐藏div特效实例
2013/02/27 Javascript
了解Javascript的模块化开发
2015/03/02 Javascript
avalonjs制作响应式瀑布流特效
2015/05/06 Javascript
深入浅出理解javaScript原型链
2015/05/09 Javascript
简介JavaScript中fixed()方法的使用
2015/06/08 Javascript
jQuery实现类似标签风格的导航菜单效果代码
2015/08/25 Javascript
jQuery遍历DOM节点操作之filter()方法详解
2016/04/14 Javascript
学习使用jQuery表单验证插件和日历插件
2017/02/13 Javascript
利用js定义一个导航条菜单
2017/03/14 Javascript
Javascript别踩白块儿(钢琴块儿)小游戏实现代码
2017/07/20 Javascript
使用Angular CLI进行Build(构建)和Serve详解
2018/03/24 Javascript
JS温故而知新之变量提升和时间死区
2019/01/27 Javascript
原生js实现照片墙效果
2020/10/13 Javascript
Python减少循环层次和缩进的技巧分析
2016/03/15 Python
Python中is与==判断的区别
2017/03/28 Python
Python简单实现自动删除目录下空文件夹的方法
2017/08/29 Python
Python机器学习之决策树算法
2017/12/22 Python
python爬虫中get和post方法介绍以及cookie作用
2018/02/08 Python
Pandas Shift函数的基础入门学习笔记
2018/11/16 Python
详解pyppeteer(python版puppeteer)基本使用
2019/06/12 Python
python移位运算的实现
2019/07/15 Python
Django的Modelforms用法简介
2019/07/27 Python
python获取Linux发行版名称
2019/08/30 Python
Python参数传递机制传值和传引用原理详解
2020/05/22 Python
如何基于Python代码实现高精度免费OCR工具
2020/06/18 Python
Python GUI库Tkiner使用方法代码示例
2020/11/27 Python
西班牙在线光学:Visual-Click
2020/06/22 全球购物
财务经理的岗位职责
2013/12/17 职场文书
《郑和远航》教学反思
2014/04/16 职场文书
大三学习计划书范文
2014/05/02 职场文书
严以律己专题学习研讨会发言材料
2015/11/09 职场文书
Python还能这么玩之用Python做个小游戏的外挂
2021/06/04 Python