конвертировать curl в жрет для spreedly API

Я пытаюсь преобразовать этот вызов curl в жрет:

curl https://core.spreedly.com/v1/gateways/CAL6uXHtGfDsxV2kW6apTP5JhG/purchase.xml \
-u 'Ll6fAtoVY5hTGlJEmtpo5YTS:RKOCG5D8jhgfdDSg524u5iF22XD4Io5VXmyzdCptrvHFTTSy' \
-H 'Content-Type: application/xml' \
-d '<transaction>
<payment_method_token>ZgPNHes541EMlBN86glRDKRexzq</payment_method_token>
<amount>100</amount>
<currency_code>USD</currency_code>
</transaction>'

Я знаю, использовать это так много, поэтому любая помощь будет оценена

Это то, что я пробовал, но я всегда получаю эту ошибку
[код состояния] 422
[фраза разума] Unprocessable Entity «

$xml =  '<transaction>\n';
$xml .=     '<payment_method_token>$payment_method_token</payment_method_token>\n';
$xml .=     '<amount>100</amount>\n';
$xml .=     '<currency_code>USD</currency_code>\n'
$xml .= '<transaction>\n';
$headers = ['Content-Type' => 'application/xml', 'auth' => ['Ll6fAtoVY5hTGlJEmtpo5YTS', 'RKOCG5D8jhgfdDSg524u5iF22XD4Io5VXmyzdCptrvHFTTSy']];
$client = new Client('https://core.spreedly.com/v1/gateways/CAL6uXHtGfDsxV2kW6apTP5JhG/purchase.xml');
$requestCurl = $client->post('', $headers, $xml,[]);
$response = $requestCurl->send()->xml();
dd($response);

Спасибо!

1

Решение

Это должно выглядеть примерно так:

$client = new Client('https://core.spreedly.com/v1/gateways/merchant_id');

$xml = '<...>';
$options = [
'headers'   => [ 'Content-Type' => 'application/xml' ],
'auth'      => ['username', 'password'],
'body'      => $xml,
];

$response = $client->post('/purchase.xml', $options);

и вы, возможно, захотите еще раз взглянуть на свой код и выяснить, случайно ли вы опубликовали свои учетные данные API.

2

Другие решения

Если вы ссылаетесь на Документы Guzzle для работы с клиенты вы увидите, что вы можете установить base_url, заголовки и аутентификацию для всех запросов, сделанных с клиентом.

Разница между моим примером ниже и примером Sammitch заключается в том, что я добавил заголовок и аутентификацию по умолчанию для клиента. Это позволит вам совершать последующие вызовы к вашему API без необходимости добавлять их в качестве опций для каждого запроса.

В целях устранения неполадок я просто присоединяю LogSubscriber, чтобы http запрос и ответ были легко доступны.

$client = new GuzzleHttp\Client([
'base_url' => ['https://core.spreedly.com/{version}/gateways/{merchant_id}/', [
'version' => 'v1',
'merchant_id' => $merchant_id
]],
'defaults' => [
'headers'       => ['Content-Type' => 'application/xml'],
'auth'          => [$username, $pw],
]]);
/**
* Attach a log subscriber is configured to log the full request and response message using echo() calls.
**/
$client->getEmitter()->attach(new GuzzleHttp\Subscriber\Log\LogSubscriber(null, GuzzleHttp\Subscriber\Log\Formatter::DEBUG));

$response = $client->post('purchase.xml', [
'body' => $xml
]);
0

По вопросам рекламы [email protected]