Si le formulaire est soumis de la manière normale, il n'y aura aucun problème de vérification des antécédents :
$file = $request->avatar;
$input = array('image' => $file);
$rules = array(
'image' => 'image'
);
$validator = \Validator::make($input, $rules);
if ( $validator->fails() ) {
return \Response::json([
'success' => false,
'errors' => $validator->getMessageBag()->toArray()
]);
}
Cependant, lorsqu'il est soumis à l'aide de l'objet formData, le fichier image est converti en fichier blob et ne peut pas être vérifié :
$('#uploadAvatar').on('click', function (e) {
$('#uploadAvatar').html('正在保存...');
$("#image").cropper('getCroppedCanvas').toBlob(function (blob) {
var formData = new FormData();
formData.append('croppedImage', blob);
$.ajaxSetup({
headers: {
'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
}
});
$.ajax({
type: "POST",
url: "{{ url('/avatar') }}",
processData: false,
contentType: false,
cache: false,
data: formData
}).done(function (response) {
showResponse(response);
}).fail(function (data) {
alert('提交失败,请尝试重新提交');
});
});
});
Comment l'arrière-plan peut-il vérifier que le fichier blob est une image ?
C'est très simple, ne serait-il pas agréable de créer une variable temporaire et de la restaurer ?
$file = file_put_contents('/path/to/new/file_name', $blob);
Règles de validation étendues
getimagesize
Vous pouvez utiliser le streaming base64