Создание подписи: различия между версиями
Jump to navigation
Jump to search
Ikbot (обсуждение | вклад) |
Ikbot (обсуждение | вклад) |
||
Строка 1: | Строка 1: | ||
+ | <span data-link_translate_pl_title="Generowanie podpisu" data-link_translate_pl_url="Generowanie+podpisu"></span>[[:pl:Generowanie podpisu]][[pl:Generowanie podpisu]] | ||
<span data-link_translate_fr_title="Génération de la signature" data-link_translate_fr_url="G%C3%A9n%C3%A9ration_de_la_signature"></span>[[:fr:Génération de la signature]][[fr:Génération de la signature]] | <span data-link_translate_fr_title="Génération de la signature" data-link_translate_fr_url="G%C3%A9n%C3%A9ration_de_la_signature"></span>[[:fr:Génération de la signature]][[fr:Génération de la signature]] | ||
<br /> | <br /> |
Версия 17:03, 22 октября 2015
pl:Generowanie podpisu
fr:Génération de la signature
Эта статья является результатом автоматического перевода, выполняемого программного обеспечения. Вы можете посмотреть исходный статьи здесь.
Введение
Во время вызова API как описано в вики аутентификации, подпись не требуется. Он генерируется все параметры, заданные во время вызова на основании .
По техническим причинам, параметры проверки подлинности должны на данный момент всегда быть переданы через метод HTTP GET
Пример
// Définition des paramètres
$data["login"] = "mail@example.com";
$data["пароль "] = "DH 4=674j_G "; // Mot de passe non chiffré
// D"autres paramètres peuvent êtres ajoutés en fonction de l"appel à l"API
// $data["autre_parametre"] = "valeur";
// $data["autre_parametre_2"] = "valeur_2";
// $data["..."] = "...";
// Triage des paramètres dans l'ordre croissant
ksort($data);
// Encodage des paramètres
$query = http_build_query($data);
// Encodage des signes plus
$query = str_replace("+", "%20", $query);
// Transformation de la chaîne de caractères en minuscule
$query = strtolower($query);
// Clé publique d'Ikoula (cf. lien ci-dessus)
$public_key="MIIBIjAN...";
// Hashage des paramètres
$hash = hash_hmac("SHA1", $query, $public_key, true);
// Encodage en base64, puis encodage en URL selon RFC 3986
$signature = rawurlencode(base64_encode($hash));
// ==> $signature contient alors la signature finale
Вывод
После того, как создается подпись, это нужно передать его как параметр (Помимо всех остальных параметров ) вызов API.
После предыдущего примера, параметры, передаваемые таким образом были бы :
- login = "mail@example.com"
- password = "dh4=674j_G"
- signature = $signature
Эта статья представляется вам быть полезным ?
0
Включить автоматическое обновление комментариев