Answer the question
In order to leave comments, you need to log in
How to set image upload to Froala content editor?
Hello!
I installed the Froala Editor content editor in the site admin panel.
There is a button to upload a picture, but the problem is that the upload goes to their server, not mine. The documentation has an article about installing editor.froala.com/docs/image-upload-php , but I couldn't figure it out.
If anyone has encountered such a problem in this editor, please help.
Answer the question
In order to leave comments, you need to log in
The link imageUploadURL: '/upload.php'
should be a page that moves the file $_FILES['file']
to the "uploads" folder with the name sha1(microtime()) . "." . $extension;
and in response gives a link to it in the form of JSON of the following form
{ link: "uploads/ed13a3f3e78deef2fbeb8a2781297f7860efaa9c.jpg" }
I needed all the available options, I'm happy to share.
imageUploadURL: 'image_upload.php',
imageUploadParams: {
path: '/images/'
},
imageManagerLoadURL: 'image_load.php',
imageManagerLoadParams: {
path: '/images/'
},
imageManagerLoadMethod: 'POST',
imageManagerDeleteURL: 'image_delete.php',
// Allowed extentions.
$allowedExts = array("gif", "jpeg", "jpg", "png", "blob");
// Get filename.
$temp = explode(".", $_FILES["file"]["name"]);
// Get extension.
$extension = strtolower(end($temp));
// An image check is being done in the editor but it is best to
// check that again on the server side.
// Do not use $_FILES["file"]["type"] as it can be easily forged.
$finfo = finfo_open(FILEINFO_MIME_TYPE);
$mime = finfo_file($finfo, $_FILES["file"]["tmp_name"]);
if ((($mime == "image/gif")
|| ($mime == "image/jpeg")
|| ($mime == "image/pjpeg")
|| ($mime == "image/x-png")
|| ($mime == "image/png"))
&& in_array($extension, $allowedExts)) {
$path = base_path() . '/public/images/' . $_POST['path'];
if ( !is_dir($path) ) \File::makeDirectory($path, 0775, true);
// image
$img = $_FILES["file"];
$name = strtolower($img['name']);
$src = $path . $name;
$imgM = Image::make($img['tmp_name']);
if ( isset($_POST['save']) ){
$imgM = $imgM->fit(200, 200);
$user->photo = $_POST['path'].$name;
$user->save();
}
$imgM->save($src);
// Generate response.
$response = new \StdClass;
$response->link = $_POST['path'] . $name;
echo stripslashes(json_encode($response));
}
// Array of image objects to return.
$response = array();
// Image types.
$image_types = array(
"image/gif",
"image/jpeg",
"image/pjpeg",
"image/jpeg",
"image/pjpeg",
"image/png",
"image/x-png"
);
// Filenames in the uploads folder.
$path = $_POST['path'];
$fnames = scandir($path);
// Check if folder exists.
if ($fnames) {
// Go through all the filenames in the folder.
foreach ($fnames as $name) {
// Filename must not be a folder.
if (!is_dir($name)) {
// Check if file is an image.
if (in_array(mime_content_type(getcwd() . '/' . $path . $name), $image_types)) {
// Build the image.
$img = new \StdClass;
$img->url = $_POST['path'] . $name;
$img->thumb = $_POST['path'] . $name;
$img->name = $name;
// Add to the array of image.
array_push($response, $img);
}
}
}
}
// Folder does not exist, respond with a JSON to throw error.
else {
$response = new \StdClass;
$response->error = "Images folder does not exist!";
}
$response = json_encode($response);
// Send response.
echo stripslashes($response);
// Get src.
$src = getcwd() . $_POST["src"];
// delete image
unlink($src);
Didn't find what you were looking for?
Ask your questionAsk a Question
731 491 924 answers to any question