이 글에서는 주로 WeChat 개발 시 JSAPI_TICKET을 획득하는 방법을 자세히 소개하고 있습니다. 관심 있는 친구들은 참고하시기 바랍니다
1. access_token 획득
2. jsapi_ticket3. 서명 알고리즘서명 생성 규칙은 다음과 같습니다: 서명에 참여하는 필드에는 noncestr(임의의 문자열), 유효한 jsapi_ticket, timestamp(timestamp), 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 = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={$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은 7200년대에 유효하므로 여러 요청을 피하기 위해 파일 저장소에 저장할 수 있습니다.
/** * [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 = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token={$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; }
/** * [getSignpackage description] 获取签名 * @return [type] [description] */public function getSignpackage(){ $jsapi_ticket = $this->getJsapiTicket(); // 注意 URL 一定要动态获取,不能 hardcode. $protocol = (!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== 'off' || $_SERVER['SERVER_PORT'] == 443) ? "https://" : "http://"; $url = "$protocol$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]"; $noncestr = $this->createNonceStr(); $timestamp = time(); $string1 = "jsapi_ticket={$jsapi_ticket}&noncestr={$noncestr}×tamp={$timestamp}&url={$url}"; $signature = sha1($string1); $signPackage = array( 'appId' => $this->appID, 'nonceStr' => $noncestr, 'timestamp' => $timestamp, 'signature' => $signature, ); return $signPackage; }
서명 알고리즘
URL 키-값 쌍 형식을 사용하세요(예: key1=value1&key2=value2) … ) 문자열 string1에 연결:
서명을 얻으려면 sha1로 string1에 서명하세요.
참고:
1 서명에 사용되는 noncestr 및 타임스탬프는 wx의 nonceStr 및 타임스탬프와 동일해야 합니다. 구성. 2. 서명에 사용되는 URL은 JS 인터페이스를 호출하는 페이지의 전체 URL이어야 합니다. 3. 보안상의 이유로 개발자는 서버 측에서 서명 논리를 구현해야 합니다.
자세한 내용은 https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421140183
을 참조하세요. 관련 권장 사항:
WeChat 개발에서 jsapi_ticket 가져오기 정보 가져오는 인스턴스 WeChat 개발 튜토리얼의 jsapi_ticket 이미지 선택, 이미지 업로드, 이미지 미리보기 및 다운로드를 위한 WeChat 개발용 WeChat jsapi 방법위 내용은 JSAPI TICKET 획득을 위한 WeChat 개발 공유 예시의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!