如何仅从图像 url 将图像发送到服务器?

时间:2021-06-05 21:03:28

标签: javascript http

我正在尝试将图像发送到我的 chrome 扩展程序的服务器。我正在使用之前讨论中的代码 --> how to send image to server with http.post in javascript and store base64 in mongodb

我的问题是图像从未真正上传到页面。例如,我试图将图像上传到不是我的服务器上的此输入:image upload section。代码运行后,图片部分不上传图片,这是我程序的最终目标。

这是所有 console.log() 运行后终端的样子:enter image description here

有谁知道这背后的原因以及我如何解决这个问题?简单地说,我希望将所需的图像上传到“添加照片”部分。

如果有人对如何解决整个问题有更好的解决方案,请告诉我!

      var convertToBase64 = function(url, imagetype, callback){

          var img = document.createElement('IMG'),
              canvas = document.createElement('CANVAS'),
              ctx = canvas.getContext('2d'),
              data = '';

          // Set the crossOrigin property of the image element to 'Anonymous',
          // allowing us to load images from other domains so long as that domain
          // has cross-origin headers properly set

          img.crossOrigin = 'Anonymous'

          // Because image loading is asynchronous, we define an event listening function that will be called when the image has been loaded
          img.onload = function(){
              console.log('hoiii');
              // When the image is loaded, this function is called with the image object as its context or 'this' value
              canvas.height = this.height;
              canvas.width = this.width;
              ctx.drawImage(this, 0, 0);
              console.log(canvas);
              console.log(ctx);
              data = canvas.toDataURL(imagetype);
              console.log(data);
              callback(data);
          };

          // We set the source of the image tag to start loading its data. We define
          // the event listener first, so that if the image has already been loaded
          // on the page or is cached the event listener will still fire

          img.src = url;
          console.log(img);
      };

      // Here we define the function that will send the request to the server.
      // It will accept the image name, and the base64 data as arguments

      var sendBase64ToServer = function(name, base64){
          var httpPost = new XMLHttpRequest(),
              path = "",
              data = JSON.stringify({image: base64});
          httpPost.onreadystatechange = function(err) {
                  if (httpPost.readyState == 4 && httpPost.status == 200){
                      console.log(httpPost.responseText);
                  } else {
                      console.log(err);
                  }
              };
          // Set the content type of the request to json since that's what's being sent
          httpPost.open("POST", path, true);
          httpPost.setRequestHeader('Content-Type', 'image/jpeg');
          httpPost.send(data);
      };

      // This wrapper function will accept the name of the image, the url, and the
      // image type and perform the request

      var uploadImage = function(src, name, type){
          convertToBase64(src, type, function(data){
              sendBase64ToServer(name, data);
          });
      };

      // Call the function with the provided values. The mime type could also be png
      // or webp

      uploadImage(result.products[pointer][3], 'cool.jpeg', 'image/jpeg');

0 个答案:

没有答案