Есть скрипт отправки формы, все работало, но стал выдавать ошибку "Ошибка, доступ запрещен! Свяжитесь с нами другим способом, пожалуйста"
В чем может быть причина?
<?php
// константы
$To = "";
$From = "";
$Sender = "";
$Subject = "Заказ с сайта";
$Success = "Мы получили Ваше сообщение и свяжемся с Вами в ближайшее время";
$Error = "Ошибка. Вы забыли заполнить все обязательные поля";
//$PrivacyError = "Ошибка. Вы забыли согласиться с политикой конфиденциальности.";
$MailError = "Ошибка почтового сервера. Сообщение не отправлено. Свяжитесь с нами другим способом, пожалуйста";
$AccessError = "Ошибка, доступ запрещен! Свяжитесь с нами другим способом, пожалуйста";
$FileError = "Ошибка! Не удалось загрузить файл на сервер!";
$FileDir = '/home/c/ct16307/site.ru/public_html/files/';
$ErrorDownload = "Ошибка. Файл не загружен";
$MIMEError = "Ошибка. Загружать можно только документы (doc, xls, pdf) и изображения (jpg, png, gif).";
// список разрешенных MIME-типов
$AllowedMIME = array(
'image/jpeg',
'image/png',
'image/gif',
'application/msword',
'application/vnd.ms-excel',
'application/excel',
'application/x-msexcel',
'application/x-excel',
'application/pdf',
'application/vnd.oasis.opendocument.spreadsheet',
'application/vnd.oasis.opendocument.text');
// очистка ввода
function clean($value = "") {
$value = trim($value);
$value = stripslashes($value);
$value = strip_tags($value);
$value = htmlspecialchars($value);
return $value;
}
// транслит
function rus2translit($string) {
$converter = array(
'а' => 'a', 'б' => 'b', 'в' => 'v',
'г' => 'g', 'д' => 'd', 'е' => 'e',
'ё' => 'e', 'ж' => 'zh', 'з' => 'z',
'и' => 'i', 'й' => 'y', 'к' => 'k',
'л' => 'l', 'м' => 'm', 'н' => 'n',
'о' => 'o', 'п' => 'p', 'р' => 'r',
'с' => 's', 'т' => 't', 'у' => 'u',
'ф' => 'f', 'х' => 'h', 'ц' => 'c',
'ч' => 'ch', 'ш' => 'sh', 'щ' => 'sch',
'ь' => '\'', 'ы' => 'y', 'ъ' => '\'',
'э' => 'e', 'ю' => 'yu', 'я' => 'ya',
'А' => 'A', 'Б' => 'B', 'В' => 'V',
'Г' => 'G', 'Д' => 'D', 'Е' => 'E',
'Ё' => 'E', 'Ж' => 'Zh', 'З' => 'Z',
'И' => 'I', 'Й' => 'Y', 'К' => 'K',
'Л' => 'L', 'М' => 'M', 'Н' => 'N',
'О' => 'O', 'П' => 'P', 'Р' => 'R',
'С' => 'S', 'Т' => 'T', 'У' => 'U',
'Ф' => 'F', 'Х' => 'H', 'Ц' => 'C',
'Ч' => 'Ch', 'Ш' => 'Sh', 'Щ' => 'Sch',
'Ь' => '\'', 'Ы' => 'Y', 'Ъ' => '\'',
'Э' => 'E', 'Ю' => 'Yu', 'Я' => 'Ya',
);
return strtr($string, $converter);
}
// формируем урл
function str2url($str) {
// переводим в транслит
$str = rus2translit($str);
// в нижний регистр
$str = strtolower($str);
// заменям все ненужное нам на "-"
$str = preg_replace('~[^-a-z0-9._]+~u', '-', $str);
// удаляем начальные и конечные '-'
$str = trim($str, "-");
return $str;
}
// проверяем заголовки: ajax?
if(isset($_SERVER['HTTP_X_REQUESTED_WITH']) && !empty($_SERVER['HTTP_X_REQUESTED_WITH']) && strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) == 'xmlhttprequest') {
// получаем данные
$Subject = '=?utf-8?b?'. base64_encode($Subject) .'?=';
$Name = clean($_POST['name']);
$Tel = clean($_POST['tel']);
$Email = clean($_POST['email']);
$Text = clean($_POST['msg']);
$Length = clean($_POST['length']);
$Width = clean($_POST['width']);
$Type = clean($_POST['type']);
$Weight = clean($_POST['weight']);
$Page = $_SERVER['HTTP_REFERER'];
$Message ='';
$Privacy = clean($_POST['privacy']);
// формируем сообщение
// проверяем на заполнение
if ( ( ($Tel == '') and ($Email == '') ) or ($Privacy != 'on') ){
exit($Error);
}
$Headers = "Content-type: text/plain; charset=\"utf-8\"\r\n";
$Headers .= "From: ".$Sender."<". $From .">\r\n";
$Headers .= "MIME-Version: 1.0\r\n";
$Headers .= "Date: ". date('D, d M Y h:i:s O') ."\r\n";
if ($Name) $Message .= "Имя: ".$Name."\r\n";
if ($Tel) $Message .= "Телефон: ".$Tel."\r\n";
if ($Email) $Message .= "Email: ".$Email."\r\n";
if ($Length) $Message .= "Длина: ".$Length."\r\n";
if ($Width) $Message .= "Ширина: ".$Width."\r\n";
if ($Type) $Message .= "Тип ленты: ".$Type."\r\n";
if ($Weight) $Message .= "Нагрузка на метр ленты: ".$Weight."\r\n";
if ($Text) $Message .= "Сообщение: ".$Text."\r\n";
if ($_FILES['file']['name']) {
// если загрузка файла не удалась — выход
if ($_FILES['file']['error'] != UPLOAD_ERR_OK){
exit($ErrorDownload. "Код:". UPLOAD_ERR_OK);
}
// если NIME-тип не соответствует разрешенным - выход
$file_mime = mime_content_type($_FILES['file']['tmp_name']);
if( ! in_array( $file_mime, $AllowedMIME ) ) {
exit($MIMEError);
}
$filename = str2url($_FILES['file']['name']);
$filepath = $FileDir.$filename;
//echo $_FILES['file']['name'];
// переносим файл из временной директории и формируем ссылку на него
if (move_uploaded_file($_FILES['file']['tmp_name'], $filepath))
{
// echo "Файл успешно загружен на сервер";
$Message .= "Файл: ht"."t"."p://konveery.ru/files/".$filename."\r\n";
// echo $Message;
}
else
{
exit($FileError);
}
}
if ($Page) $Message .= "Страница: ".$Page."\r\n";
// отправляем
$Send = mail ($To,$Subject,$Message,$Headers);
if ($Send){
exit($Success);
}
else{
exit($MailError);
}
}
exit($AccessError); //не ajax*/