jssdk.php页,主要获取token和ticket

  1. <?php
  2. /*
  3. * 微信公众号后台里获取appId和appSecret,并在公众号后台=>安全中心=>IP白名单中设置当前页面服务器的IP,如果是负载均衡则需将每台子服务器IP都设置上,否则不能获取token
  4. */
  5. class Jssdk {
  6. // 公众号的appId
  7. private $appId = 'wx98527950badbe995';
  8. // 公众号的appSecret
  9. private $appSecret = '3482d6679db63ccacb67843f6ea8d9f9';
  10.  
  11. // 获取签名等信息,本方法内容可做微信分享接口用
  12. public function getInfo() {
  13. // 获取最新可用ticket
  14. $jsapiTicket = $this->getJsApiTicket ();
  15. // 注意 URL 一定要动态获取,不能 hardcode.
  16. $protocol = (! empty ( $_SERVER ['HTTPS'] ) && $_SERVER ['HTTPS'] !== 'off' || $_SERVER ['SERVER_PORT'] == 443) ? "https://" : "http://";
  17. // 获取当前页面的url
  18. // $url = "$protocol$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]";
  19. // 如果方法作为接口,则无法将当前页面访问路径作为分享url,需要访问接口的前端页面通过 window.location.href 获取页面url传过来
  20. $url = $_POST ['url'] ? $_POST ['url'] : "$protocol$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]";
  21.  
  22. $timestamp = time ();
  23. $nonceStr = $this->createNonceStr ();
  24.  
  25. // 这里参数的顺序要按照 key 值 ASCII 码升序排序
  26. $string = "jsapi_ticket=$jsapiTicket&noncestr=$nonceStr&timestamp=$timestamp&url=$url";
  27.  
  28. $signature = sha1 ( $string );
  29.  
  30. $signPackage = array (
  31. "appId" => $this->appId,
  32. "nonceStr" => $nonceStr,
  33. "timestamp" => $timestamp,
  34. "url" => $url,
  35. "signature" => $signature,
  36. "rawString" => $string
  37. );
  38. //如果是接口,这里则是 echo json_encode($signPackage);
  39. return $signPackage;
  40. }
  41. // 创建获取随机字符串
  42. private function createNonceStr($length = 16) {
  43. $chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
  44. $str = "";
  45. for($i = 0; $i < $length; $i ++) {
  46. $str .= substr ( $chars, mt_rand ( 0, strlen ( $chars ) - 1 ), 1 );
  47. }
  48. return $str;
  49. }
  50. // 获取ticket
  51. private function getJsApiTicket() {
  52. // jsapi_ticket 应该全局存储与更新,以下代码以写入到文件中做示例,实际应存在数据库中
  53. $data = json_decode ( $this->get_php_file ( "jsapi_ticket.php" ) );
  54. //获取没过期的ticket,过期则重新获取
  55. if ($data->expire_time < time ()) {
  56. // 获取最新可用token,ticket需要通过token获取
  57. $accessToken = $this->getAccessToken ();
  58. // 如果是企业号用以下 URL 获取 ticket
  59. // $url = "https://qyapi.weixin.qq.com/cgi-bin/get_jsapi_ticket?access_token=$accessToken";
  60. $url = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?type=jsapi&access_token=$accessToken";
  61. $res = json_decode ( $this->httpGet ( $url ) );
  62. $ticket = $res->ticket;
  63. if ($ticket) {
  64. //将有效时间设置成将来的7000秒内
  65. $data->expire_time = time () + 7000;
  66. $data->jsapi_ticket = $ticket;
  67. $this->set_php_file ( "jsapi_ticket.php", json_encode ( $data ) );
  68. }
  69. } else {
  70. $ticket = $data->jsapi_ticket;
  71. }
  72.  
  73. return $ticket;
  74. }
  75. // 获取token
  76. private function getAccessToken() {
  77. // access_token 应该全局存储与更新,以下代码以写入到文件中做示例,实际应存在数据库中
  78. $data = json_decode ( $this->get_php_file ( "access_token.php" ) );
  79. //获取没过期的token,过期则重新获取
  80. if ($data->expire_time < time ()) {
  81. // 如果是企业号用以下URL获取access_token
  82. // $url = "https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=$this->appId&corpsecret=$this->appSecret";
  83. $url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=$this->appId&secret=$this->appSecret";
  84. $res = json_decode ( $this->httpGet ( $url ) );
  85. $access_token = $res->access_token;
  86. if ($access_token) {
  87. //将有效时间设置成将来的7000秒内
  88. $data->expire_time = time () + 7000;
  89. $data->access_token = $access_token;
  90. $this->set_php_file ( "access_token.php", json_encode ( $data ) );
  91. }
  92. } else {
  93. $access_token = $data->access_token;
  94. }
  95. return $access_token;
  96. }
  97. // curl访问返回数据
  98. private function httpGet($url) {
  99. $curl = curl_init ();
  100. curl_setopt ( $curl, CURLOPT_RETURNTRANSFER, true );
  101. curl_setopt ( $curl, CURLOPT_TIMEOUT, 500 );
  102. // 为保证第三方服务器与微信服务器之间数据传输的安全性,所有微信接口采用https方式调用,必须使用下面2行代码打开ssl安全校验。
  103. // 如果在部署过程中代码在此处验证失败,请到 http://curl.haxx.se/ca/cacert.pem 下载新的证书判别文件。
  104. curl_setopt ( $curl, CURLOPT_SSL_VERIFYPEER, 1 );
  105. curl_setopt ( $curl, CURLOPT_SSL_VERIFYHOST, 2 );//CURLOPT_SSL_VERIFYHOST 设置为 1 是检查服务器SSL证书中是否存在一个公用名(common name)。注:公用名(Common Name)一般来讲就是填写将要申请SSL证书的域名 (domain)或子域名(sub domain)。 设置成 2,会检查公用名是否存在,并且是否与提供的主机名匹配。 在生产环境中,这个值应该是 2(默认值)
  106. curl_setopt ( $curl, CURLOPT_URL, $url );
  107.  
  108. $res = curl_exec ( $curl );
  109. curl_close ( $curl );
  110.  
  111. return $res;
  112. }
  113. // 读取文件
  114. private function get_php_file($filename) {
  115. return trim ( substr ( file_get_contents ( $filename ), 15 ) );
  116. }
  117. // 写入文件
  118. private function set_php_file($filename, $content) {
  119. $fp = fopen ( $filename, "w" );
  120. fwrite ( $fp, "<?php exit();?>" . $content );
  121. fclose ( $fp );
  122. }
  123. }

