• JS、C#编码解码


    最近在项目中用到请求一个地址的时候,会传个JSON数据。刚开开始没什么问题,后来发现有特殊符号就会有问题,找到一些解决方案,在此记录下。

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

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

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

    1.

    JS: escape :

    • js使用数据时可以使用escape
    • 例如:搜藏中history纪录。
    • 0-255以外的unicode值进行编码时输出%u****格式,其它情况下escape,encodeURI,encodeURIComponent编码结果相同。

    解码使用:unescape

    C#:

    HttpUtility.UrlEncode   
    HttpUtility.UrlDecode

    2.

    JS: encodeURI :

    • 进行url跳转时可以整体使用encodeURI
    • 例如:Location.href=encodeURI("http://cang.baidu.com/do/s?word=百度&ct=21");

    解码使用decodeURI();

    C#: decodeURIComponent

    3.

    JS: encodeURIComponent :

    • 传递参数时需要使用encodeURIComponent,这样组合的url才不会被#等特殊字符截断。                           
    • 例如:<script language="javascript">document.write('<a href="http://passport.baidu.com/?logout&aid=7& u='+encodeURIComponent("http://cang.baidu.com/bruce42")+'">退出</a& gt;');</script>

    解码使用decodeURIComponent()

    C#:

    [HttpContext.Current.]Server.UrlDecode
    [HttpContext.Current.]Server.UrlEncode
  • 相关阅读:
    RDD执行延迟执行原理
    spark应用运行机制解析1
    spark streaming job生成与运行
    spark的Task的序列化
    spark将计算结果写入到hdfs的两种方法
    spark的runJob函数2
    SVG---------SVG sprite 使用示例
    段落边框——paraBox.scss
    背景条纹——bgStripes.scss
    css3动画——基本准则
  • 原文地址:https://www.cnblogs.com/sexintercourse/p/12067974.html
Copyright © 2020-2023  润新知