forked from Drunyacoder/AtomXCMS-2
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathimg_uploader.php
43 lines (37 loc) · 1.49 KB
/
img_uploader.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
<?php
include_once 'sys/boot.php';
// Проверка доступа. Этот скрипт должен быть доступен только из панели администратора
session_start(); // Убедитесь, что сессия инициализирована
if (empty($_SESSION['adm_panel_authorize']) ||
$_SESSION['adm_panel_authorize'] < time() ||
empty($_SESSION['user'])
) {
die('Access denied');
} else {
$_SESSION['adm_panel_authorize'] = time() + Config::read('session_time', 'secure');
}
// Папка для хранения файлов
$dir = ROOT . '/sys/files/pages/';
if (!file_exists($dir)) {
mkdir($dir, 0777, true);
}
// Проверка типа файла
$allowed_types = ['image/png', 'image/jpg', 'image/jpeg', 'image/gif', 'image/pjpeg'];
$file_type = strtolower($_FILES['file']['type']);
if (in_array($file_type, $allowed_types)) {
// Установка уникального имени файла
$filename = md5(date('YmdHis') . uniqid('', true)) . '.jpg';
$file = $dir . $filename;
// Копирование файла
if (move_uploaded_file($_FILES['file']['tmp_name'], $file)) {
// Отображение ссылки на файл
$response = [
'filelink' => WWW_ROOT . '/sys/files/pages/' . $filename,
];
echo json_encode($response);
} else {
echo json_encode(['error' => 'File upload failed']);
}
} else {
echo json_encode(['error' => 'Invalid file type']);
}