access_token.php页,保存获取的token

  1. <?php exit();?>
  2. {"access_token":"","expire_time":0}

jsapi_ticket.php页,保存获取的ticket

  1. <?php exit();?>
  2. {"jsapi_ticket":"","expire_time":0}

index.php页,前端调用页

  1. <?php
  2. /*
  3. * 前端页面,这里是直接包含了获取签名的页面,实际可将获取签名页面写成接口,前端通过ajax获取
  4. */
  5. require_once "jssdk.php";
  6. $jssdk = new Jssdk();
  7. $info = $jssdk->getInfo();
  8. ?>
  9. <!DOCTYPE html>
  10. <html lang="en">
  11. <head>
  12. <meta charset="UTF-8">
  13. <title></title>
  14. </head>
  15. <body>
  16.  
  17. </body>
  18. <script src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script>
  19. <script>
  20. /*
  21. * 注意:
  22. * 1. 所有的JS接口只能在公众号绑定的域名下调用,公众号开发者需要先登录微信公众平台进入“公众号设置”的“功能设置”里填写“JS接口安全域名”。
  23. * 2. 如果发现在 Android 不能分享自定义内容,请到官网下载最新的包覆盖安装,Android 自定义分享接口需升级至 6.0.2.58 版本及以上。
  24. * 3. 常见问题及完整 JS-SDK 文档地址:http://mp.weixin.qq.com/wiki/7/aaa137b55fb2e0456bf8dd9148dd613f.html
  25. *
  26. * 开发中遇到问题详见文档“附录5-常见错误及解决办法”解决,如仍未能解决可通过以下渠道反馈:
  27. * 邮箱地址:weixin-open@qq.com
  28. * 邮件主题:【微信JS-SDK反馈】具体问题
  29. * 邮件内容说明:用简明的语言描述问题所在,并交代清楚遇到该问题的场景,可附上截屏图片,微信团队会尽快处理你的反馈。
  30. */
  31. wx.config({
  32. debug: true,
  33. appId: '<?php echo $info["appId"];?>',
  34. timestamp: <?php echo $info["timestamp"];?>,
  35. nonceStr: '<?php echo $info["nonceStr"];?>',
  36. signature: '<?php echo $info["signature"];?>',
  37. jsApiList: [
  38. // 所有要调用的 API 都要加到这个列表中
  39. ]
  40. });
  41. wx.ready(function () {
  42. // 在这里调用 API
  43. });
  44. </script>
  45. </html>

