Отправка файлов метода POST на сервер отсутствует. Мне кажется, что некоторые люди избегают необходимости скрипта для «разбора» файла, однако, как я понимаю POST, файл должен быть POST и скопирован на сервер apache, даже если я ничего с ним не делаю, правильно?
Я пробовал многочисленные решения от изменения .htaccess, php.ini и apache2.conf.
В настоящее время у меня есть
apache2.conf
<Directory /var/www/>
<IfModule mod_rewrite.c>
RewriteEngine On
RewriteCond %{REQUEST_FILENAME}.php -f
RewriteRule (.*) $1.php [L]
RewriteCond %{REQUEST_FILENAME}.xml -f
RewriteRule (.*) $1.xml [L]
</IfModule>
Options FollowSymLinks
AllowOverride All
Require all granted
</Directory>
.htaccess
DirectorySlash Off
php.ini (upload_tmp_dir не обязательно указывать полный путь или из корня сети. Я также прочитал, чтобы поместить его в кавычки)
file_uploads = On
upload_tmp_dir = /var/www/html/eSCL/ScanJobs
Корневой веб-каталог - / var / www / html. Я хочу загрузить в / var / www / html / eSCL / ScanJobs Права доступа к папке заданий на сканирование - 777 Владелец www-данных (подходит для ubuntu)
Ошибки из 2 постов - 404, один - CURL для тестирования, другой - приложение Mopria Android для сканирования.
CURL
curl -v -X POST -d @scansettings.xml
http://localhost:80/eSCL/ScanJobs
Note: Unnecessary use of -X or --request, POST is already inferred.
* Trying 127.0.0.1...
* Connected to localhost (127.0.0.1) port 80 (#0)
> POST /eSCL/ScanJobs HTTP/1.1
> Host: localhost
> User-Agent: curl/7.47.0
> Accept: */*
> Content-Length: 605
> Content-Type: application/x-www-form-urlencoded
>
* upload completely sent off: 605 out of 605 bytes
< HTTP/1.1 404 Not Found
< Date: Thu, 16 May 2019 17:14:32 GMT
< Server: Apache/2.4.18 (Ubuntu)
< Content-Length: 286
< Content-Type: text/html; charset=iso-8859-1
<
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN">
<html><head>
<title>404 Not Found</title>
</head><body>
<h1>Not Found</h1>
<p>The requested URL /eSCL/ScanJobs was not found on this server.
</p>
<hr>
<address>Apache/2.4.18 (Ubuntu) Server at localhost Port 80</address>
</body></html>
* Connection #0 to host localhost left intact
Запись в журнале Apache для вышеуказанного запроса CURL
127.0.0.1 - - [16/May/2019:12:14:32 -0500] "POST /eSCL/ScanJobs HTTP/1.1" 404 447 "-" "curl/7.47.0"
в журнале Apache с использованием Mopria (включая успешные попадания)
192.168.0.8 - - [16/May/2019:12:17:59 -0500] "GET /eSCL/ScannerStatus HTTP/1.1" 200 716 "-" "okhttp/3.9.1"
192.168.0.8 - - [16/May/2019:12:18:04 -0500] "GET /eSCL/ScannerStatus HTTP/1.1" 200 715 "-" "okhttp/3.9.1"
192.168.0.8 - - [16/May/2019:12:18:09 -0500] "GET /eSCL/ScannerStatus HTTP/1.1" 200 715 "-" "okhttp/3.9.1"
192.168.0.8 - - [16/May/2019:12:18:13 -0500] "GET /eSCL/ScannerCapabilities HTTP/1.1" 200 1389 "-" "okhttp/3.9.1"
192.168.0.8 - - [16/May/2019:12:18:13 -0500] "GET /eSCL/ScannerStatus HTTP/1.1" 200 715 "-" "okhttp/3.9.1"
192.168.0.8 - - [16/May/2019:12:18:16 -0500] "GET /eSCL/ScannerStatus HTTP/1.1" 200 716 "-" "okhttp/3.9.1"
192.168.0.8 - - [16/May/2019:12:18:20 -0500] "GET /eSCL/ScannerCapabilities HTTP/1.1" 200 1389 "-" "okhttp/3.9.1"
192.168.0.8 - - [16/May/2019:12:18:20 -0500] "GET /eSCL/ScannerStatus HTTP/1.1" 200 715 "-" "okhttp/3.9.1"
192.168.0.8 - - [16/May/2019:12:18:25 -0500] "POST /eSCL/ScanJobs HTTP/1.1" 404 506 "-" "okhttp/3.9.1"
192.168.0.8 - - [16/May/2019:12:18:25 -0500] "GET /eSCL/ScannerStatus HTTP/1.1" 200 715 "-" "okhttp/3.9.1"
192.168.0.8 - - [16/May/2019:12:18:30 -0500] "GET /eSCL/ScannerStatus HTTP/1.1" 200 715 "-" "okhttp/3.9.1"
192.168.0.8 - - [16/May/2019:12:18:35 -0500] "GET /eSCL/ScannerStatus HTTP/1.1" 200 715 "-" "okhttp/3.9.1"
Всего 1 ответ
Корнем вашего документа является / var / www /, но я думаю, что это должно быть / var / www / html.
Кроме того, запрос curl для проверки
curl -v -F "file=@img.jpg" http: //localhost/index.php
И, конечно же, загруженный файл временно помещается в
/ Вар / WWW / HTML / ESCL / ScanJobs /
так что вы должны переместить его с
move_uploaded_file ($ file_tmp, "ESCL /".$ имя_файла);
или любую папку, которую вы хотите.
Проверьте мою конфигурацию ниже, код ответа 200 от curl и print_r ($ _ FILES), где вы видите временный путь к загружаемому файлу.
<Directory /var/www/html/>
<IfModule mod_rewrite.c>
RewriteEngine On
RewriteCond %{REQUEST_FILENAME}.php -f
RewriteRule (.*) $1.php [L]
RewriteCond %{REQUEST_FILENAME}.xml -f
RewriteRule (.*) $1.xml [L]
</IfModule>
Options FollowSymLinks
AllowOverride All
Require all granted
</Directory>
curl -v -F "file=@img.jpg" http://localhost/index.php
* Trying 127.0.0.1...
* TCP_NODELAY set
* Connected to localhost (127.0.0.1) port 80 (#0)
> POST /index.php HTTP/1.1
> Host: localhost
> User-Agent: curl/7.58.0
> Accept: */*
> Content-Length: 1238948
> Content-Type: multipart/form-data; boundary=------------------------98473343d22dab8a
> Expect: 100-continue
>
< HTTP/1.1 100 Continue
< HTTP/1.1 200 OK
< Date: Thu, 16 May 2019 21:29:01 GMT
< Server: Apache/2.4.29 (Ubuntu)
< Vary: Accept-Encoding
< Content-Length: 282
< Content-Type: text/html; charset=UTF-8
<
Array
(
[file] => Array
(
[name] => img.jpg
[type] => image/jpeg
[tmp_name] => /var/www/html/eSCL/ScanJobs/phpZBF3Cc
[error] => 0
[size] => 1238763
)
)
test
* Connection #0 to host localhost left intact