Make image croppie before sending to server

1

It had a simple code that was just:

<form action="upload.php" method="post" enctype="multipart/form-data">
    <input type="text" name="description" />
    <input type="file" name="file" />
    <input type="submit" value="Enviar" />
</form>

It sent me a post with a file that I used on my server, however it was necessary to treat this image before sending it to the server.

I created the following code:

var Demo = (function() {

  function popupResult(result) {
    var html;
    if (result.html) {
      jQuery("#cropped").attr("src", html);
    }
    if (result.src) {
      jQuery("#cropped").attr("src", result.src);
    }

  }

  function demoUpload() {
    var $uploadCrop;

    function readFile(input) {
      if (input.files && input.files[0]) {
        var reader = new FileReader();
        reader.onload = function(e) {
          jQuery('.upload-demo').addClass('ready');
          $uploadCrop.croppie('bind', {
            url: e.target.result
          }).then(function() {
            console.log('jQuery bind complete');
          });

        }

        reader.readAsDataURL(input.files[0]);
      } else {
        alert("Sorry - you're browser doesn't support the FileReader API");
      }
    }

    $uploadCrop = jQuery('#upload-demo').croppie({
      // url: 'https://httpsimage.com/lock.png',
      viewport: {
        width: 100,
        height: 100,
        type: 'circle'
      },
      enableExif: true
    });

    jQuery('#upload').on('change', function() {
      readFile(this);
    });
    jQuery('.upload-result').on('click', function(ev) {
      $uploadCrop.croppie('result', {
        type: 'canvas',
        size: 'viewport'
      }).then(function(resp) {
        popupResult({
          src: resp
        });
      });
    });
  }

  function init() {
    demoUpload();
  }

  return {
    init: init
  };
})();

Demo.init();
input[type="file"] {
  cursor: pointer;
}
button:focus {
  outline: 0;
}
.file-btn {
  position: relative;
}
.file-btn input[type="file"] {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
}
.upload-demo .upload-demo-wrap,
.upload-demo .upload-result,
.upload-demo.ready .upload-msg {
  display: none;
}
.upload-demo.ready .upload-demo-wrap {
  display: block;
}
.upload-demo.ready .upload-result {
  display: inline-block;
}
.upload-demo-wrap {
  width: 300px;
  height: 300px;
  margin: 0 auto;
}
.upload-msg {
  text-align: center;
  padding: 50px;
  font-size: 22px;
  color: #aaa;
  width: 300px;
  height: 300px;
  margin: 0 auto;
  border: 1px solid #aaa;
}
<link type="text/css" rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/croppie/2.4.0/croppie.css" />
<script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/jquery/1.9.1/jquery.js"></script><scripttype="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/croppie/2.4.0/croppie.js"></script><formaction="upload.php" method="post" enctype="multipart/form-data">
  <!--
            <input type="text" name="description" />
			<input type="file" name="file" />
            -->
  <img id="cropped" name="cropped" />
  <div class="demo-wrap upload-demo">
    <div class="container">
      <div class="grid">
        <div class="actions">
          <a class="btn file-btn">
            <span>Selecionar Imagem</span>
            <input type="file" id="upload" name="upload" value="Choose a file" accept="image/*" />
          </a>
          <button class="upload-result">Cortar imagem</button>
        </div>
        <div class="upload-msg">
          Selecione uma imagem para cortar
        </div>
        <div class="upload-demo-wrap">
          <div id="upload-demo"></div>
        </div>
      </div>
    </div>
    <input type="submit" value="Enviar" />
  </div>
</form>

In the <img id="cropped" name="cropped" /> element I get a base64 of type:

<img id="cropped" name="cropped" src="">

Now I need to know how to send this image to the base64 pro server and work with it to be in the form of a input type file

    
asked by anonymous 26.12.2016 / 14:20

1 answer

2

You can include a hidden field in your form, and update it automatically:

<input type="hidden" name="imagem" id="imagem" value="">

And in JS update the field automatically:

if (result.src) {
  jQuery("#cropped").attr("src", result.src);
  jQuery("#imagem").attr("value", result.src);
}

In this way, when sending the form, the result will be in the "image" field.

Tip: If you are to store the image in a DB, it is probably best to decode the base64 and store the original data in a BLOB, and the mime-type correct in a separate field, or better yet, convert to image file .

Saving data to base64 almost always indicates lack of technique.

    
26.12.2016 / 14:42