Блокировка перекрестного источника (CORB) заблокировала ответ перекрестного происхождения https://blabla.net/errors/404/ с текстом MIME типа / html - PullRequest
0 голосов
/ 09 июля 2019

Я пытаюсь загрузить изображение на сервер, но я получаю сообщение об ошибке в заголовке.Кто-нибудь знает, почему это происходит или что это значит?

Я имею в виду, что я уже прочитал описание в ссылке, но я понятия не имею, почему мои загрузки "сомнительны"

Вот мой код

<!DOCTYPE html>
<html lang="en" dir="ltr">
  <head>
    <meta charset="utf-8">
    <title>form</title>
  </head>
  <body>


    <form class="" action="backend.php" method="POST" enctype="multipart/form-data">
      <input type="hidden" name="MAX_FILE_SIZE" value="30000000" />
      <input type="file" name="file1" value="">
      <input type="submit" name="" value="gonder">

    </form>




  </body>
</html>

А здеськод php бэкенда;

<!DOCTYPE html>
<html lang="en" dir="ltr">
  <head>
    <meta charset="utf-8">
    <title>asd</title>
  </head>
  <body>
<?php

    function uploadFile ($file_field = null, $check_image = false, $random_name = false) {

    //Config Section
    //Set file upload path
    $path = 'images/'; //with trailing slash
    //Set max file size in bytes
    $max_size = 10000000;
    //Set default file extension whitelist
    $whitelist_ext = array('jpeg','jpg','png','gif');
    //Set default file type whitelist
    $whitelist_type = array('image/jpeg', 'image/jpg', 'image/png','image/gif');

    //The Validation
    // Create an array to hold any output
    $out = array('error'=>null);

    if (!$file_field) {
      $out['error'][] = "Please specify a valid form field name";
    }

    if (!$path) {
      $out['error'][] = "Please specify a valid upload path";
    }

    if (count($out['error'])>0) {
      return $out;
    }

    //Make sure that there is a file
    if((!empty($_FILES[$file_field])) && ($_FILES[$file_field]['error'] == 0)) {

    // Get filename
    $file_info = pathinfo($_FILES[$file_field]['name']);
    $name = $file_info['filename'];
    $ext = $file_info['extension'];

    //Check file has the right extension
    if (!in_array($ext, $whitelist_ext)) {
      $out['error'][] = "Invalid file Extension";
    }

    //Check that the file is of the right type
    if (!in_array($_FILES[$file_field]["type"], $whitelist_type)) {
      $out['error'][] = "Invalid file Type";
    }

    //Check that the file is not too big
    if ($_FILES[$file_field]["size"] > $max_size) {
      $out['error'][] = "File is too big";
    }

    //If $check image is set as true
    if ($check_image) {
      if (!getimagesize($_FILES[$file_field]['tmp_name'])) {
        $out['error'][] = "Uploaded file is not a valid image";
      }
    }

    //Create full filename including path
    if ($random_name) {
      // Generate random filename
      $tmp = str_replace(array('.',' '), array('',''), microtime());

      if (!$tmp || $tmp == '') {
        $out['error'][] = "File must have a name";
      }
      $newname = $tmp.'.'.$ext;
    } else {
        $newname = $name.'.'.$ext;
    }

    //Check if file already exists on server
    if (file_exists($path.$newname)) {
      $out['error'][] = "A file with this name already exists";
    }

    if (count($out['error'])>0) {
      //The file has not correctly validated
      return $out;
    }

    if (move_uploaded_file($_FILES[$file_field]['tmp_name'], $path.$newname)) {
      //Success
      $out['filepath'] = $path;
      $out['filename'] = $newname;
      return $out;
    } else {
      $out['error'][] = "Server Error!";
    }

     } else {
      $out['error'][] = "No file uploaded";
      return $out;
     }
    }


    if (isset($_POST['submit'])) {
     $file = uploadFile('file', true, true);
     if (is_array($file['error'])) {
      $message = '';
      foreach ($file['error'] as $msg) {
      $message .= '<p>'.$msg.'</p>';
     }
    } else {
     $message = "File uploaded successfully".$newname;
    }
     echo $message;
    }

?>
  </body>
</html>

Почему Corb блокирует изображение, которое я пытаюсь загрузить?Что можно сделать, чтобы решить эту проблему?Есть идеи?

1 Ответ

0 голосов
/ 09 июля 2019

попробуйте добавить

header("Access-Control-Allow-Origin: *");

после открытия тега php и перед всем остальным. это должно разрешить доступ "везде" (*)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...