>  기사  >  백엔드 개발  >  jsapi_ticket을 얻기 위한 WeChat 개발 예제 튜토리얼

jsapi_ticket을 얻기 위한 WeChat 개발 예제 튜토리얼

零下一度
零下一度원래의
2017-07-20 17:28:231954검색

jsapi_ticket을 얻기 위한 WeChat 개발 예제 튜토리얼

1. access_token을 얻습니다

2. access_token

을 통해 jsapi_ticket을 교환합니다.

서명 생성 규칙은 다음과 같습니다. 서명에는 noncestr(임의의 문자열), 유효한 jsapi_ticket, 타임스탬프(타임스탬프), url(# 및 다음 부분을 제외한 현재 웹페이지의 URL)이 포함됩니다. 필드 이름의 ASCII 코드에 따라 서명할 모든 매개변수를 작은 것부터 큰 것까지(사전순) 정렬한 후 URL 키-값 쌍 형식(예: key1=value1&key2=value2...)을 사용하여 이를 하나의 매개변수로 연결합니다. 문자열 문자열1. 여기에서 모든 매개변수 이름은 소문자라는 점에 유의해야 합니다. string1에 대해 sha1 암호화를 수행하고, 필드 이름 및 필드 값에 원래 값을 사용하고, URL 이스케이프를 수행하지 마십시오.

2. 구체적인 구현 방법

1. access_token 획득

/**
 * [getAccessToken description] 获取access_token
 * @return [type] [description] */private  function getAccessToken() {
    $data = $this->getFile($this->accessTokenFile);    if(time() - $data['time'] > 0){
        $url = "{$this->appID}&secret={$this->appsecret}";
        $re = $this->httpGet($url);
        $access_token = $re['access_token'];        if(isset($access_token)){
            $data['access_token']  = $access_token;
            $data['time'] = time() + 7200;
            $this->setFile($this->accessTokenFile,json_encode($data));
        }
    }else{
        $access_token = $data['access_token'];
    }   return $access_token;
}

access_token은 7200s에 유효하므로 여러 요청을 피하기 위해 파일 저장에 저장할 수 있습니다.

2.

access_token을 통해 jsapi_ticket을 얻으려면 유효 기간도 7200초입니다.
3. 서명 생성

/**
 * [getJsapiTicket description] 获取jsapi_ticket
 * @return [type] [description] */private function getJsapiTicket() {
    $access_token = $this->getAccessToken();
    $jsapi_ticket = $this->getFile($this->jsapiTicketFile);    if(time() - $jsapi_ticket['time'] > 0) {
        $url = "{$access_token}&type=jsapi";
        $re = $this->httpGet($url);
        $this->preArr($re);
        $jsapi_ticket = $re['ticket'];        if(isset($jsapi_ticket)){
            $data['jsapi_ticket'] = $jsapi_ticket;
            $data['time'] = time() + 7200;
            $this->setFile($this->jsapiTicketFile, json_encode($data));
        }
    }else{
        $jsapi_ticket = $jsapi_ticket['jsapi_ticket'];
    }   return $jsapi_ticket;
}

서명 알고리즘,
URL 키-값 쌍 형식을 사용합니다(예: key1=value1&key2=value2) ... ) 문자열 string1에 연결됩니다.

sha1로 string1에 서명하고 서명을 받습니다.

참고:

1 서명에 사용되는 noncestr 및 타임스탬프는 wx.config의 nonceStr 및 타임스탬프와 동일해야 합니다.

2. 서명에 사용되는 URL은 JS 인터페이스를 호출하는 페이지의 전체 URL이어야 합니다.

3. 보안상의 이유로 개발자는 서버 측에서 서명 논리를 구현해야 합니다.

위 내용은 jsapi_ticket을 얻기 위한 WeChat 개발 예제 튜토리얼의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.