Не удается загрузить файл iPhone из браузера на белый экран

Кто-нибудь испытывал / преодолевал проблемы с загрузкой файлов через браузер на iPhone?

У меня есть простая форма, которая принимает имя, электронную почту и вложение фотографий, отправляя их через почтовую функцию PHP при отправке, и она прекрасно работает на Android и в настольных браузерах.

<input id="selectPhotoInput" type="file" name="uploaded_file"  accept="image/*">

Однако на iPhone, когда вы выбираете фотографию из рулона камеры, она просто выводит вас на пустой белый экран, оставляя вам только возможность вернуться назад / начать все сначала.

В первом выпуске iOS8 была задокументированная ошибка, когда Safari не поддерживал загрузку файлов, но это происходит во многих браузерах, и эта ошибка была исправлена ​​несколько месяцев назад.

Любая помощь приветствуется.
введите описание изображения здесь

Изменить: Включая мой код PHP, хотя я не думаю, что это является причиной проблемы, так как я даже не могу добраться до точки, где я отправляю / вызываю этот файл.

<?php
// Pear library includes
// You should have the pear lib installed
include_once('Mail.php');
include_once('Mail/mime.php');

//Settings
$max_allowed_file_size = 3000; // size in KB
$allowed_extensions = array("jpg", "jpeg", "gif", "bmp", "png");
$upload_folder = './uploads/'; //<-- this folder must be writeable by the script
$your_email = 'redacted';//

$errors ='';

if(isset($_POST['submit']))
{
//Get the uploaded file information
$name_of_uploaded_file =  basename($_FILES['uploaded_file']['name'].$name);

//get the file extension of the file
$type_of_uploaded_file = substr($name_of_uploaded_file,
strrpos($name_of_uploaded_file, '.') + 1);$size_of_uploaded_file = $_FILES["uploaded_file"]["size"]/1024;///------------Do Validations-------------
if(empty($_POST['name'])||empty($_POST['email']))
{
$errors .= "\n Name and Email are required fields. ";
}
if(IsInjected($visitor_email))
{
$errors .= "\n Bad email value!";
}

if($size_of_uploaded_file > $max_allowed_file_size )
{
$errors .= "\n Size of file should be less than $max_allowed_file_size";
}
//------ Validate the file extension -----
$allowed_ext = false;
for($i=0; $i<sizeof($allowed_extensions); $i++)
{
if(strcasecmp($allowed_extensions[$i],$type_of_uploaded_file) == 0)
{
$allowed_ext = true;
}
}

if(!$allowed_ext)
{
$errors .= "\n The uploaded file is not supported file type. ".
" Only the following file types are supported: ".implode(',',$allowed_extensions);
}
//send the email
if(empty($errors))
{
//copy the temp. uploaded file to uploads folder
$path_of_uploaded_file = $upload_folder . $name_of_uploaded_file;
$tmp_path = $_FILES["uploaded_file"]["tmp_name"];

if(is_uploaded_file($tmp_path))
{
if(!copy($tmp_path,$path_of_uploaded_file))
{
$errors .= '\n error while copying the uploaded file';
}
}

//send the email
$name = $_POST['name'];
$visitor_email = $_POST['email'];
$phone = $_POST['phone'];
$user_message = $_POST['message'];
$to = "redacted@gmail.com";
$subject="TicketSharks: Fresh blood! ($name)";
$from = $your_email;
$text = "$user_message";

$msg_body = "Name: " . $name ."<br>";
$msg_body .= "Phone: " . $phone ."<br>";
$msg_body .= "Email: " . $visitor_email ."<br>";
$msg_body .= "Message: " . $text ."<br>";

$message = new Mail_mime();
$message->setTXTBody($msg_body);
$message->addAttachment($path_of_uploaded_file);
$body = $message->get();
$extraheaders = array("From"=>$from, "Subject"=>$subject,"Reply-To"=>$visitor_email);
$headers = $message->headers($extraheaders);
header('Location: thank-you.html');
$mail = Mail::factory("mail");
$mail->send($to, $headers, $body);
//redirect to 'thank-you page
}

1

Решение

Ваши HTML-коды содержат логические ошибки.

Любой тег кнопки без type="button" будет рассматриваться как кнопка «Отправить», которая действует так же, как указано ниже:

<input type="submit" value="Submit" />

Таким образом, чтобы решить вашу проблему, вы должны добавить type="button" на твоем фото кнопки (как минимум 2 кнопки я заметил).

<button id="choosePhoto" type="button">Take photo</button>
1

Другие решения

Других решений пока нет …