在框架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×tamp=$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×tamp=$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