C
C
CloudMonster2014-06-09 09:37:42
PHP
CloudMonster, 2014-06-09 09:37:42

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

2 answer(s)
D
Dmitry Evdokimov, 2014-07-04
@dmitry_e

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" }

S
Sergey Saveliev, 2016-10-03
@sergej_saveljev

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);

Classes from laravel are involved in the file code, but I think it will not be difficult to find similar ones on the Internet and change the corresponding sections a little.

Didn't find what you were looking for?

Ask your question

Ask a Question

731 491 924 answers to any question