Base64 encoding and decoding in web browsers

Introduction to Base64

Base64 is a representation of binary data based on 64 printable characters. Since 2^6=64, every 6 bits is a unit, corresponding to a certain printable character. 3 bytes have 24 bits, corresponding to 4 Base64 units, and 3 bytes can be represented by 4 printable characters. The printable characters in Base64 include the letters AZ, az, and the numbers 0-9, so there are 62 characters in total. The other two printable characters are different in different systems. ——Wikipedia

Base64 is often used to represent, transmit, and store some binary data in situations where text data is usually processed, including MIME emails and some complex data in XML.

However, the most exposed to Base64 in the front end must be Base64 images. A very important aspect of performance optimization is to reduce requests, so some smaller images can be converted to Base64 to reduce the number of requests. Many front-end framework scaffolding is also configured with this by default. point.

Conversion of base64 in web pages

string

window.btoa() method

The window.btoa() function creates a base-64 encoded ASCII string from a String object, where each character in the string is treated as a binary data byte. Although his name is quite casual, it is as simple and crude as his name.

grammar:

    let encodedData = window.btoa(stringToEncode);

like:

    console.log(window.btoa('123456abc'));  // 'MTIzNDU2YWJj'
window.atob() method

As can be seen from the name, window.btoa() returns and decodes the base64-encoded string.

If the length of the incoming string is not a multiple of 4, a DOMException is thrown.

grammar:

    var decodedData = window.atob(encodedData);

like:

    console.log(window.atob('MTIzNDU2YWJj'));  // '123456abc'
*Cross-border exception

In each browser, using window.btoa to encode a Unicode string will trigger an out-of-bounds character exception.

This problem can be solved by first converting the Unicode string to UTF-8 encoding,
such as

    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"
Compatibility of window.btoa() and window.atob() methods (2019-06-03)atob compatibility

It can be seen that the compatibility is very good

If you want to be compatible with IE—— Base.js

coding

use

    var encodedData = Base64.encode(stringToEncode);

like

    console.log(Base64.encode('123456abc'));  // 'MTIzNDU2YWJj'
decoding

use

    var decodedData = Base64.decode(encodedData);

like:

    console.log(Base64.decode('MTIzNDU2YWJj'));  // '123456abc'

document

If you want to implement Base64 encoding of files, you need FileReader . The FileReader type implements an asynchronous file reading mechanism. You can think of FileReader as XMLHttpRequest, except that it reads the file system instead of the remote server.
The specific use is not introduced in detail here. Here is an example of encoding the test.txt file into Base64 through FileReader:

    function getFileBase64 (file, cb) {
    
    
        if (!file) throw new Error('Error! no param "file"(getFileBase64()).');

        let reader = new FileReader();
        reader.onload = function(e) {
    
    
            let base64 = e.target.result;   // 该文件的完整Base64

            if (cb) cb(base64);
        };
        reader.onerror = function () {
    
    
            alert('Read file fail.');
        };
        reader.readAsDataURL(file);
    }
    

use:

    window.addEventListener("dragenter", function(event) {
    
     event.preventDefault(); }, false);
    window.addEventListener("dragover", function(event) {
    
     event.preventDefault(); }, false);

    window.addEventListener("drop", function(event) {
    
    
        getFileBase64(event.dataTransfer.files[0], function (base64) {
    
    
            console.log(base64)
        });
        event.preventDefault();

    }, false);

Result (original test.txt content is "123456abc"):

    data:text/plain;base64,MTIzNDY1YWJj

Current (2019-06-03) filereader compatibility status
filereader

The map's address

For pictures or picture URLs on the page, you can encode them through the toDataURL method of canvas. Note that the URL has domain name restrictions.

    function getImgBase64(urlorImg, cb) {
    
    
        if (!urlorImg) throw new Error('Error! no param "url"(getImgBase64).')

        function getBase64 (imgObj) {
    
    
            let _width = imgObj.width,
                _height = imgObj.height;

            canvas = document.createElement('canvas');
            canvas.width = _width;
            canvas.height = _height;

            ctx = canvas.getContext("2d");
            ctx.drawImage(imgObj, 0, 0, _width, _height);

            return canvas.toDataURL('image/jpeg', 1);
        }


        if (typeof urlorImg === 'string') {
    
     // url
            let _img = new Image();
            _img.onload = function () {
    
    
                let img64 = getBase64(_img)

                if (cb) cb(img64);
            };

            _img.onerror = function () {
    
    
                alert('Image load failed.');
            };

            _img.src = urlorImg;
        } else {
    
            // Image Object
            let img64 = getBase64(urlorImg)

            if (cb) cb(img64);
        }
    }

use

    getImgBase64('https://fund.10jqka.com.cn/public/181024koi/dist/images/t-2.png', base64 => {
    
    
        console.log(base64);
    });

result

    

Summarize

  • For simple string conversion, you can use the window.btoa() method. To be compatible with IE, you need to reference Base64.js and use the corresponding method;
  • For conversion of images on the page or image URLs with the same domain name, you can use the canvas-based getImgBase64() method;
  • For files, you can use the getFileBase64() method based on FileReader;

References:

Author contact information

Guess you like

Origin blog.csdn.net/qq_24357165/article/details/90748339