Potrzebuję twojej pomocy, aby załadować obraz medialny na moim blogu wordpress poprzez uwierzytelnianie Wp-rest-api v2 i Oauth2.
W dokumentacji interfejsu API REST nie znalazłem sposobu na przesłanie danych obrazu (nazwa pola, tryb wysyłania ...?).
require('OAuth2/Client.php');
require('OAuth2/GrantType/IGrantType.php');
require('OAuth2/GrantType/AuthorizationCode.php');
const CLIENT_ID = 'XXX';
const CLIENT_SECRET = 'XX';
const REDIRECT_URI = 'http://127.0.0.1/test_api_wp/test.php';
const AUTHORIZATION_ENDPOINT = 'http://wordpress.local/oauth/authorize';
const TOKEN_ENDPOINT = 'http://wordpress.local/oauth/token';
$client = new OAuth2\Client(CLIENT_ID, CLIENT_SECRET);
if (!isset($_GET['code']))
{
$auth_url = $client->getAuthenticationUrl(AUTHORIZATION_ENDPOINT, REDIRECT_URI);
header('Location: ' . $auth_url);
die('Redirect');
}
else
{
$params = array('code' => $_GET['code'], 'redirect_uri' => REDIRECT_URI);
$response = $client->getAccessToken(TOKEN_ENDPOINT, 'authorization_code', $params); //authorization_code
$token = $response['result']['access_token'];
$client->setAccessToken($token);
$client->setAccessTokenType(OAuth2\Client::ACCESS_TOKEN_BEARER);
}
$values = array(
"date" => "2015-11-26 10:00:00",
"date_gmt" => "2015-11-26 09:00:00",
"modified" => "2015-11-26 10:00:00",
"modified_gmt" => "2015-11-26 09:00:00",
"status" => "future",
"title" => "Titre media",
"description" => "description media",
"media_type" => "image",
"source_url" => "https://www.base64-image.de/build/img/mr-base64-482fa1f767.png"
);
$data = $client->fetch("wordpress.local/wp-json/wp/v2/media", $values, "POST");
echo "<pre>";print_r($data);echo "</pre>";
Odpowiedź :
Array
(
[result] => Array
(
[code] => rest_upload_no_data
[message] => No data supplied
[data] => Array
(
[status] => 400
)
)
[code] => 400
[content_type] => application/json; charset=UTF-8
)
Dowolny pomysł? Wielkie dzięki
;
wwordpress.local/wp-json/wp/v2/media";
to się tu błędnie albo jest w prawdziwym kodzie też?source_url
powinieneś być wpost
obiekcie.Odpowiedzi:
WIĘC! To jest fajne.
Należy pamiętać, że WP-API jest wciąż bardzo, bardzo w toku.
Dyspozycja treści
Znalazłem problem zgłoszony w kolejce problemów WP-API dotyczący Content-Disposition. Jest to wymagany nagłówek do publikowania nowych treści medialnych i istnieją bardzo, bardzo surowe wymagania, jeśli chodzi o udostępnianie tego w odpowiednim formacie.
Cel utworzenia medialnego punktu końcowego
Po pierwsze, cofnijmy się o krok. Interfejs API zakłada, że w tym momencie przesłałeś już nowy plik do właściwego katalogu. Ten punkt końcowy tworzy zawartość multimedialną w bazie danych, która odwołuje się do tego pliku.
Rozwiązanie
Musisz podać nazwę pliku multimedialnego, aby powiązać go z nową treścią. To nie może być zdalny adres URL. Jak widać z dokumentacji v2 ,
source_url
ilink
są tylko do odczytu. Aby pomyślnie przesłać nową treść, musisz tylko dodać do nagłówka:Jak wspomniano w zgłoszeniu, nie można dodawać ofert ani określać metody wysyłania pliku. To musi być w formacie powyżej. Przynajmniej tak jest, dopóki nie zmienią tego dookoła.
Upewnij się, że typ pliku jest jednym z akceptowanych typów plików i że dołączasz rozszerzenie pliku zawarte w żądaniu. Dzięki dr Deo w komentarzach.
Dla przypomnienia, roześmiałem się z zawrotną radością, kiedy w końcu zorientowałem się, że ... przestraszyłem moją żonę.
źródło
Content-Disposition
!Sorry, this file type is not permitted for security reasons
curl --request POST --url http://localhost/kayinjaproject/wp-json/wp/v2/media --header "cache-control: no-cache" --header "content-disposition: attachment; filename=tmp.png" --header "authorization: Basic cm9vdDppYW1haGVybw==" --header "content-type: image/png" --data-binary "@c:/gnu/png.png" --location
ale jeśli pominieszpng
nazwę plikutmp.png
, otrzymaszerror sorry, this file type is not permitted for security reasons
Ze względu na „odsyłacze” zobacz moją pokrewną odpowiedź tutaj na StackOverflow dotyczącą przesyłania multimediów i używania tych mediów jako „polecanych mediów” dla postu.
źródło