zoukankan      html  css  js  c++  java
  • javascript中对编码的解读

    首先来一下js知识的巩固与复习

    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编码结果相同。

    javascript对URL中的参数进行简单加密处理

    javascript的api本来就支持Base64,因此我们可以很方便的来进行编码和解码。

    var encodeData = window.btoa("name=xiaoming&age=10")//编码

    var decodeData = window.atob(encodeData)//解码。

    例子:

    var encodedData = window.btoa("Hello, world"); // 编码
    var decodedData = window.atob(encodedData); // 解码

    在各浏览器中,使用 window.btoa 对Unicode字符串进行编码都会触发一个字符越界的异常.

    先把Unicode字符串转换为UTF-8编码,可以解决这个问题, 代码来自Johan Sundstr?m:

    function utf8_to_b64( str ) {
        return window.btoa(unescape(encodeURIComponent( str )));
    }
    
    function b64_to_utf8( str ) {
        return decodeURIComponent(escape(window.atob( str )));
    }
    
    // Usage:
    utf8_to_b64('? à la mode'); // "4pyTIMOgIGxhIG1vZGU="
    b64_to_utf8('4pyTIMOgIGxhIG1vZGU='); // "? à la mode"
    //译者注:在js引擎内部,encodeURIComponent(str)相当于escape(unicodeToUTF8(str))
    //所以可以推导出unicodeToUTF8(str)等同于unescape(encodeURIComponent(str))
    //example

    $(function () {
    $(".edit-btn").on("click",function () {
    var policyNo=$(this).parents(".t-r").find(".policy-no").text();
    var holderName=$(this).parents(".t-r").find(".holder-name").text();
    // $.ajax({
    // url:"/reviseService/revise/reviseOption/"+policyNo+"/"+holderName+"",
    // type:"POST",
    // success:function () {
    // window.location.href();
    // }
    // })
    // window.open("/reviseService/revise/reviseOption/"+policyNo+"/"+holderName+"");
    // window.open(encodeURIComponent("/reviseService/revise/reviseOption/"+window.btoa(policyNo+"/"+holderName+"")));
    window.open("/reviseService/revise/reviseOption/"+ window.btoa(unescape(encodeURIComponent(policyNo+"/"+holderName+""))+""));
    })
    })

    //例子

    var url="http://localhost:8080/reviseService/revise/reviseOption/NkRZSUwxNzA1SkswMjAwMTE3MDAwMDA0OS/lvKDlhas=";
    
    var uu=url.split("reviseOption/")[1];
    console.log(uu);//NkRZSUwxNzA1SkswMjAwMTE3MDAwMDA0OS/lvKDlhas=
    
    function b64_to_utf8(str) {
    return decodeURIComponent(escape(window.atob(str)));
    }
    var aa=b64_to_utf8(uu);
    console.log(aa);//6DYIL1705JK02001170000049/张八
    var cc=aa.split("/");
    console.log(cc);//["6DYIL1705JK02001170000049", "张八"]
    

      

     
    参考文档:http://www.cnblogs.com/fishtreeyu/archive/2011/02/27/1966178.html
    https://developer.mozilla.org/zh-CN/docs/Web/API/WindowBase64/btoa
    http://www.cnblogs.com/xiao-lei/p/6064134.html
    http://www.cnblogs.com/fishtreeyu/archive/2011/02/27/1966178.html
  • 相关阅读:
    软件工程第四次作业-题目2
    oracle数据库本地网络服务名配置常见问题
    2020软件工程第三次作业
    2020软件工程第二次作业
    2020软件工程第一次作业
    20145208 蔡野 《网络攻防》 后门原理与实践
    20145208蔡野 《网络对抗》逆向及BOF基础实践
    密码分析学学习总结
    20145208 《信息安全系统设计基础》课程总结
    20145208 《信息安全系统设计基础》第十四周学习总结
  • 原文地址:https://www.cnblogs.com/shj-com/p/7544543.html
Copyright © 2011-2022 走看看