php制作微信自定义分享功能(连接)(微信公众号上)

在框架TP3.2中:

控制器:<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<

<?php
namespace Home\Controller;
use Think\Controller;
class JssdkController extends Controller {
    public function __construct(){
        parent::__construct();
        $this->appId = '填写申请好的appId号';
        $this->appSecret = 'appSecret 号';
    }
  
  public function index(){
        $jsapiTicket = $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]";


        $timestamp = time();
        $nonceStr = $this->createNonceStr();


        // 这里参数的顺序要按照 key 值 ASCII 码升序排序
        $string = "jsapi_ticket=$jsapiTicket&noncestr=$nonceStr&timestamp=$timestamp&url=$url";


        $signature = sha1($string);


        $signPackage = array(
          "appId"     => $this->appId,
          "nonceStr"  => $nonceStr,
          "timestamp" => $timestamp,
          "url"       => $url,
          "signature" => $signature,
          "rawString" => $string
        );
        $this->assign('signPackage',$signPackage);
        $this->display();
    }
  public function assessmentPage(){
        $jsapiTicket = $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]";


        $timestamp = time();
        $nonceStr = $this->createNonceStr();


        // 这里参数的顺序要按照 key 值 ASCII 码升序排序
        $string = "jsapi_ticket=$jsapiTicket&noncestr=$nonceStr&timestamp=$timestamp&url=$url";


        $signature = sha1($string);


        $signPackage = array(
          "appId"     => $this->appId,
          "nonceStr"  => $nonceStr,
          "timestamp" => $timestamp,
          "url"       => $url,
          "signature" => $signature,
          "rawString" => $string
        );
        $this->assign('signPackage',$signPackage);
        $this->display();
    }


  private function createNonceStr($length = 16) {
    $chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
    $str = "";
    for ($i = 0; $i < $length; $i++) {
      $str .= substr($chars, mt_rand(0, strlen($chars) - 1), 1);
    }
    return $str;
  }


  private function getJsApiTicket() {
    // jsapi_ticket 应该全局存储与更新,以下代码以写入到文件中做示例
    $data = json_decode($this->get_php_file("F:\phpStudy\WWW\XXW\sincewin_teacher\Application\Home\Controller\jsapi_ticket.php"));
    if ($data->expire_time < time()) {
      $accessToken = $this->getAccessToken();
      // 如果是企业号用以下 URL 获取 ticket
      // $url = "https://qyapi.weixin.qq.com/cgi-bin/get_jsapi_ticket?access_token=$accessToken";
      $url = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?type=jsapi&access_token=$accessToken";
      $res = json_decode($this->httpGet($url));
      $ticket = $res->ticket;
      if ($ticket) {
        $data->expire_time = time() + 7000;
        $data->jsapi_ticket = $ticket;
        $this->set_php_file("F:\phpStudy\WWW\XXW\sincewin_teacher\Application\Home\Controller\jsapi_ticket.php", json_encode($data));
      }
    } else {
      $ticket = $data->jsapi_ticket;
    }
    // var_dump($ticket);
    return $ticket;
  }


  private function getAccessToken() {
    // access_token 应该全局存储与更新,以下代码以写入到文件中做示例
    $data = json_decode($this->get_php_file("F:\phpStudy\WWW\XXW\sincewin_teacher\Application\Home\Controller\access_token.php"));
    if ($data->expire_time < time()) {
      // 如果是企业号用以下URL获取access_token
      //https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=wx560cf4ea56580f26&secret=$this->appSecret
      // $url = "https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=$this->appId&corpsecret=$this->appSecret";
      $url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=$this->appId&secret=$this->appSecret";
      $res = json_decode($this->httpGet($url));
      $access_token = $res->access_token;
      if ($access_token) {
        $data->expire_time = time() + 7000;
        $data->access_token = $access_token;
        $this->set_php_file("F:\phpStudy\WWW\XXW\sincewin_teacher\Application\Home\Controller\access_token.php", json_encode($data));
      }
    } else {
      $access_token = $data->access_token;
    }
    // var_dump($access_token);
    return $access_token;
  }


  private function httpGet($url) {
    $curl = curl_init();
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
    curl_setopt($curl, CURLOPT_TIMEOUT, 500);
    // 为保证第三方服务器与微信服务器之间数据传输的安全性,所有微信接口采用https方式调用,必须使用下面2行代码打开ssl安全校验。
    // 如果在部署过程中代码在此处验证失败,请到 http://curl.haxx.se/ca/cacert.pem 下载新的证书判别文件。
    curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, true);
    curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, true);
    curl_setopt($curl, CURLOPT_URL, $url);


    $res = curl_exec($curl);
    curl_close($curl);


    return $res;
  }


  private function get_php_file($filename) {
    return trim(substr(file_get_contents($filename), 15));
  }
  private function set_php_file($filename, $content) {
    $fp = fopen($filename, "w");
    fwrite($fp, "<?php exit();?>" . $content);
    fclose($fp);
  }
}

视图:<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta name="wap-font-scale" content="no">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>小凤凰幼儿园4月10日DemoClass课调查问卷</title>
    <script src="__PUBLIC__/static/js/flexible.js"></script>
    <link rel="stylesheet" href="https://cdn.bootcss.com/mui/3.7.1/css/mui.min.css">
    <link rel="stylesheet" href="__PUBLIC__/static/css/index.css">
    <script src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script>
