在前端开发中,经常会涉及与后端之间的图片传输,通常情况下可以转码base64,来进行图片上传,也可以通过img标签的src属性展示base64编码格式储存的图片

base64 将 A-Z(ascii 65 – 90) 、a-z(ascii 97 – 122)、0-9(ascii 48 – 57)、+、/ 组成的有序数组作为标准的Base64协议规定

  • 生成base64数组
var base64Array = [];
for (var i = 65; i < 91; i++) {
base64Array.push(String.fromCharCode(i));
}
for (var i = 97; i < 123; i++) {
base64Array.push(String.fromCharCode(i));
}
for (var i = 48; i < 58; i++) {
base64Array.push(String.fromCharCode(i));
}
base64Array.push("+", "/");

一个英文字符占一个字节,一个字节由8位组成

将字符串按每三个字节分成若干组

将每组的24位按照每6位一组分成4组

每组6位,前两位用0补齐形成,4组每组8位,共32位

再将每组的8位2进制转换成10进制,在base64数组中找到对应的值输出

btoa:

function () {
    window.myBtoA = function (testString) {
        var base64Array = [];
        for (var i = 65; i < 91; i++) {
            base64Array.push(String.fromCharCode(i));
        }
        for (var i = 97; i < 123; i++) {
            base64Array.push(String.fromCharCode(i));
        }
        for (var i = 48; i < 58; i++) {
            base64Array.push(String.fromCharCode(i));
        }
        base64Array.push("+", "/");
        var bits = [];
        var newbits = [];
        for (var i = 0; i < testString.length; i++) {
            for (var j = 0; j < 8; j++) {
                bits.push(((testString[i].charCodeAt() >> (7 - j)) & 1));
            }
        }
        while (bits.length) {
            var bit = [0, 0, ...bits.splice(0, 6)];
            if (bit.length !== 8) {
                bit.push(...(new Array(8 - bit.length).fill(0)));
            }
            newbits.push(bit);
        }
        var result = "";
        for (var i of newbits) {
            result += (base64Array[parseInt(i.toString().replace(/,/g, ""), 2)]);
        }
        if (testString.length % 3 === 1) {
            result += "==";
        }
        if (testString.length % 3 === 2) {
            result += "=";
        }
        return result;
    };
})();

