JsSdk.php 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. <?php
  2. namespace wx\offiaccount;
  3. use wx\Base;
  4. class JsSdk extends Base
  5. {
  6. public function getSignPackage($jsapiTicket, $url=null) {
  7. // 注意 URL 一定要动态获取,不能 hardcode.
  8. //$protocol = (!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== 'off' || $_SERVER['SERVER_PORT'] == 443) ? "https://" : "http://";
  9. $protocol = "https://"; //负载均衡情况下 后端监听80,业务服务器默认http头,但是此处要强制使用https头
  10. if(empty($url)){
  11. $url = "$protocol$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]";
  12. }
  13. $timestamp = time();
  14. $nonceStr = $this->createNonceStr();
  15. // 这里参数的顺序要按照 key 值 ASCII 码升序排序
  16. $string = "jsapi_ticket=$jsapiTicket&noncestr=$nonceStr&timestamp=$timestamp&url=$url";
  17. $signature = sha1($string);
  18. $signPackage = array(
  19. "nonceStr" => $nonceStr,
  20. "timestamp" => $timestamp,
  21. "url" => $url,
  22. "signature" => $signature,
  23. "rawString" => $string
  24. );
  25. return $signPackage;
  26. }
  27. private function createNonceStr($length = 16) {
  28. $chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
  29. $str = "";
  30. for ($i = 0; $i < $length; $i++) {
  31. $str .= substr($chars, mt_rand(0, strlen($chars) - 1), 1);
  32. }
  33. return $str;
  34. }
  35. /**
  36. * jsapi_ticket 应该全局存储与更新,以下代码以写入到文件中做示例
  37. * @param $token
  38. * @return mixed
  39. */
  40. public function getJsApiTicket($token) {
  41. // 如果是企业号用以下 URL 获取 ticket
  42. // $url = "https://qyapi.weixin.qq.com/cgi-bin/get_jsapi_ticket?access_token=$accessToken";
  43. $url = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?type=jsapi&access_token=$token";
  44. $res = json_decode(curl($url));
  45. if($res->errcode != 0) trace($res->errmsg, 'error');
  46. $ticket = $res->ticket;
  47. return $ticket;
  48. }
  49. }