您的位置:首页 > 移动开发 > 微信开发

关于微信二次分享,标题变链接的解决方法(二)----代码部分

2017-02-27 11:17 483 查看
上篇主要介绍了分享的文档,下面这篇直接上代码(代码是用PHP来写的),让大家更容易理解。上篇地址:关于微信二次分享,描述变链接的解决方法(一)----文档说明

代码分三部分进行,第一部分是C层(Controller),第二部分是M层(Model),第三部分是V层(View)

1.控制器层WeixinController

 

$data = array(
'pic'=>'',//图片地址
'title'=>'',//标题
'description'=>''//描述
);
$weixinmodel = new WeixinshareModel();
$weixindata = array();
$weixindata['appId'] = 'xxxxxxxxxxxxxxxxxxxx';//appid
$weixindata['nonceStr'] = $weixinmodel->createNonceStr();
$weixindata['timestamp'] = time();

$protocol = (!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== 'off' || $_SERVER['SERVER_PORT'] == 443) ? "https://" : "http://";
$url = "$protocol$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]";

$weixindata['pic'] = $data['pic'];

$weixindata['link'] = $url;

$weixindata['title'] = $data['title'];

$weixindata['description'] = mb_substr($data['description'], 0, 30, 'UTF-8');

$weixindata['signature'] = $weixinmodel->signature($weixindata['nonceStr'],$weixindata['timestamp'],$url);

$this->assign("weixindata", $weixindata);


 

2.模型层WeixinModel

<?php
class WeixinshareModel extends BaseModel
{
const APPID = 'xxxxxxxxxxxxxxx';
const APPSECRET = 'xxxxxxxxxxxxxxxxxxxxxxxx';
function __construct()
{
parent::__construct();
}

//获取access_token
public function accessToken()
{
$access_token = $this->redis->get("weixin_access_token");//存入redis,这里要结合自己的项目,对redis或者memcahe进行设置
if(!$access_token){
$url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=".self::APPID."&secret=".self::APPSECRET;
$data = json_decode($this->httpGet($url),true);
if(isset($data['access_token']) && $data['access_token'] != ''){
$access_token = $this->redis->set("weixin_access_token",$data['access_token'],7200);
}else{
return false;
}
}
return $access_token;
}

//用第一步拿到的access_token 采用http GET方式请求获得jsapi_ticket
public function jsapiTicket()
{
$jsapi_ticket = $this->redis->get("weixin_jsapi_ticket");
if(!$jsapi_ticket){
$access_token = $this->accessToken();
if($access_token){
$url = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=".$access_token."&type=jsapi";
$data = json_decode($this->httpGet($url),true);
if(isset($data['errcode']) && $data['errcode']== 0){//请求成功
$jsapi_ticket = $this->redis->set("weixin_jsapi_ticket",$data['ticket'],7200);
}else{
return false;
}
}else{
return false;
}
}
return $jsapi_ticket;
}

//获取signature
public function signature($nonceStr,$timestamp,$url)
{
$jsapi_ticket = $this->jsapiTicket();

$signature = '';
if($jsapi_ticket) {
$string = "jsapi_ticket=$jsapi_ticket&noncestr=$nonceStr×tamp=$timestamp&url=$url";
$signature = sha1($string);//对string1进行sha1签名,得到signature
}else{
return false;
}
return $signature;
}

  //生成随机字符串
public 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;
}
  

  //远程请求,可以调用自己项目的远程请求
public function httpGet($url)
{
$curl = curl_init();
curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
curl_setopt($curl, CURLOPT_TIMEOUT, 500);
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
curl_setopt($curl, CURLOPT_URL, $url);

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

return $res;
}

}


 

3.视图层weixin.phtml

<!DOCTYPE html>
<html>
<head>
<title></title>
<meta charset="utf-8">
<meta content="width=device-width,minimum-scale=1.0,maximum-scale=1.0" name="viewport">
<!--这个js必须引入-->
<script type="text/javascript" src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script>
</head>
<body>
<script type="text/javascript">
wx.config({
//debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
appId: '<?=$weixindata['appId']?>', // 必填,公众号的唯一标识
timestamp: <?=$weixindata['timestamp']?>, // 必填,生成签名的时间戳
nonceStr: '<?=$weixindata['nonceStr']?>', // 必填,生成签名的随机串
signature: '<?=$weixindata['signature']?>',// 必填,签名,见附录1
jsApiList: ['onMenuShareTimeline','onMenuShareAppMessage','onMenuShareQQ','onMenuShareWeibo','onMenuShareQZone'] // 必填,需要使用的JS接口列表
});
wx.ready(function(){
wx.onMenuShareTimeline({//分享到朋友圈
title: '<?=$weixindata['title']?>', // 分享标题
link: '<?=$weixindata['link']?>', // 分享链接
imgUrl: '<?=$weixindata['pic']?>' // 分享图标
});
wx.onMenuShareAppMessage({//分享给朋友
title: '<?=$weixindata['title']?>', // 分享标题
desc: '<?=$weixindata['description']?>', // 分享描述
link: '<?=$weixindata['link']?>', // 分享链接
imgUrl: '<?=$weixindata['pic']?>', // 分享图标
type: '', // 分享类型,music、video或link,不填默认为link
dataUrl: '', // 如果type是music或video,则要提供数据链接,默认为空
success: function () {
// 用户确认分享后执行的回调函数
},
cancel: function () {
// 用户取消分享后执行的回调函数
}
});
wx.onMenuShareQQ({//分享到QQ
title: '<?=$weixindata['title']?>', // 分享标题
desc: '<?=$weixindata['description']?>', // 分享描述
link: '<?=$weixindata['link']?>', // 分享链接
imgUrl: '<?=$weixindata['pic']?>' // 分享图标
});
wx.onMenuShareWeibo({//分享到腾讯微博
title: '<?=$weixindata['title']?>', // 分享标题
desc: '<?=$weixindata['description']?>', // 分享描述
link: '<?=$weixindata['link']?>', // 分享链接
imgUrl: '<?=$weixindata['pic']?>' // 分享图标
});
wx.onMenuShareQZone({//分享到QQ空间
title: '<?=$weixindata['title']?>', // 分享标题
desc: '<?=$weixindata['description']?>', // 分享描述
link: '<?=$weixindata['link']?>', // 分享链接
imgUrl: '<?=$weixindata['pic']?>' // 分享图标
});

// config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中。
});

</script>
<div class="wrap">

</div>
</body>
</html>


 

以上就是开发过程中的代码部分,php部分的代码没有优化,不足之处还望指正,若有疑惑之处可以QQ我:991769422;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息