</head>
<body>
<div class="mui-content">
    <div class="autor-box">
        <img src="__PUBLIC__/static/images/assB.png" alt="">
    </div>
    <div class="logo"><img src="__PUBLIC__/static/images/assesslogo.png"></div>
    <div class="mui-box">
        <div class="autor-box-title" style="padding: 1rem 0;">
            <p><span>您好,Demo class 满意度调查表,请您真实填写,非常感谢您的配合!</span>
            </p>
            <div class="form-box txwj">
                <form>
                    <div class="assess-k-h">
                        <h2 style="padding-left: 6%;"><span>1.</span><span>很高兴认识您,怎么称呼您?</span></h2>
                        <div class="assess-k-h-form">
                            <div class="mui-input-row">
                                <input type="text" id="userName">
                            </div>
                        </div>
                    </div>
                    <div class="assess-k-h">
                        <h2 style="padding-left: 6%;"><span>2.</span><span>为了更好的反馈,您的电话:</span></h2>
                        <div class="assess-k-h-form">
                            <div class="mui-input-row">
                                <input type="tel" autocomplete="new-password" pattern="\d*" id="phone" maxlength="11">
                            </div>
                        </div>
                    </div>
                </form>
            </div>
        </div>


        <div class="autor-box-bottom">
            <div class="autor-btn-box">
                请选择您的身份
            </div>
            <div class="autor-content">
                <div class="form-box indxBox">
                    <form>
                        <div class="mui-input-row mui-radio mui-left index-label-box">
                            <label style="text-align: center;">家长</label>
                            <input name="assess" type="radio" value="2" class="radioClass" style="top:22%;">
                        </div>
                        <div class="mui-input-row mui-radio mui-left index-label-box">
                            <label style="text-align: center;">市场人员</label>
                            <input name="assess" type="radio" value="4" style="top:22%;">
                        </div>
                        <div class="mui-input-row mui-radio mui-left index-label-box">
                            <label style="text-align: center;">园长</label>
                            <input name="assess" type="radio" value="3" class="radioClass" style="top:22%;">
                        </div>
                        <div class="mui-input-row mui-radio mui-left index-label-box">
                            <label style="text-align: center;">线下老师</label>
                            <input name="assess" type="radio" value="1" style="top:22%;">
                        </div>
                    </form>
                    <div class="sumbitBut" id="btn">
                        马上开始
                    </div>
                </div>
            </div>
        </div>
    </div>
</div>
<script src="https://cdn.bootcss.com/zepto/1.2.0/zepto.min.js"></script>
<script src="https://cdn.bootcss.com/mui/3.7.1/js/mui.min.js"></script>
<script src="https://cdn.bootcss.com/layer/3.1.0/mobile/layer.js"></script>
<script src="__PUBLIC__/static/js/assessInit.js"></script>
<script src="__PUBLIC__/static/js/assess.js"></script>
<script>
    var shareTitle = '通州幼儿园4月10日DemoClass(预热)课调查问卷',
        sharelink = 'http://yz.weiope.com/Home/Jssdk/index',
        sharedesc = '新学问国际课堂',
        myimgUrl = 'http://yz.weiope.com/Public/static/images/assesslogo.png';
    wx.config({
        debug: false,
        appId: '{$signPackage['appId']}',
        timestamp: {$signPackage['timestamp']},
        nonceStr: '{$signPackage['nonceStr']}',
        signature: '{$signPackage['signature']}',
        jsApiList: [
            'onMenuShareAppMessage',
            'onMenuShareTimeline',
            'onMenuShareQQ',
            'onMenuShareQZone'
        ]
    });
    wx.ready(function () {
        wx.onMenuShareAppMessage({
            title: shareTitle, // 分享标题
            desc: sharedesc, // 分享描述
            link: sharelink, // 分享链接
            imgUrl: myimgUrl, // 分享图标
            success: function (res) {
            },
            cancel: function (res) {
            }
        });
        wx.onMenuShareTimeline({
            title: shareTitle, // 分享标题
            desc: sharedesc, // 分享描述
            link: sharelink, // 分享链接
            imgUrl: myimgUrl, // 分享图标
            success: function (res) {
            },
            cancel: function (res) {
            }
        });
        wx.onMenuShareQQ({
            title: shareTitle, // 分享标题
            desc: sharedesc, // 分享描述
            link: sharelink, // 分享链接
            imgUrl: myimgUrl, // 分享图标
            success: function (res) {
            },
            cancel: function (res) {
            }
        });
        wx.onMenuShareQZone({
            title: shareTitle, // 分享标题
            desc: sharedesc, // 分享描述
            link: sharelink, // 分享链接
            imgUrl: myimgUrl, // 分享图标
            success: function (res) {
            },
            cancel: function (res) {
            }
        });
    });
    wx.error(function (res) {
        var resss = JSON.stringify(res);
        layer.open({
            content: resss,
            skin: 'mag',
            time: 2
        });
    });
</script>
</body>
</html>


<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<

相关连接:

百度经验:https://jingyan.baidu.com/article/425e69e6d7e1b3be14fc1679.html

微信公众平台开发文档:https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421141115

(可下载demo页面,示例代码)

TP5框架简单示例文档:http://www.thinkphp.cn/code/2738.html

TP5集成JS-SDK实现微信自定义分享:https://www.cnblogs.com/sunshineliulu/p/8034286.html

https://blog.csdn.net/sh13523149003/article/details/73692699




  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值