赞
踩
后台用到的公共方法(写入common.php文件的)
1.发送HTTP请求方法,用于获取code。
- /**
- * 发送HTTP请求方法
- * @param string $url 请求URL
- * @param array $params 请求参数
- * @param string $method 请求方法GET/POST
- * @return array $data 响应数据
- */
- function httpCurl($url, $params, $method = 'POST', $header = array(), $multi = false){
- date_default_timezone_set('PRC');
- $opts = array(
- CURLOPT_TIMEOUT => 30,
- CURLOPT_RETURNTRANSFER => 1,
- CURLOPT_SSL_VERIFYPEER => false,
- CURLOPT_SSL_VERIFYHOST => false,
- CURLOPT_HTTPHEADER => $header,
- CURLOPT_COOKIESESSION => true,
- CURLOPT_FOLLOWLOCATION => 1,
- CURLOPT_COOKIE =>session_name().'='.session_id(),
- );
- /* 根据请求类型设置特定参数 */
- switch(strtoupper($method)){
- case 'GET':
- // $opts[CURLOPT_URL] = $url . '?' . http_build_query($params);
- // 链接后拼接参数 & 非?
- $opts[CURLOPT_URL] = $url . '?' . http_build_query($params);
- break;
- case 'POST':
- //判断是否传输文件
- $params = $multi ? $params : http_build_query($params);
- $opts[CURLOPT_URL] = $url;
- $opts[CURLOPT_POST] = 1;
- $opts[CURLOPT_POSTFIELDS] = $params;
- break;
- default:
- throw new Exception('不支持的请求方式!');
- }
- /* 初始化并执行curl请求 */
- $ch = curl_init();
- curl_setopt_array($ch, $opts);
- $data = curl_exec($ch);
- $error = curl_error($ch);
- curl_close($ch);
- if($error) throw new Exception('请求发生错误:' . $error);
- return $data;
- }
2.微信信息解密方法
- /**
- * 微信信息解密
- * @param string $appid 小程序id
- * @param string $sessionKey 小程序密钥
- * @param string $encryptedData 在小程序中获取的encryptedData
- * @param string $iv 在小程序中获取的iv
- * @return array 解密后的数组
- */
- function decryptData( $appid , $sessionKey, $encryptedData, $iv ){
- $OK = 0;
- $IllegalAesKey = -41001;
- $IllegalIv = -41002;
- $IllegalBuffer = -41003;
- $DecodeBase64Error = -41004;
-
- if (strlen($sessionKey) != 24) {
- return $IllegalAesKey;
- }
- $aesKey=base64_decode($sessionKey);
-
- if (strlen($iv) != 24) {
- return $IllegalIv;
- }
- $aesIV=base64_decode($iv);
-
- $aesCipher=base64_decode($encryptedData);
-
- $result=openssl_decrypt( $aesCipher, "AES-128-CBC", $aesKey, 1, $aesIV);
- $dataObj=json_decode( $result );
- if( $dataObj == NULL )
- {
- return $IllegalBuffer;
- }
- if( $dataObj->watermark->appid != $appid )
- {
- return $DecodeBase64Error;
- }
- $data = json_decode($result,true);
-
- return $data;
- }
3.请求过程中因为编码原因+号变成了空格,需要用下面的方法转换回来
- /**
- * 请求过程中因为编码原因+号变成了空格
- * 需要用下面的方法转换回来
- */
- function define_str_replace($data)
- {
- return str_replace(' ','+',$data);
- }
控制器里写入的代码
- public function weixinlogin()
- {
- $get = input('get.');
- //获取session_key
- $params['appid']= '小程序ID';
- $params['secret']= '小程序密钥';
- $params['js_code']= define_str_replace($get['code']);
- $params['grant_type']= 'authorization_code';
- $http_key = httpCurl('https://api.weixin.qq.com/sns/jscode2session', $params, 'GET');
- $session_key = json_decode($http_key,true);
- if(!empty($session_key['session_key'])){
- $appid = $params['appid'];
- $encryptedData= urldecode($get['encryptedData']);
- $iv = define_str_replace($get['iv']);
- $errCode = decryptData($appid,$session_key['session_key'],$encryptedData,$iv);
- dump($errCode); //打印获取的数据
- }else{
- echo '获取session_key失败!';
- }
- }
小程序JS因为getUserInfo方法将不再出现授权弹窗,请使用 <button open-type="getUserInfo"></button> 引导用户主动进行授权操作,
所以需要在页面加一个引导用户授权的按钮在js页面data里加一个
- data: {
- canIUse: wx.canIUse('button.open-type.getUserInfo')
- },
wxml里也需要加一个
<button wx:if="{{canIUse}}" open-type="getUserInfo" bindgetuserinfo="bindGetUserInfo">授权登录</button>
- onLoad: function() {
- wx.login({//login流程
- success: function (res) {//登录成功
- if (res.code) {
- var code = res.code;
- wx.getUserInfo({//getUserInfo流程
- success: function (res2) {//获取userinfo成功
- var encryptedData = encodeURIComponent(res2.encryptedData);//一定要把加密串转成URI编码
- var iv = res2.iv;
- //请求自己的服务器
- Login(code,encryptedData,iv);
- }
- })
- } else {
- console.log('获取用户登录态失败!' + res.errMsg)
- }
- }
- });
- function Login(code,encryptedData,iv){
- //创建一个dialog
- wx.showToast({
- title: '正在登录...',
- icon: 'loading',
- duration: 10000
- });
- //请求服务器
- wx.request({
- url: '你的服务器API接口',
- data: {
- code:code,
- encryptedData:encryptedData,
- iv:iv
- },
- method: 'GET', // OPTIONS, GET, HEAD, POST, PUT, DELETE, TRACE, CONNECT
- header: {
- 'content-type': 'application/json'
- }, // 设置请求的 header
- success: function (res) {
- // success
- wx.hideToast();
- console.log('服务器返回'+res.data);
-
- },
- fail: function () {
- // fail
- // wx.hideToast();
- },
- complete: function () {
- // complete
- }
- })
- }
- }
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。