php获取微信token和ticket并返回签名的更多相关文章

  1. 微信公众号获取微信token

    微信在公众号和小程序的开发都有开放文档一般看文档开发就行,很简单这里写一个小demo获取微信token,之后根据自己的业务获取信息处理即可 package com.demo.ccx; import o ...

  2. 获取微信Token值

    /** * 获取Token值 * @param $corpid * @param $corpsecret * @return mixed * @author 宁佳兵 <meilijing.nin ...

  3. C# 获取微信小程序access_token

    /// <summary> /// 获取access_token /// </summary> /// <returns></returns> publ ...

  4. 微信公众平台开发视频教程-03-获取Access Token和获取微信服务器IP,添加微信菜单

    1 获取access token 此token是以后每次调用微信接口都会带上的票据,token是公众号全局唯一票据,在调用其他接口之前都需要先得到token,taoken长度至少512个字符,通常用s ...

  5. 后台微信开发入口+关键字 回复等 关注公众号回复 注意获取随机Token 微信的对接校验Token保存到数据库的只是做第一次的校验 其他对微信公众号的操作是去缓存中获取7200S的随机Token

    package com.epalmpay.controller.apiweixin; import com.epalmpay.commom.BaseController;import com.epal ...

  6. NodeJs实现自定义分享功能,获取微信授权+用户信息

    最近公司搞了个转盘抽奖的运营活动,入口放在了微信公众号里,好久没碰过微信了,刚拾起来瞬间感觉有点懵逼....似乎把之前的坑又都重新踩了一遍,虽然过程曲折,不过好在顺利完成了,而且印象也更加深刻了,抽时 ...

  7. .netcore2.1 JS-SDK 从后台获取微信签名,实现自定义分享标题、描述、图片

    最近项目移动端需要实现微信自定义分享功能,包含分享自定义标题.描述等. 首先到公众号的后台,功能设置里面,添加将要被分享的域名,如图 后端签名算法实现 ,参考腾讯开发者文档https://mp.wei ...

  8. 第七篇 :微信公众平台开发实战Java版之如何获取微信用户基本信息

    在关注者与公众号产生消息交互后,公众号可获得关注者的OpenID(加密后的微信号,每个用户对每个公众号的OpenID是唯一的.对于不同公众号,同一用户的openid不同). 公众号可通过本接口来根据O ...

  9. 微信公众平台开发—利用OAuth2.0获取微信用户基本信息

    在借鉴前两篇获取微信用户基本信息的基础下,本人也总结整理了一些个人笔记:如何通过OAuth2.0获取微信用户信息 1.首先在某微信平台下配置OAuth2.0授权回调页面: 2.通过appid构造url ...

随机推荐

  1. css3 动画应用 animations 和transtions transform在加上JavaScript 可以实现硬件加速动画。

    transitions(过渡) 被应用于元素指定的属性变化时,该属性经过一段时间逐渐的过渡到最终想要的值. 主要包括四个属性: 执行变换的属性:transition-property 变换延续的时间: ...

  2. ECMAScript面向对象术语

    面向对象术语1.对象ECMA-262 把对象(object)定义为“属性的无序集合,每个属性存放一个原始值.对象或函数”.严格来说,这意味着对象是无特定顺序的值的数组.尽管 ECMAScript 如此 ...

  3. ABAP术语-BAPI Explorer

    BAPI Explorer 原文:http://www.cnblogs.com/qiangsheng/archive/2007/12/24/1012110.html Tool for developi ...

  4. java连接Redis初始化jedis失败!

    Bean instantiation via constructor failed; nested exception is org.springframework.beans.BeanInstant ...

  5. 快速玩转linux(4)

    websever安装配置 Nginx & Apache 并发量. Apache基本操作 解释 命令 安装 yum install httpd 启动 service httpd start 停止 ...

  6. python实践项目—Collatz序列

    Collatz序列题意说明 编写一个名为collatz()的函数,它有一个名为number 的参数.如果参数是偶数,那么collatz()就打印出number // 2,并返回该值.如果number ...

  7. 【TCP/IP实现磁盘资源的分享-----ISCSI(互联网最小应用程序接口)】

    Iscsi server: 首先把多块磁盘合并为RAID5,便于后期iscis client访问以及服务端的管理 安装 targted服务端包,以及targtedcli创建iscsi TCP/IP共享 ...

  8. 源码安装CentOs7下的PHP7

    首先安装APACHE环境,直接用yum安装 yum install httpd httpd-devel /etc/httpd/ systemctl start httpd.service #启动apa ...

  9. ADB工具的安装

    1.Windows ADB工具下载地址: https://developer.android.google.cn/studio/releases/platform-tools ADB工具官网教程: h ...

  10. P2419 [USACO08JAN]牛大赛Cow Contest

    P2419 [USACO08JAN]牛大赛Cow Contest 题目背景 [Usaco2008 Jan] 题目描述 N (1 ≤ N ≤ 100) cows, conveniently number ...