今天就跟大家聊聊有关thinkphp5框架结合mysql实现微信登录,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。
php代码
function curlHtml($url){ $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_HEADER, 0); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false); $output = curl_exec($ch); //释放curl句柄 curl_close($ch); return $output; } class Wechat { public $errmsg; //微信登录获取用户信息 public function getUserInfo() { //1.准备scope为snsapi_base网页授权页面 $redirect_url = config('system.site_url') . $_SERVER["REQUEST_URI"]; $baseurl = urlencode($redirect_url); $snsapi_base_url = 'https://open.weixin.qq.com/connect/oauth3/authorize?appid=' . config('system.appid') . '&redirect_uri=' . $baseurl . '&response_type=code&scope=snsapi_base&state=STATE#wechat_redirect'; //2.静默授权,获取code //页面跳转至redirect_uri/?code=CODE&state=STATE $code = input('code'); if (!isset($code) || empty($code)) { header('Location:' . $snsapi_base_url);exit(0); } //3.通过code换取网页授权access_token和openID $curl = 'https://api.weixin.qq.com/sns/oauth3/access_token?appid=' . config('system.appid') . '&secret=' . config('system.appsecret') . '&code=' . $code . '&grant_type=authorization_code'; $content = curlHtml($curl); $result = json_decode($content, true); if(!isset($result['openid'])) { $this->errmsg = $result['errmsg'];return false; } $openid = $result['openid']; $userinfo = $this->getUserByOpenid($openid); return $userinfo; } private function getUserByOpenid($openid) { //获取access_token $token_info = $this->curlGetWxAccessToken(); $access_token = $token_info['value']; //通过OpenID来获取用户基本信息 $url = "https://api.weixin.qq.com/cgi-bin/user/info?access_token=".$access_token."&openid=".$openid."&lang=zh_CN"; $content = curlHtml($url); $result = json_decode($content, true); return $result; } /** * [wxShare 微信分享] * @param [type] $url [description] * @return [type] [description] */ public function wxShare() { $noncestr = uniqid(); $timestamp = time(); $url = config('system.site_url') . $_SERVER["REQUEST_URI"]; // $redis = new \Redis; // $ticket_key = 'wx_ticket'; // $ticket = $redis->get($ticket_key); // if (!$ticket) { // $ticket = $this->getJsapiTicket(); // $redis->set($ticket_key, $ticket); // $redis->expire($ticket_key, 7200); // } $ticket = $this->getJsapiTicket(); if ($ticket) { $str = 'jsapi_ticket=' . $ticket . '&noncestr=' . $noncestr . '×tamp=' . $timestamp . '&url=' . $url; $signature = sha1($str); $return_data = [ 'noncestr' => $noncestr, 'timestamp' => $timestamp, 'signature' => $signature, 'appid' => config('system.appid'), 'link' => $url, ]; return $return_data; } } private function getJsapiTicket() { $map['keyname'] = 'Ticket'; $map['modifytime'] = array('GT', time() - 7200); $return = WxTokenModel::getOne('*', $map); if ($return) { return $return['value']; } else { $token_info = $this->curlGetWxAccessToken(); $access_token = $token_info['value']; $url = 'https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=' . $access_token . '&type=jsapi'; $output = curlHtml($url); $data = json_decode($output, true); if (isset($data['errcode']) && $data['errcode'] == 0) { $condition['keyname'] = 'Ticket'; $update_data['modifytime'] = time(); $update_data['value'] = $data['ticket']; $up_result = WxTokenModel::updateData($condition, $update_data); if ($up_result !== false) { return $data['ticket']; } } } return false; } private function curlGetWxAccessToken() { $map['keyname'] = 'AccessToken'; $map['modifytime'] = array('GT', time() - 7200); $return = WxTokenModel::getOne('*', $map); if ($return) { return $return; } else { $url = 'https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=' . config('system.appid') . '&secret=' . config('system.appsecret'); $output = curlHtml($url); $data = json_decode($output, true); if ($data && isset($data['access_token'])) { $condition['keyname'] = 'AccessToken'; $update_data['modifytime'] = time(); $update_data['value'] = $data['access_token']; $up_result = WxTokenModel::updateData($condition, $update_data); if ($up_result !== false) { return $update_data; } } } return false; } }
html代码
<script type="text/javascript" src="http://res.wx.qq.com/open/js/jweixin-1.2.0.js"></script> <script> wx.config({ debug: false, appId: '{$appid}', // 必填,公众号的唯一标识 timestamp: '{$timestamp}', // 必填,生成签名的时间戳 nonceStr: '{$noncestr}', // 必填,生成签名的随机串 signature: '{$signature}',// 必填,签名,见附录1 jsApiList: ['onMenuShareTimeline'] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2 }); wx.ready(function () { // 分享到朋友圈 wx.onMenuShareTimeline({ title: '', // 名 link: '{$link}', // 地址 imgUrl: '', // 分享的图标 success: function () { // 用户确认分享后执行的回调函数 }, cancel: function () { // 用户取消分享后执行的回调函数 } }); }); </script>
看完上述内容,你们对thinkphp5框架结合mysql实现微信登录有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。