> 백엔드 개발 > PHP 문제 > PHP 공식 계정 토큰 확인에 실패하면 어떻게 해야 하나요?

PHP 공식 계정 토큰 확인에 실패하면 어떻게 해야 하나요?

PHPz
풀어 주다: 2023-04-19 10:36:55
원래의
5066명이 탐색했습니다.

PHP 공개 계정 토큰 확인 실패에 대한 해결 방법

WeChat 공개 계정을 개발하는 과정에서 토큰 확인 실패가 자주 발생합니다. 이 상황은 일반적으로 토큰 구성이 잘못되었거나 WeChat 서버가 서버에 액세스할 수 없기 때문에 발생합니다. 이 문서에서는 몇 가지 일반적인 토큰 확인 실패와 해결 방법을 소개합니다.

  1. 토큰 구성 오류

토큰을 설정할 때 코드에 토큰을 작성하고 WeChat 공개 플랫폼에서 구성해야 합니다. 우리가 입력한 토큰이 코드의 토큰과 일치하지 않으면 토큰 확인이 실패합니다.

토큰 구성 오류에 대한 해결 방법:

먼저 공개 플랫폼에 입력한 토큰이 코드의 토큰과 동일한지 확인해야 합니다. 서로 다른 경우 동일한 토큰으로 수정해야 합니다.

두 번째로 코드의 토큰이 올바르게 설정되었는지 확인해야 합니다. 아래와 같이 코드에 있는 토큰을 인쇄하여 확인할 수 있습니다.

define("TOKEN", "XXXXXXXXXXXXXX");

echo TOKEN;
로그인 후 복사

인쇄된 결과는 퍼블릭 플랫폼에 설정된 토큰과 동일해야 합니다. 다른 경우 코드에서 토큰을 수정해야 합니다.

  1. 서버 구성 오류

토큰 확인 중에 WeChat 서버는 우리 서버에 HTTP GET 요청을 시작합니다. 요청에는 WeChat 공개 플랫폼에서 입력한 토큰, 타임스탬프 및 nonce의 세 가지 매개변수가 포함되어 있습니다. 우리 서버는 이 세 가지 매개변수를 기반으로 암호화 처리를 수행하고 이를 WeChat 서버에 반환해야 합니다.

WeChat 서버에서 서버에 접근할 수 없거나 서버 응답이 잘못된 경우 토큰 확인이 실패합니다.

서버 구성 오류 해결 방법:

먼저 서버에 포트 80이 열려 있고 방화벽이 WeChat 서버에 대한 액세스를 차단하지 않는지 확인해야 합니다.

둘째, 서버측 코드가 올바르게 설정되었는지 확인해야 합니다. 이는 아래와 같이 서버에서 반환한 데이터를 코드로 출력하여 확인할 수 있습니다.

$echostr = $_GET["echostr"];

echo $echostr;
로그인 후 복사

서버가 데이터를 올바르게 반환하지 않는 경우 코드에 오류나 논리 문제가 있는지 확인해야 합니다.

  1. 안전 모드에서 토큰 확인 오류

저희 공식 계정 설정에서 안전 모드가 켜져 있는 경우 토큰에 대해 특별한 처리를 수행해야 합니다. 안전 모드에서 WeChat 서버는 우리 서버에 대한 HTTP POST 요청을 시작합니다. 요청에는 WeChat 공개 플랫폼에서 입력한 4개의 매개변수 토큰, 타임스탬프, nonce 및 msg_signature가 포함됩니다.

안전 모드에서 토큰 확인 오류에 대한 해결 방법:

먼저 서버가 HTTP POST 요청을 정상적으로 처리할 수 있는지 확인해야 합니다. 둘째, 토큰에 대해 특수 처리를 수행해야 합니다.

$token = "XXXXXXXXXXXXXX"; // Token和公众平台上设置一致
$timestamp = $_GET["timestamp"];
$nonce = $_GET["nonce"];
$msg_signature = $_GET["msg_signature"];
$encrypt_type = (isset($_GET['encrypt_type']) && ($_GET['encrypt_type'] == "aes")) ? "aes" : "raw"; // 兼容明文模式与安全模式

if ($msg_signature) {
    $signature = $_GET["signature"];

    $tmpArr = array($token, $timestamp, $nonce);
    sort($tmpArr, SORT_STRING);
    $tmpStr = implode($tmpArr);
    $tmpStr = $encrypt_type == 'aes' ? $tmpStr . $_GET["encrypted"] : $tmpStr;
    $signatureLocal = sha1($tmpStr);

    if ($signature == $signatureLocal) {
        if ($encrypt_type == 'aes') {
            // 对密文进行解密
        }

        $echostr = $_GET["echostr"];

        echo $echostr;
    }
}
로그인 후 복사
  1. Token timeout

토큰에 만료 시간이 있으면 토큰이 무효화됩니다. 으로 인해 토큰이 만료되었습니다. 확인이 실패했습니다.

토큰 시간 초과에 대한 해결 방법:

코드에서 토큰 만료 시간을 설정할 수 있습니다. 예를 들어 7200초(2시간)로 설정합니다. 코드 예제는 다음과 같습니다.

define("TOKEN", "XXXXXXXXXXXXXX");
define("EXPIRE_TIME", 7200);

$timestamp = $_GET['timestamp'];
$nonce = $_GET['nonce'];
$signature = $_GET['signature'];

if (time() - $timestamp > EXPIRE_TIME) {
    die('Token expired');
}

$tmpArr = array(TOKEN, $timestamp, $nonce);
sort($tmpArr, SORT_STRING);
$tmpStr = implode($tmpArr);
$tmpStr = sha1($tmpStr);

if ($tmpStr == $signature) {
    $echostr = $_GET['echostr'];
    echo $echostr;
}
로그인 후 복사

위는 다음과 같습니다. PHP 공식 계정 토큰 확인 실패 방법을 요약하여 모든 분들께 도움이 되기를 바랍니다.

위 내용은 PHP 공식 계정 토큰 확인에 실패하면 어떻게 해야 하나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