如何获得用户提供的图像的链接?

时间:2019-01-30 07:47:04

标签: javascript html css

我正在建立一个小网站,用户可以在其中粘贴图像。我想获取该粘贴图像的链接。我现在得到的是:



还有50万个字符。

这也是我使用的代码,也获得了粘贴的图像:

  document.getElementById('pasteArea').onpaste = function (event) {
  var items = (event.clipboardData  || event.originalEvent.clipboardData).items;
  console.log(JSON.stringify(items)); // will give you the mime types
  // find pasted image among pasted items
  var blob = null;
  for (var i = 0; i < items.length; i++) {
    if (items[i].type.indexOf("image") === 0) {
      blob = items[i].getAsFile();
    }
  }
  // load image if there is a pasted image
  if (blob !== null) {
    var reader = new FileReader();
    reader.onload = function(event) {
      console.log(event.target.result); // data url!
      document.getElementById("pastedImage").src = event.target.result;
        console.log(event.target.result);
        alert(event.target.result);
    };
    reader.readAsDataURL(blob);
  }
    }

然后我使用<div class="absoluteText square"> <img id="pastedImage"/> </div>

显示它

我希望能够以某种方式轻松引用此图像。例如,在另一个选项卡中打开。 那么我将如何获得到该图像的正常链接,最好是用户端?

1 个答案:

答案 0 :(得分:0)

将文件转换为Blob网址。下面的代码会将所有多个文件放入数组,并可以存储在后端。

var filesArray = new Array();
var file = document.getElementById('XYZ').files[0];
    if(file){
        var reader = new FileReader(); 
        reader.onloadend = function(e) {
            filesArray.push(e.target.result);
        };  
        reader.readAsDataURL(file); 
    }

下面的代码将获取文件名(php)

foreach($filesArray as $key => $value){
   $data = explode(',',$value);
   $typeFile = explode('/', $data[0]);
   $extension = explode(';', $typeFile[1]);
   $fileName = base64_decode($data[1]);
}

将文件名保存在数据库中