Я пытаюсь загрузить файл с моего локального сервера на безбумажный 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
Кемеровские программисты php общаются здесь
1746128997
Anonymous
Я пытаюсь загрузить файл с моего локального сервера на безбумажный 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, является неверным, или метод, который я использую для извлечения, не поддерживается.>
Подробнее здесь: [url]https://stackoverflow.com/questions/78808960/how-to-post-a-file-to-paperless-ngx-api-with-csrf-token-and-basic-authentication[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия