微信JS-SDK——微信分享给朋友

    参考: 微信JS-SDK文档 其中包含有分享朋友圈、发送给朋友的js接口方法。(似乎不知道什么时候就会废弃)
    文档中有完整的步骤,麻烦的是第三步:通过config接口注入权限验证配置。其中需要获取 signature(签名) ,必须通过服务器端才行。

    本文主要是关于通过服务器获取签名的方法

  授权需要获取access_token,然后通过access_token取到jsapi_ticket再进行加密签名。

  微信公众号获取的access_token有两种:网页授权access_token、普通access_token,前者仅用于网页端请求用户授权,获取用户信息。后者则广泛用于微信各种接口。本文需要的就是后者:普通access_token。

  (另外备注一点:网页授权获取access_token是先获取到(用户同意授权之后的)code,再根据code获取access_token,而普通access_token直接通过appid、appsecret,请求一次就可获得)

主要是获取access_token的,以后再用直接复制就行

<?php

class weixin{
    private $AppID = ‘‘;//自行填写
    private $AppSecret = ‘‘;//自行填写

    public $tokenFile = ‘./wxtoken.txt‘;//保存token的文件,有效期2小时
    public $jsapiFile = ‘./wxjsapi_ticket.txt‘;//保存 jsapi_ticket的文件,有限期2小时
    public $getTokenUrl = ‘https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET‘;
    public $getjsapiUrl = ‘https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=ACCESS_TOKEN&type=jsapi‘;

    public function __construct(){
        $this->http_type = ((isset($_SERVER[‘HTTPS‘]) && $_SERVER[‘HTTPS‘] == ‘on‘) || (isset($_SERVER[‘HTTP_X_FORWARDED_PROTO‘]) && $_SERVER[‘HTTP_X_FORWARDED_PROTO‘] == ‘https‘)) ? ‘https://‘ : ‘http://‘;
    }

    public function index(){
      $action = isset($_GET[‘do‘]) ? $_GET[‘do‘] : ‘‘;
      switch($action){
        case ‘ApiJsSignature‘:
          $ret = $this->ApiJsSignature();//获取分享需要的签名等数据
          break;
        default:
          echo ‘default‘;
          break;
      }
    }

    //用于微信分享到朋友圈或给朋友的参数
    public function ApiJsSignature(){
        $access_token = $this->get_access_token();
        $JsapiTicket = $this->get_jsapi_ticket($access_token);

        $signArr = array(
            ‘jsapi_ticket‘ => $JsapiTicket,
            ‘noncestr‘ => $this->str_rand(16),
            ‘timestamp‘ => time(),
            ‘url‘ => urldecode($_POST[‘jsapi_url‘])
        );
        $signStr = ‘jsapi_ticket=‘.$signArr[‘jsapi_ticket‘].‘&noncestr=‘.$signArr[‘noncestr‘].‘&timestamp=‘.$signArr[‘timestamp‘].‘&url=‘.$signArr[‘url‘];
        //http_build_query()这个方法好像有问题,我使用之后返回的参数缺少字符

        $signArr[‘signature‘] = sha1($signStr);
        $signArr[‘appid‘] = $this->AppID;
        echo json_encode($signArr);
    }

    //第二步获取jsapi_ticket
    public function get_jsapi_ticket($access_token) {
        if(!file_exists($this->jsapiFile)) {
            $JsapiTicket = $this->resetJsapiTicket($access_token);
        }else{
            $fileContent=file_get_contents($this->jsapiFile);
            $ticketArr = json_decode($fileContent,true);
            if($ticketArr[‘expires_in‘] < time()) {
                $JsapiTicket = $this->resetJsapiTicket($access_token);
            }else{
                $JsapiTicket = $ticketArr[‘ticket‘];
            }
        }
        return $JsapiTicket;
    }
    public function resetJsapiTicket($access_token) {
        $url = str_replace(‘ACCESS_TOKEN‘, $access_token, $this->getjsapiUrl);

        $ticketJson = $this->curlPost($url);
        $ticketData = json_decode($ticketJson, true);

        $ticketData[‘expires_in‘] = $ticketData[‘expires_in‘]+time();
        file_put_contents($this->jsapiFile, json_encode($ticketData));

        return $ticketData[‘ticket‘];
    }

