Я пытаюсь загрузить файл с моего локального сервера на безбумажный API NGX с помощью PHP. API требует токена CSRF и базовой аутентификации для запроса POST. Тем не менее, у меня возникают проблемы с получением токена CSRF и успешного выполнения запроса. Вот код, который я написал до сих пор: < /p>
Получение токена CSRF: < /li>
< /ol>
$apiUrl = 'http://hostname:8000/api/documents/post_document/';
$filePath = '/path/to/file.pdf';
$username = 'username';
$password = 'password';
function getCsrfToken($apiUrl, $username, $password) {
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $apiUrl);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HEADER, true);
curl_setopt($ch, CURLOPT_NOBODY, true);
curl_setopt($ch, CURLOPT_USERPWD, "$username:$password");
$response = curl_exec($ch);
$headers = [];
$header_text = substr($response, 0, curl_getinfo($ch, CURLINFO_HEADER_SIZE));
foreach (explode("\r\n", $header_text) as $i => $line) {
if ($i === 0) {
$headers['http_code'] = $line;
} else {
list ($key, $value) = explode(': ', $line);
$headers[$key] = $value;
}
}
curl_close($ch);
return $headers['X-CSRFToken'] ?? null;
}
$csrfToken = getCsrfToken($apiUrl, $username, $password);
if (!$csrfToken) {
die('CSRF-Token could not be retrieved');
}
< /code>
Загрузка файла: < /li>
< /ol>
$ch = curl_init();
$file = new CURLFile($filePath);
$postData = [
'document' => $file
];
curl_setopt($ch, CURLOPT_URL, $apiUrl);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, $postData);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_USERPWD, "$username:$password");
curl_setopt($ch, CURLOPT_HTTPHEADER, [
'X-CSRFToken: ' . $csrfToken,
'Content-Type: multipart/form-data'
]);
$response = curl_exec($ch);
$httpCode = curl_getinfo($ch, CURLINFO_HTTP_CODE);
curl_close($ch);
if ($httpCode == 201) {
echo 'File uploaded successfully!';
} else {
echo 'Error uploading file: ' . $response;
}
}
uploadFile($apiUrl, $filePath, $csrfToken, $username, $password);
< /code>
Однако, когда я запускаю этот код, я получаю ответ «405 не разрешен» при попытке получить токен CSRF. Я подозреваю, что URL API, который я использую для получения токена CSRF, является неверным, или метод, который я использую для извлечения, не поддерживается.>
Подробнее здесь: https://stackoverflow.com/questions/788 ... entication
Как разместить файл в безбумажный NGX API с токеном CSRF и базовой аутентификацией в PHP? ⇐ Php
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение
-
-
Как отправить файл в Paperless NGX API с токеном CSRF и базовой аутентификацией в PHP?
Anonymous » » в форуме Php - 0 Ответы
- 19 Просмотры
-
Последнее сообщение Anonymous
-
-
-
API ограничения скорости Laravel для пользователя с базовой аутентификацией
Anonymous » » в форуме Php - 0 Ответы
- 29 Просмотры
-
Последнее сообщение Anonymous
-
-
-
Конечная точка API не выполняет проверку токена CSRF в Sanctum – несоответствие токена CSRF
Anonymous » » в форуме Php - 0 Ответы
- 152 Просмотры
-
Последнее сообщение Anonymous
-
-
-
Подключение Python к облачному SQL-серверу с аутентификацией IAM и токеном доступа
Anonymous » » в форуме Python - 0 Ответы
- 18 Просмотры
-
Последнее сообщение Anonymous
-
-
-
Подключение Python к облачному SQL-серверу с аутентификацией IAM и токеном доступа
Anonymous » » в форуме Python - 0 Ответы
- 19 Просмотры
-
Последнее сообщение Anonymous
-