118 个评论

  1. I’ve been browsing online more than 3 hours these days, yet I never found
    any fascinating article like yours. It is beautiful price sufficient for
    me. In my view, if all website owners and bloggers made excellent content material as you probably did, the
    internet will probably be much more helpful than ever before.

  2. After going over a number of the blog posts on your site, I truly appreciate your technique of writing a blog.
    I book marked it to my bookmark webpage list and will be checking
    back in the near future. Take a look at my website as well
    and tell me how you feel.

  3. Hi there! This post could not be written much better! Going through this post reminds me of my previous roommate!
    He continually kept talking about this. I am going to send this post to him.
    Fairly certain he will have a great read. I appreciate you for
    sharing!

  4. I’ve been browsing online more than 3 hours today,
    yet I never found any interesting article like yours. It is pretty worth enough for me.

    Personally, if all site owners and bloggers made good content as you did, the web will be
    much more useful than ever before.

  5. It’s appropriate time to make some plans for the long run and it is time to be happy.

    I’ve learn this submit and if I may just I want
    to recommend you some fascinating things or tips.

    Perhaps you could write subsequent articles
    relating to this article. I want to learn even more issues
    approximately it!

  6. Having read this I believed it was extremely informative. I appreciate you spending some time and effort to put this informative article together. I once again find myself spending way too much time both reading and commenting. But so what, it was still worthwhile!

  7. I loved as much as you will receive carried out right here.
    The sketch is tasteful, your authored subject matter stylish.
    nonetheless, you command get bought an edginess over that you wish be delivering the
    following. unwell unquestionably come further formerly again since exactly the same nearly very often inside case you shield this increase.

  8. I have been surfing on-line greater than three
    hours today, yet I by no means found any attention-grabbing article like yours.
    It is lovely price enough for me. Personally, if all website
    owners and bloggers made just right content as you did, the internet might
    be much more helpful than ever before.

  9. I’ve been browsing online greater than 3 hours these days, but I never discovered any interesting
    article like yours. It’s lovely value sufficient for me.
    In my view, if all site owners and bloggers made just right
    content material as you probably did, the web will probably be much more useful than ever before.

  10. It is appropriate time to make some plans for the future and
    it is time to be happy. I have read this post and if I could
    I want to suggest you few interesting things or suggestions.
    Maybe you can write next articles referring to this article.
    I want to read even more things about it!

  11. It is appropriate time to make a few plans for the long run and it is time to be happy.
    I’ve learn this submit and if I may I wish to recommend you
    few fascinating things or advice. Perhaps you
    could write next articles referring to this article.

    I desire to learn even more issues about it!

  12. I have been surfing on-line greater than 3 hours as of late, but I by no means found any interesting article like yours.
    It is beautiful price sufficient for me.
    In my view, if all webmasters and bloggers
    made excellent content as you did, the internet shall be much more
    helpful than ever before.

  13. I’ve been browsing online more than 4 hours today, yet I never
    found any interesting article like yours. It’s pretty worth enough for me.

    Personally, if all site owners and bloggers made good content as you did, the web will be
    much more useful than ever before.

  14. Thanks for the various tips contributed on this web site. I have observed that many insurance companies offer consumers generous reductions if they prefer to insure more and more cars with them. A significant amount of households include several cars these days, particularly those with elderly teenage youngsters still dwelling at home, and the savings in policies can easily soon increase. So it pays to look for a bargain.

  15. I’ve been browsing online more than 2 hours today, yet I never found any
    interesting article like yours. It’s pretty worth enough for me.
    Personally, if all webmasters and bloggers made good content as you did, the web will be a lot more
    useful than ever before.

  16. Hi there! This blog post could not be written much better!
    Reading through this article reminds me of my previous roommate!
    He continually kept talking about this. I will forward this information to him.
    Pretty sure he’s going to have a good read. Many thanks
    for sharing!

  17. I’ve been surfing online more than 4 hours today, yet I never found any interesting article like yours.
    It’s pretty worth enough for me. In my view, if all webmasters
    and bloggers made good content as you did,
    the web will be much more useful than ever before.

  18. I’ve been browsing on-line greater than 3 hours these days, yet
    I by no means discovered any interesting article like yours.

    It’s beautiful price sufficient for me. Personally, if all web owners and bloggers
    made excellent content material as you probably did, the net will probably be much more useful than ever before.

  19. It’s perfect time to make some plans for the long run and it is time to be happy.
    I’ve learn this put up and if I may I desire to suggest you few attention-grabbing issues or advice.
    Maybe you can write next articles referring to this article.

    I want to learn more issues approximately it!

  20. Pretty portion of content. I just stumbled upon your weblog and
    in accession capital to claim that I get actually enjoyed account your weblog posts.
    Any way I’ll be subscribing to your augment or even I success you get entry to constantly rapidly.

  21. It is appropriate time to make some plans for the long
    run and it’s time to be happy. I’ve learn this publish and if I
    may just I wish to suggest you few fascinating issues
    or tips. Maybe you can write subsequent articles referring to this article.
    I wish to read even more issues approximately it!

  22. Hey would you mind letting me know which web host you’re using?
    I’ve loaded your blog in 3 different internet browsers
    and I must say this blog loads a lot quicker then most. Can you suggest
    a good internet hosting provider at a fair price? Thank you, I appreciate it!

  23. Instagram için takipçi almak önemlidir fakat keşfet için yada kaliteli bir profile sahip olarak
    takipçi satın almak için En kaliteli site olan takip2018.com dan türk takipçi satın al hesabını bot takipçiler ile dolmasın
    Ayrıca Türk takipçi paketlerin hepsin de hediyeler mevcuttur.

  24. Today, while I was at work, my sister stole my iPad and tested to see if it can survive a 30 foot drop, just
    so she can be a youtube sensation. My apple ipad is now destroyed and she has 83
    views. I know this is entirely off topic but I had
    to share it with someone!

回复 Donna Shafer 取消回复

您的电子邮箱地址不会被公开。 必填项已用*标注