Gigya PHP Sdk - Уведомления о комментариях

0

Я пытаюсь использовать функцию уведомления о комментариях Gigya, и я выполнил следующие рекомендации: http://developers.gigya.com/010_Developer_Guide/18_Plugins/022_Comments_Version_2/Comment_Notifications

Я разработал следующий код:

<?php

    require_once('GSSDK.php');

    $event = $_POST['event'];
    $eventData = $_POST['eventData'];
    $nonce = $_POST['nonce'];
    $timestamp = $_POST['timestamp'];
    $signature = $_POST['signature'];
    $signatureBase = sprintf("%s_%s_%s_%s", $event, $eventData, $nonce, $timestamp);
    $expectedSignature = SigUtils::calcSignature(
        $signatureBase,
        MY_SECRET_KEY);

    if($signature !== $expectedSignature) {
        header('HTTP/1.0 403 Forbidden');
        die();
    }

    //Some other stuff
    exit();

?>

Но он никогда не попадает в часть "//Некоторые другие вещи". Всегда ожидаемая подпись отличается от подписи, предоставленной сервером Gigya. Что я делаю не так?

Теги:
comments
sdk
hmacsha1
gigya

1 ответ

0
Лучший ответ

Вместо этого попробуйте использовать следующий код:

<?php

  static function calcSignature($baseString,$key)
  {
    $baseString = utf8_encode($baseString);
    $rawHmac = hash_hmac("sha1", utf8_encode($baseString), base64_decode($key), true);
    $sig = base64_encode($rawHmac); 
    return $sig;
  }

  function checkSignature() 
  {
    $event = $_POST["event"];
    $eventData = $_POST["eventData"];
    $nonce = $_POST["nonce"];
    $timestamp = $_POST["timestamp"];
    $signature = $_POST["signature"];

    $signatureBase = $event . "_" . $eventData . "_" . $nonce . "_" . $timestamp;
    $secret = "[your gigya secret key]";
    $expectedSignature = calcSignature($signatureBase, $secret);        

    // Now compare the expectedSignature value to the signature value returned in the callback
    if ($signature !== $expectedSignature) 
    {
      header('HTTP/1.0 403 Forbidden');
      die();
    }
  }

  checkSignature();
  //Some other stuff
  exit();
?>

Этот код удаляет зависимость от GigyaSDK только для проверки подписи. Предоставленный метод - это тот же самый метод, который использует GigyaSDK, но преимущество здесь в том, что это намного меньший объем памяти, поскольку весь GigyaSDK не нужно загружать.

Кроме того, я не уверен, было ли это намеренно, но в вашем сравнении есть код:

if(!$signature !== $expectedSignature) {

Вместо:

if ($signature !== $expectedSignature) {

Я не совсем уверен, что цель постороннего логического-NOT-оператора на $ signature должна выполнить, но похоже, что это приведет к неожиданному поведению.

  • 0
    Джей, я проверил твоё решение, но оно не работает. Полезная нагрузка поступает в переменные $ _POST, в $ _GET ничего нет. Да, действительно (!$signature !== было опечаткой. Я исправил это в коде ссылки и все еще не работает. Сигнатура, генерируемая calcSignature, отличается от подписи, поступающей в запросе (поле POST "signature") )
  • 0
    Если вы позволите мне, я могу отправить вам по электронной почте последние полезные данные, которые я получил, и вы можете проверить это. Также мне понадобится ваша электронная почта :)
Показать ещё 3 комментария

Ещё вопросы

Сообщество Overcoder
Наверх
Меню