>백엔드 개발 >PHP 튜토리얼 >JSAPI TICKET 획득을 위한 WeChat 개발 공유 예시

JSAPI TICKET 획득을 위한 WeChat 개발 공유 예시

小云云
小云云원래의
2018-02-08 14:08:592024검색

이 글에서는 주로 WeChat 개발 시 JSAPI_TICKET을 획득하는 방법을 자세히 소개하고 있습니다. 관심 있는 친구들은 참고하시기 바랍니다

1. access_token 획득

2. jsapi_ticket

3. 서명 알고리즘

서명 생성 규칙은 다음과 같습니다: 서명에 참여하는 필드에는 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년대에 유효하므로 여러 요청을 피하기 위해 파일 저장소에 저장할 수 있습니다.

2.

/**
 * [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;
}

jsapi_ticket을 얻기 위해 access_token을 교환하세요. 유효 기간도 7200초입니다.

3. 서명 생성


/**
 * [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}&timestamp={$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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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