Почему мои файлы POSTed не попадают на сервер? - PullRequest
0 голосов
/ 16 мая 2019

Отправка файлов метода 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 Ответ

0 голосов
/ 17 мая 2019

Ваш корень документа - / 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
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...