Мой вопрос заключается в том, как прочитать информацию заголовка с php, полученные с другого сайта. (Я использую patreon webhooks)
На странице документации написано:
Когда происходит одно из этих событий, наши серверы отправляют HTTP-запрос POST на указанный вами URL-адрес. Этот HTTP POST будет содержать соответствующие данные от действия пользователя в формате JSON. Он также будет иметь заголовки
X-Patreon-Event:
<trigger>
X-Patreon-Signature:
<message signature>
где подпись сообщения — это тело JSON POST, подписанное HMAC (с помощью MD5) с помощью client_secret
Это мой код:
<?php
logData("asd");
$headers = getallheaders();
$X_Patreon_Event = $headers['X-Patreon-Event'];
$X_Patreon_Signature = $headers['X-Patreon-Signature'];
logMusic(json_decode($X_Patreon_Event));
logMusic(json_decode($X_Patreon_Signature));
function logData($str){
$url = '/var/www/websitelog.txt';
$current = "$str\n";
file_put_contents($url,$current,FILE_APPEND | LOCK_EX);
}
getallheaders
(начиная с PHP 5.4.0) вернет все заголовки в виде ассоциативного массива …
$headers = getallheaders();
…что вы сможете проверить, чтобы получить нужные значения заголовков
$X_Patreon_Event = $headers['X-Patreon-Event'];
$X_Patreon_Signature = $headers['X-Patreon-Signature'];
Примечание: getallheaders()
функция может быть недоступна (например, если ваш веб-сервер nginx). В этом случае вы всегда можете заново реализовать функцию с небольшим фрагментом кода: Получить заголовки http из текущего запроса в PHP
У меня есть полностью рабочая страница webhooks с использованием php и mysqli, надеюсь, это поможет
ПРИМЕЧАНИЕ ** вам нужно php 5.6>, чтобы это работало
MySQL таблицы БД, необходимые для моей реализации
/ **
— Структура стола для посетителей стола
CREATE TABLE IF NOT EXISTS patrons (
patron_key bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'key to row',
patron_id tinytext NOT NULL COMMENT 'patron id',
patron_fullname tinytext NOT NULL COMMENT 'fullname',
patron_firstname tinytext NOT NULL,
patron_lastname tinytext NOT NULL,
patron_email tinytext NOT NULL,
patron_image_url tinytext NOT NULL,
patron_pledge bigint(20) NOT NULL,
patron_list tinyint(4) NOT NULL COMMENT 'include in patrons honour list',
patron_decline tinytext,
PRIMARY KEY (patron_key)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;
—
— Структура таблицы для уведомлений таблицы
CREATE TABLE IF NOT EXISTS notifications (
notification_id bigint(20) NOT NULL AUTO_INCREMENT,
notification_type tinytext NOT NULL,
notification text NOT NULL,
notification_action int(11) NOT NULL,
notification_date tinytext NOT NULL,
notification_archived tinytext NOT NULL,
PRIMARY KEY (notification_id)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=1401 ;
* /
$secret_webhook_id = "your-secret-key-here";
/** get the headers */
$headers = getallheaders();
$X_Patreon_Event = $headers['X-Patreon-Event'];
$X_Patreon_Signature = $headers['X-Patreon-Signature'];
/** get the json body */
$body = @file_get_contents("php://input");
/** get json body as array */
$patron_data = json_decode($body, true);
/** compute an md5 hash using the body and your secret key */
$signature = hash_hmac('md5', $body, $secret_webhook_id);
/** Timing attack safe string comparison */
if (hash_equals ($X_Patreon_Signature, $signature)){
/** get the data from the json array - look for errors*/
if (isset($patron_data['included']) && isset($patron_data['data'])) {
$data = $patron_data['data'];
$declined = $data['attributes']['declined_since'];
/** stored as a string*/
$declined = is_null($declined) ? "":$declined;
$included = $patron_data['included'];
$patron_id = $included[0]['id'];
$patron_full_name = $included[0]['attributes']['full_name'];
$patron_firstname = $included[0]['attributes']['first_name'];
$patron_lastname = $included[0]['attributes']['last_name'];
$patron_email = $included[0]['attributes']['email'];
$patron_image_url = $included[0]['attributes']['image_url'];
$pledge = $included[1]['attributes']['amount_cents'];
/** select event for db insert/update/delete*/
switch ($X_Patreon_Event){
case "pledges:create":
$sql = "INSERT INTO patrons SET patron_id = ?, patron_fullname = ?, patron_firstname = ?, patron_lastname = ?, patron_email = ?, patron_image_url = ?, patron_pledge = ?, patron_list = 1, patron_decline = ?";
$stmt = $conn->prepare($sql);
$stmt->bind_param("ssssssis", $patron_id, $patron_full_name, $patron_firstname, $patron_lastname, $patron_email, $patron_image_url, $pledge, $declined);
if (!$stmt->execute()) {
/** your_error_routine(__LINE__, __FILE__, $sql, $stmt->error); */
}
break;
case "pledges:update":
$sql = "UPDATE patrons SET patron_fullname = ?, patron_firstname = ?, patron_lastname = ?, patron_email = ?, patron_image_url = ?, patron_pledge = ?, patron_decline = ? WHERE patron_id = ?";
$stmt = $conn->prepare($sql);
$stmt->bind_param("sssssiss", $patron_full_name, $patron_firstname, $patron_lastname, $patron_email, $patron_image_url, $pledge, $declined, $patron_id);
if (!$stmt->execute()) {
/** your_error_routine(__LINE__, __FILE__, $sql, $stmt->error); */
}
break;
case "pledges:delete":
$sql = "DELETE FROM patrons WHERE patron_id = ?";
$stmt = $conn->prepare($sql);
$stmt->bind_param("s", $patron_id);
if (!$stmt->execute()) {
/** your_error_routine(__LINE__, __FILE__, $sql, $stmt->error); */
}
break;
}
/** now update your own admin notifications */
$notification = "Patreon Webhook update for: $patron_full_name - X_Patreon_Event: $X_Patreon_Event";
$sql = "INSERT INTO notifications SET notification_type = 'Patreon', notification = ?, notification_date = ".time();
$stmt = $conn->prepare($sql);
$stmt->bind_param("s", $notification);
if (!$stmt->execute()) {
/** your_error_routine(__LINE__, __FILE__, $sql, $stmt->error); */
}
}
В вашем скрипте напишите:
var_dump($_SERVER);
и вы увидите возвращающиеся переменные. Вы можете получить к ним доступ как к массиву.
Как здесь было сказано, getallheaders () — это то, что вы ищете.
А поскольку это JSON, используйте json_decode () для этих переменных, прочтите руководство по json_decode / encode.