    //第一步获取access_token
    public function get_access_token() {
        if(!file_exists($this->tokenFile)) {
            $access_token = $this->resetToken();//重置token并写入文件 , 返回token值
        }else{
            $fileContent=file_get_contents($this->tokenFile);
            $tokenArr = json_decode($fileContent,true);
            if($tokenArr[‘expires_in‘] < time()) {
                $access_token = $this->resetToken();
            }else{
                $access_token = $tokenArr[‘access_token‘];
            }
        }
        return $access_token;
    }
    //刷新、重置token, 设置获取token事件并将json数据写入文件,最后返回token值,
    private function resetToken(){
        $url = str_replace(‘APPID‘, $this->AppID, $this->getTokenUrl);
        $url = str_replace(‘APPSECRET‘, $this->AppSecret, $url);

        $tokenJson = $this->curlPost($url);
        $tokenData = json_decode($tokenJson, true);

        $tokenData[‘expires_in‘] = $tokenData[‘expires_in‘]+time();
        file_put_contents($this->tokenFile, json_encode($tokenData));

        return $tokenData[‘access_token‘];
    }

    //生成随机字符串
    public function str_rand($length = 32) {
        $char = ‘0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ‘;
        if(!is_int($length) || $length < 0) {
            return false;
        }
        $string = ‘‘;
        for($i = $length; $i > 0; $i--) {
            $string .= $char[mt_rand(0, strlen($char) - 1)];
        }
        return $string;
    }

    //发送请求
    public function curlPost($url, $data = ‘‘) {
        if (! function_exists(‘curl_init‘)) {
            return ‘‘;
        }

        $ch = curl_init();
        curl_setopt($ch, CURLOPT_URL, $url);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);

        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
        curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);

        curl_setopt($ch, CURLOPT_POST, 1);
        curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
        // curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($data)); // 可提交数组参数
        $data = curl_exec($ch);

        if (! $data) {
            error_log(curl_error($ch));
        }

        curl_close($ch);
        return $data;
    }
}

// 调用方式: index.php?do=ApiJsSignature
$weixin = new weixin();
$weixin->index();

原文地址:https://www.cnblogs.com/mengwangchuan/p/9470548.html

时间: 2024-10-15 13:02:22

微信JS-SDK——微信分享给朋友的相关文章

实战微信JS SDK开发:贺卡制作与播放(1)

前段时间忙于CanTK 2.0的开发,所以博客一直没有更新.CanTK 2.0主要增强了游戏和富媒体的开发,现在编码和测试基本完成了,等文档完成了再正式发布,里面有不少激动人心的功能,等发布时再一一细说吧. 最近同事用CanTK开发了一个基于微信的贺卡制作APP,我虽然没有参与开发,但是提供CanTK和GameBuilder的技术支持,觉得有些东西比较有意思,写几篇博客和大家分享吧.这个贺卡APP完全开源,有需要的朋友可以随意修改和发布. CanTK(Canvas ToolKit)是一个开源的游

微信js sdk上传多张图片

