本文實(shí)例為大家分享了微信小程序獲取用戶信息及手機(jī)號(hào)的具體代碼,供大家參考,具體內(nèi)容如下
霞山網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)!從網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、響應(yīng)式網(wǎng)站建設(shè)等網(wǎng)站項(xiàng)目制作,到程序開發(fā),運(yùn)營維護(hù)。創(chuàng)新互聯(lián)從2013年成立到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)。
wxml頁面
login prompt To provide better service, click "allow" in the prompt box later! login prompt To provide better service, click "allow" in the prompt box later!
wxss頁面
.dialog-mask{ position: fixed; z-index: 1000; top: 0; right: 0; left: 0; bottom: 0; background: rgba(0, 0, 0, 0.3); } .dialog-info{ position: fixed; z-index: 5000; width: 80%; max-width: 600rpx; top: 50%; left: 50%; -webkit-transform: translate(-50%, -50%); transform: translate(-50%, -50%); background-color: #FFFFFF; text-align: center; border-radius: 3px; overflow: hidden; } .dialog-title{ font-size: 36rpx; padding: 30rpx 30rpx 10rpx; } .dialog-content{ padding: 10rpx 30rpx 20rpx; min-height: 80rpx; font-size: 32rpx; line-height: 1.3; word-wrap: break-word; word-break: break-all; color: #999999; } .dialog-footer{ display: flex; align-items: center; position: relative; line-height: 90rpx; font-size: 34rpx; } .dialog-btn{ display: block; -webkit-flex: 1; flex: 1; position: relative; color: #3CC51F; }
js頁面
data: { userName: '', pwd: '', getUserInfoFail: '', userInfo: [], hasUserInfo: '', phone: '', config: { tipsshow1: true, tipsshow2: false } }, /** * 生命周期函數(shù)--監(jiān)聽頁面加載 */ onLoad: function(options) { var that = this; //用戶是否授權(quán)過手機(jī)號(hào) wx.getStorage({ key: 'phone', success: function (res) { that.setData({ config: { tipsshow1: false, tipsshow2: false }, }) } }) //是否授權(quán)過用戶信息 wx.getSetting({ success: function(res) { if (res.authSetting['scope.userInfo']) { // 已經(jīng)授權(quán),可以直接調(diào)用 getUserInfo 獲取頭像昵稱 wx.getUserInfo({ success: function(res) { that.setData({ userInfo: res.userInfo, config: { tipsshow1: false, }, }) } }) } } }) }, getPhoneNumber: function(e) { if (e.detail.errMsg == "getPhoneNumber:fail user deny") return; //用戶允許授權(quán) wx.showLoading() var self = this //1. 調(diào)用登錄接口獲取臨時(shí)登錄code wx.login({ success: res => { console.log(res, 555) if (res.code) { //2. 訪問登錄憑證校驗(yàn)接口獲取session_key、openid wx.request({ url: "xxxxxxx/index/author/login", data: { 'js_code': res.code, }, method: 'GET', // OPTIONS, GET, HEAD, POST, PUT, DELETE, TRACE, CONNECT header: { 'content-type': 'application/json' }, // 設(shè)置請求的 header success: function(data) { console.log(data, data) if (data.statusCode == 200) { //3. 解密 wx.request({ url: 'xxxxxx/index/author/number', data: { 'appid': data.data.appid, 'sessionKey': data.data.session_key, 'encryptedData': e.detail.encryptedData, 'iv': e.detail.iv, }, method: 'GET', // OPTIONS, GET, HEAD, POST, PUT, DELETE, TRACE, CONNECT header: { 'content-type': 'application/json' }, // 設(shè)置請求的 header success: function(data2) { wx.hideLoading() console.log(data2.data.phoneNumber) if (data2.statusCode == 200 && data2.data.phoneNumber) { self.setData({ phone: data2.data.phoneNumber, config: { tipsshow1: false, tipsshow2: false, }, }) wx.setStorageSync('phone', data2.data.phoneNumber); if (self.data.userInfo != '') { wx.request({ url: 'xxxx/index/author/regist', data: { username: self.data.userInfo.nickName, sex: self.data.userInfo.gender, phone: self.data.phone, pwd: 123456, avatarimg: self.data.userInfo.avatarUrl }, success: function(data) { console.log(data.data,56565) if (data.data != null) { wx.showToast({ title: '登錄中...', icon: 'loading', duration: 2000 }) wx.navigateTo({ url: '../managementList/managementList'//管理頁面 }) } } }); } console.log(self.data, 526336) } }, fail: function(err) { console.log(err); } }) } }, fail: function(err) { console.log(err); } }) } } }) }, getUserInfo: function(e) { var that = this; console.log(e.detail.userInfo, "getuserinfo") if (e.detail.userInfo) { that.setData({ userInfo: e.detail.userInfo, config: { tipsshow1: false, tipsshow2: true, }, }) console.log(that.data.userInfo); } else { console.log("獲取信息失敗") } },
PHP后端
<?php namespace app\index\controller; use think\Controller; use app\admin\model\UserRecharge; use think\Db; class Author extends Controller { /** * 發(fā)送HTTP請求方法 * @param string $url 請求URL * @param array $params 請求參數(shù) * @param string $method 請求方法GET/POST * @return array $data 響應(yīng)數(shù)據(jù) */ 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(), ); /* 根據(jù)請求類型設(shè)置特定參數(shù) */ switch(strtoupper($method)){ case 'GET': // $opts[CURLOPT_URL] = $url . '?' . http_build_query($params); // 鏈接后拼接參數(shù) & 非? $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('不支持的請求方式!'); } /* 初始化并執(zhí)行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('請求發(fā)生錯(cuò)誤:' . $error); return $data; } /** * 微信信息解密 * @param string $appid 小程序id * @param string $sessionKey 小程序密鑰 * @param string $encryptedData 在小程序中獲取的encryptedData * @param string $iv 在小程序中獲取的iv * @return array 解密后的數(shù)組 */ 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 $result; } /** * 請求過程中因?yàn)榫幋a原因+號(hào)變成了空格 * 需要用下面的方法轉(zhuǎn)換回來 */ function define_str_replace($data) { return str_replace(' ','+',$data); } //獲取手機(jī)號(hào) public function number($appid , $sessionKey, $encryptedData, $iv) { include_once (ROOT_PATH."./public/author/wxBizDataCrypt.php"); //引入 wxBizDataCrypt.php 文件 $appid = $appid; $sessionKey = $sessionKey; $encryptedData= $encryptedData; $iv = $iv; $data = ''; $pc = new \WXBizDataCrypt($appid, $sessionKey); //注意使用\進(jìn)行轉(zhuǎn)義 $errCode = $pc->decryptData($encryptedData, $iv, $data ); if ($errCode == 0) { print($data . "\n"); } else { print($errCode . "\n"); } } //微信登錄 public function login(){ $get = input('get.'); $param['appid'] = 'xxxxxxxxxx'; //小程序id $param['secret'] = 'xxxxxxxxxx'; //小程序密鑰 $param['js_code'] = $this->define_str_replace($get['js_code']); $param['grant_type'] = 'authorization_code'; $http_key = $this->httpCurl('https://api.weixin.qq.com/sns/jscode2session', $param, 'GET'); $session_key = json_decode($http_key,true);//獲取openid和session_key //print_r(http_build_query($param)); if (!empty($session_key['session_key'])) { $data['appid'] = $param['appid']; $data['session_key'] = $session_key['session_key']; return json($data); }else{ echo '獲取session_key失??!'; } } //用戶注冊 public function regist($username = "",$sex = "", $phone = "",$password = "",$avatarimg = "") { if ($phone){ //判斷該用戶是否已經(jīng)注冊 $userdata = Db::name('user')->where('phone',$phone)->find(); if ($userdata){ return json_encode(2); } //整合數(shù)組 $salt = '1122'; $password = Md5(Md5($password) . $salt); $data = [ 'name' => $username, 'sex' => $sex, 'phone' => $phone, 'password' => $password, 'avatarimg' => $avatarimg, 'logtime' => date("Y-m-d H:i:s"), 'addTime' => date("Y-m-d H:i:s") ]; //注冊新用戶 $userid = db('user')->insertGetId($data); if ($userid){ return json_decode(1); }else{ return json_encode(0); } } } }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。