最近看到了NETSNS,首先就被它个性化的界面吸引了。随着对源代码的逐步学习发现还是存在不少问题的,比如有些功能没有实现,经常会有脚本错误‘缺少对象’.由于这段时间不太忙,决定对其做一些修改,同时也寄希望于从中学到一些知识。
目前修改好的'bug'的主要有:
1.投票模块点击‘确定’按钮后提示URI编码不合法
错误原因是public.js中escape()方法使用错误,用encodeURIComponent()对参数编码即可,知识点如下:
Code
js对文字进行编码涉及3个函数:escape,encodeURI,encodeURIComponent,相应3个解码函数:unescape,decodeURI,decodeURIComponent
1、 传递参数时需要使用encodeURIComponent,这样组合的url才不会被#等特殊字符截断。
例如:<script language="javascript">document.write('<a href="http://passport.baidu.com/?logout&aid=7&u= +encodeURIComponent("http://cang.baidu.com/bruce42")+">退出</a>');</script>
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,它是将中文、
最近看到了NETSNS,首先就被它个性化的界面吸引了。随着对源代码的逐步学习发现还是存在不少问题的,比如有些功能没有实现,经常会有脚本错误‘缺少对象’.由于这段时间不太忙,决定对其做一些修改,同时也寄希望于从中学到一些知识。
目前修改好的'bug'的主要有:
1.投票模块点击‘确定’按钮后提示URI编码不合法
错误原因是public.js中escape()方法使用错误,用encodeURIComponent()对参数编码即可,知识点如下:
Code
js对文字进行编码涉及3个函数:escape,encodeURI,encodeURIComponent,相应3个解码函数:unescape,decodeURI,decodeURIComponent
1、 传递参数时需要使用encodeURIComponent,这样组合的url才不会被#等特殊字符截断。
例如:<script language="javascript">document.write('<a href="http://passport.baidu.com/?logout&aid=7&u= +encodeURIComponent("http://cang.baidu.com/bruce42")+">退出</a>');</script>
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个:*,+,-,.,/,@,_,0-9,a-z,A-Z
encodeURI不编码字符有82个:!,#,$,&,',(,),*,+,,,-,.,/,:,;,=,?,@,_,~,0-9,a-z,A-Z
encodeURIComponent不编码字符有71个:!, ',(,),*,-,.,_,~,0-9,a-z,A-Z
2.user/default页面中的逻辑错误。
错误原因:‘相遇同城好友’及‘相遇就是缘’两个栏目下的内容无法正确显示。经常是查询NetSNS.DALSQLServer.UserIndex.cs的FindFriend函数中sql语句有逻辑错误。因为该查询语句查的是好友列表,所以a.UserID not in (select FriendID from NT_Friend where UserID=" + userId + ")应该改为a.UserID in (select FriendID from NT_Friend where UserID=" + userId + "),否则是不会有结果的。
针对目前解决的两个bug做一下记录,以后如果还有时间继续把我认为有问题的地方指出来。
韩文等特殊字符转换成utf-8格式的url编码,所以如果给后台传递参数需要使用encodeURIComponent时需要后台解码对utf-8支持(form中的编码方式和当前页面编码方式相同)
escape不编码字符有69个:*,+,-,.,/,@,_,0-9,a-z,A-Z
encodeURI不编码字符有82个:!,#,$,&,',(,),*,+,,,-,.,/,:,;,=,?,@,_,~,0-9,a-z,A-Z
encodeURIComponent不编码字符有71个:!, ',(,),*,-,.,_,~,0-9,a-z,A-Z
2.user/default页面中的逻辑错误。
错误原因:‘相遇同城好友’及‘相遇就是缘’两个栏目下的内容无法正确显示。经常是查询NetSNS.DALSQLServer.UserIndex.cs的FindFriend函数中sql语句有逻辑错误。因为该查询语句查的是好友列表,所以a.UserID not in (select FriendID from NT_Friend where UserID=" + userId + ")应该改为a.UserID in (select FriendID from NT_Friend where UserID=" + userId + "),否则是不会有结果的。
3.创建相册时点’取消’按钮出错。window.location='photos.aspx?r=<%=UserID%>
针对目前解决的两个bug做一下记录,以后如果还有时间继续把我认为有问题的地方指出来。