在Javascript中将本地图像转换为base64字符串

12

我正在尝试将一张本地图片转换为Base64 字符串。我没有使用任何HTML,只需使用引用代码中图像路径的Javascript。

例如,将以下内容转换:

C:\Users\Work\Desktop\TestImage.jpg

进入

/9j/4AAQSkZJRgABAQEASABIAAD/4QBKRXhpZgAASUkqAAgAAAADABoBBQABAAAAMgAAABsBBQABAAAAOgAAACgBAwABAAAAAgAAAAAAAAAAVOoqgJaYAABU6iqAlpgA/+IMWElDQ19QUk9GSUxFAAEBAAAMSExpbm8CEAAAbW50clJHQiBYWVogB84AAgAJAAYAMQAAYWNzcE1TRlQAAAAASUVDIH.....etc...

有许多类似的帖子,但它们似乎都以某种方式利用HTML来识别文件路径。我希望我可以在JavaScript中写入一个明确定义的文件路径内部

我尝试过这个,但没有成功:

function convertImgToBase64()
{
    var canvas = document.createElement('CANVAS');
    img = document.createElement('img'),
    img.src = C:\Users\Work\Desktop\TestImage.jpg;
    img.onload = function()
    {
        canvas.height = img.height;
        canvas.width = img.width;
        var dataURL = canvas.toDataURL('image/png');
        alert(dataURL);
        canvas = null; 
    };
}

一个例子具有以下的html和javascript,但我希望这些可以合并在一起。感谢您的支持。

HTML:

<!DOCTYPE html>
<html>
<head>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1/jquery.min.js"></script>
<meta charset=utf-8 />
<title>JS Bin</title>
</head>
<body>


<input type='file' id="asd" />
<br>
<img id="img" src="//placehold.it/1x1/" />
<div id="base"></div>
</body>
</html>

Javascript:

function el(id){return document.getElementById(id);} // Get elem by ID

function readImage() {
    if ( this.files && this.files[0] ) {
        var FR= new FileReader();
        FR.onload = function(e) {
             el("img").src = e.target.result;
             el("base").innerHTML = e.target.result;
        };       
        FR.readAsDataURL( this.files[0] );
    }
}

el("asd").addEventListener("change", readImage, false);\

这里找到演示

1个回答

17

尝试使用XMLHttpRequest(),将responseType设置为Blob,在XMLHttpRequestonload事件中使用FileReader()将响应作为data URI读取。

var xhr = new XMLHttpRequest();       
    xhr.open("GET", "/path/to/local/image/file", true); 
    xhr.responseType = "blob";
    xhr.onload = function (e) {
            console.log(this.response);
            var reader = new FileReader();
            reader.onload = function(event) {
               var res = event.target.result;
               console.log(res)
            }
            var file = this.response;
            reader.readAsDataURL(file)
    };
    xhr.send()

4
这对于未托管在服务器上的文件无法使用,它不适用于上述路径“C:\Users\Work\Desktop\TestImage.jpg”,因为跨源请求仅支持像http这样的协议方案。 - Wessam El Mahdy
@WessamElMahdy 请查看 https://stackoverflow.com/questions/32996001/jquery-load-only-working-in-firefox/, https://dev59.com/Jp3ha4cB1Zd3GeqPWZPY。 - guest271314

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接