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>
He sent me one post
with a file
that I was uploading to my server, but there was a need 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>
<script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/croppie/2.4.0/croppie.js"></script>
<form action="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 element <img id="cropped" name="cropped" />
i get a Base64 of type:
<img id="cropped" name="cropped" src="">
Now I wonder how to send this image in Base64 to the server and work with it so that it stays in the format as if it were a input
of the kind file
I will send this image to the server, will not be saved on
db
no. Now I’m searching how to decode this image on the server side, to send directly as an image. ;When I say server, it’s abucket
of aws– MarceloBoni
@Marcelobonifazio to decode just give a base64_decode on what comes after date: ... Base64,
– Bacco
I think it is not necessary to convert, I did a test sending the raw Base64 and saved the image correctly
– MarceloBoni
I only commented on the conversion in case I leave in DB, but see how you think better, of course.
– Bacco