微信js sdk上传多张图片,微信上传多张图片 该案例已tp3.2商城为例 直接上代码: php代码: public function ind(){ $appid="11111111111111111111"; $secret="11111111111111111111"; $token = S('access_token'); if (!$token) { $res = file_get_contents("https://api.weixin.qq.c

微信开发SDK|微信sdk使用教程--手机客户端微信下线通知服务端

微信开发SDK|微信sdk使用教程--手机客户端微信下线通知服务端 case WeChatOfflineNotice: {// 手机客户端微信下线通知 log.debug("socket:msgtype=WeChatOfflineNotice"); weChatOfflineNoticeHandler.handleMsg(ctx, msgVo); break; } package com.jubotech.framework.netty.handler.socket; import o

微信js sdk分享开发摘记java版

绑定域名和引入js的就不说了 废话不说直接上代码 1 public void share(HttpServletRequest request) throws Exception { 2 3 StringBuffer homeUrl = request.getRequestURL(); 4 String queryString =request.getQueryString(); 5 if(StringUtils.isNotBlank(queryString)){ 6 homeUrl.appen

微信JS SDK配置授权,实现分享接口

微信开放的JS-SDK面向网页开发者提供了基于微信内的网页开发工具包,最直接的好处就是我们可以使用微信分享.扫一扫.卡券.支付等微信特有的能力.7月份的时候,因为这个分享的证书获取问题深深的栽了一坑,后面看到"config:ok"的时候真的算是石头落地,瞬间感觉世界很美好.. 这篇文章是微信开发的很多前置条件,包括了服务端基于JAVA的获取和缓存全局的access_token,获取和缓存全局的jsapi_ticket,以及前端配置授权组件封装,调用分享组件封装. 配置授权思路:首先根据

微信JS SDK Demo

微信JS-SDK 分享到朋友圈 分享给朋友 分享到QQ 拍照或从手机相册中选图 识别音频并返回识别结果 使用微信内置地图查看位置原文:http://www.cnblogs.com/txw1958/p/weixin-js-sdk-demo.html 一.JS部分 wx.ready(function () { // 1 判断当前版本是否支持指定 JS 接口,支持批量判断 document.querySelector('#checkJsApi').onclick = function () { wx.

微信JS SDK Demo 官方案例

转自:http://my.oschina.net/superkangning/blog/367484 微信JS-SDK是微信公众平台面向网页开发者提供的基于微信内的网页开发工具包. 通过使用微信JS-SDK,网页开发者可借助微信高效地使用拍照.选图.语音.位置等手机系统的能力,同时可以直接使用微信分享.扫一扫.卡券.支付等微信特有的能力,为微信用户提供更优质的网页体验. 此文档面向网页开发者介绍微信JS-SDK如何使用及相关注意事项. 一:html代码部分 ? 1 2 3 4 5 6 7 8 9

微信JS SDK Demo 官方案例[转]

摘要: 微信JS-SDK是微信公众平台面向网页开发者提供的基于微信内的网页开发工具包. 通过使用微信JS-SDK,网页开发者可借助微信高效地使用拍照.选图.语音.位置等手机系统的能力,同时可以直接使用微信分享.扫一扫.卡券.支付等微信特有的能力,为微信用户提供更优质的网页体验. 此文档面向网页开发者介绍微信JS-SDK如何使用及相关注意事项. 微信JS-SDK是微信公众平台面向网页开发者提供的基于微信内的网页开发工具包. 通过使用微信JS-SDK,网页开发者可借助微信高效地使用拍照.选图.语音.

微信-js sdk invalid signature签名错误 问题解决

如果出现 invalid signature,首先可以确定的是你的签名算法有问题.建议:首先查看微信官方网站给出的解决方案,链接为: http://mp.weixin.qq.com/wiki/7/aaa137b55fb2e0456bf8dd9148dd613f.html 1. invalid signature签名错误 建议按如下顺序检查: 确认签名算法正确,可用 http://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=jsapisign 页面工具进行校验

微信JS SDK开发 共享问题小结

首先,我要吐槽一下这个SDK,看了第一遍,完全不知所云,一会获取这个,一会获取那个,也没确切的告诉怎么获取. 和腾讯客服(拿钱不干事的好工作)讨教,人家不懂技术,不知道怎么解决,也没有相关技术人员对应这一块.总共费时 将近一周的时间才把这块弄懂.期间遇到的部分问题以及如何解决分享给大家,欢迎大家一起讨论并指正. 问题1:JS接口安全域名,你所有想要使用的微信接口,要在这个域名内部进行,不能在本地进行相关调试. 问题2:公众账号要求:必须是已经认证的. 问题3:配置config(PS:开启debu