久久99久久人婷婷精品综合_超碰aⅴ人人做人人爽欧美_亚洲电影第三页_日韩欧美一中文字暮专区_波多野结衣的一区二区三区_婷婷在线播放_人人视频精品_国产精品日韩精品欧美精品_亚洲免费黄色_欧美性猛交xxxxxxxx

使用UniApp實現(xiàn)小程序的微信登錄功能的代碼詳解

這篇文章主要講解了使用UniApp實現(xiàn)小程序的微信登錄功能的代碼詳解,內(nèi)容清晰明了,對此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會有幫助。

在醴陵等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都網(wǎng)站制作、網(wǎng)站設(shè)計 網(wǎng)站設(shè)計制作定制制作,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站制作,全網(wǎng)整合營銷推廣,外貿(mào)網(wǎng)站建設(shè),醴陵網(wǎng)站建設(shè)費(fèi)用合理。

1.微信登錄思路:

  • 在main.js 中封裝公共函數(shù),用于判斷用戶是否登錄
  • 在main.js 中分定義全局變量,用于存儲接口地址
  • 如果沒有登錄、則跳轉(zhuǎn)至登錄頁面
  • 進(jìn)入登錄頁面
  • 通過 wx.login 獲取用戶的 code
  • 通過 code 獲取用戶的 SessionKey、OpenId 等信息【本應(yīng)后臺接口、但是此處使用js發(fā)送請求】
  • 通過 openId 調(diào)用后臺 Api 獲取用戶的信息
  • 獲取成功,則說明已經(jīng)授權(quán)過了,直接登錄成功
  • 獲取失敗,則說明沒有授權(quán)過,需要授權(quán)之后才能進(jìn)行登錄
  • 用戶點擊頁面微信登錄按鈕【 <button open-type="getUserInfo"></button>】
  • 獲取用戶數(shù)據(jù),然后調(diào)用后臺接口寫入數(shù)據(jù)庫

2.在 applets/main.js 中添加如下

// 封裝全局登錄函數(shù)
// backpage, backtype 2個參數(shù)分別代表:
// backpage : 登錄后返回的頁面
// backtype : 打開頁面的類型[1 : redirectTo 2 : switchTab]
Vue.prototype.checkLogin = function( backpage, backtype ){
	// 同步獲取本地數(shù)據(jù)(uid、隨機(jī)碼、用戶名、頭像)
	var user_id = uni.getStorageSync('user_id');
	var user_nu = uni.getStorageSync('user_nu');
	var user_nm = uni.getStorageSync('user_nm');
	var user_fa = uni.getStorageSync('user_fa');
	if( user_id == '' || user_nu == '' || user_fa == ''){
		// 使用重定向的方式跳轉(zhuǎn)至登錄頁面
		uni.redirectTo({url:'../login/login&#63;backpage='+backpage+'&backtype='+backtype});
		return false;
	}
	// 登錄成功、已經(jīng)登錄返回數(shù)組 [用戶 id, 用戶隨機(jī)碼, 用戶昵稱, 用戶表情]
	return [user_id, user_nu, user_nm, user_fa];
}
// 定義一個全局的請求地址
Vue.prototype.apiServer = 'http://0608.cc/'

3.在 pages/login/login.vue 中添加如下

<template>
	<view>
		<!-- login view html start -->
		<view>
			<view>
				<view class="header"><image src="/static/img/public/login-wx.png"></image></view>
				<view class="content">
					<view>申請獲取以下權(quán)限</view>
					<text>獲得你的公開信息(昵稱,頭像、地區(qū)等)</text>
				</view>
				<button class="bottom" type="primary" open-type="getUserInfo" withCredentials="true" lang="zh_CN" @getuserinfo="wxGetUserInfo">授權(quán)登錄</button>
			</view>
		</view>
		<!-- login view html end -->
	</view>
</template>

<script>
export default {
	data() {
		return {
			appid: '*************',
			secret: '*************************',
			code: '',
			sessionKey: '',
			openId: '',
			userInfo: {
				avatarUrl: '',
				city: '',
				country: '',
				gender: 1,
				language: '',
				nickName: ''
			},
			pageOption: {}
		};
	},
	methods: {
		// 第一授權(quán)獲取用戶信息 ===》按鈕觸發(fā)
		wxGetUserInfo() {
			let _self = this;
			// 1.獲取用戶的信息
			uni.getUserInfo({
				provider: 'weixin',
				success: ( infoRes ) => {
					console.log( infoRes )
					_self.userInfo = infoRes.userInfo
					// 2.提交數(shù)據(jù)到后臺、寫入數(shù)據(jù)庫
					uni.request({
						url: _self.apiServer + 'appletsUserInfo',
						data: {
							openid: _self.openId,
							avatarUrl: _self.userInfo.avatarUrl,
							city: _self.userInfo.city,
							country: _self.userInfo.country,
							gender: _self.userInfo.gender,
							language: _self.userInfo.language,
							nickName: _self.userInfo.nickName
						},
						method: 'POST',
						success: res => {
							if( res.data.code != 0 )
							{
								uni.showToast({ title: res.data.msg, icon: 'none' });
								return false;
							}
							// 用戶信息寫入緩存
							uni.showToast({title: '登錄成功'})
							uni.setStorageSync( 'user_id', res.data.res.u_id );
							uni.setStorageSync( 'user_nm', res.data.res.u_nickName );
							uni.setStorageSync( 'user_fa', res.data.res.u_avatarUrl );
							uni.setStorageSync( 'user_nu', res.data.res.u_regtime );
							// 然后跳回原頁面
							if( _self.pageOption.backtype == 1 )
							{
								uni.redirectTo({ url: _self.pageOption.backpage })
							}else{
								uni.switchTab({ url: _self.pageOption.backpage })
							}
						},
						fail: () => {
							uni.showToast({ title: '用戶信息操作失敗', icon: 'none' });
						}
					});
				},
				fail: () => {
					uni.showToast({ title: '獲取用戶信息失敗', icon: 'none' });
				}
			});
			return false
		},
		// 登錄
		login() {
			let _self = this;

			// 0. 顯示加載的效果
			uni.showLoading({
				title: '登錄中...'
			});

			// 1. wx 獲取登錄用戶 code
			uni.login({
				provider: 'weixin',
				success: loginRes => {
					console.log(loginRes);
					_self.code = loginRes.code;
					// 2. 將用戶登錄code傳遞到后臺置換用戶SessionKey、OpenId等信息
					uni.request({
						url:
							'https://api.weixin.qq.com/sns/jscode2session&#63;appid=' +
							_self.appid +
							'&secret=' +
							_self.secret +
							'&js_code=' +
							_self.code +
							'&grant_type=authorization_code',
						success: codeRes => {
							console.log(codeRes);
							_self.openId = codeRes.data.openid;
							_self.sessionKey = codeRes.data.session_key;
							// 3.通過 openId 判斷用戶是否授權(quán)
							uni.request({
								url: _self.apiServer + 'loginApplets',
								data: {
									openid: _self.openId
								},
								method: 'POST',
								success: openIdRes => {
									console.log(openIdRes);
									// 隱藏loading
									uni.hideLoading();
									// 還沒授權(quán)登錄、請先授權(quán)然后登錄
									if (openIdRes.data.code == 1) {
										// 提示消息、讓用戶授權(quán)
										uni.showToast({ title: openIdRes.data.msg, icon: 'none' });
									}
									// 已經(jīng)授權(quán)了、查詢到用戶的數(shù)據(jù)了
									if (openIdRes.data.code == 0) {
										// 用戶信息寫入緩存
										uni.showToast({title: '登錄成功'})
										uni.setStorageSync( 'user_id', openIdRes.data.res.u_id );
										uni.setStorageSync( 'user_nm', openIdRes.data.res.u_nickName );
										uni.setStorageSync( 'user_fa', openIdRes.data.res.u_avatarUrl );
										uni.setStorageSync( 'user_nu', openIdRes.data.res.u_regtime );
										// 然后跳回原頁面
										if( _self.pageOption.backtype == 1 )
										{
											uni.redirectTo({ url: _self.pageOption.backpage })
										}else{
											uni.switchTab({ url: _self.pageOption.backpage })
										}
									}
								},
								fail: () => {
									uni.showToast({ title: '獲取授權(quán)信息失敗', icon: 'none' });
									return false;
								}
							});
						},
						fail: () => {
							uni.showToast({ title: '獲取 SesssionKey OpenId 失敗', icon: 'none' });
							return false;
						}
					});
				},
				fail: () => {
					uni.showToast({ title: '獲取 code 失敗', icon: 'none' });
					return false;
				}
			});
			return false;
		}
	},
	onLoad( options ) {
		// 接收跳轉(zhuǎn)的參數(shù)
		this.pageOption = options
		//默認(rèn)加載
		this.login();
	}
};
</script>

<style>
.header {
	margin: 90rpx 0 90rpx 50rpx;
	border-bottom: 1px solid #ccc;
	text-align: center;
	width: 650rpx;
	height: 300rpx;
	line-height: 450rpx;
}

.header image {
	width: 200rpx;
	height: 200rpx;
}

.content {
	margin-left: 50rpx;
	margin-bottom: 90rpx;
}

.content text {
	display: block;
	color: #9d9d9d;
	margin-top: 40rpx;
}

.bottom {
	border-radius: 80rpx;
	margin: 70rpx 50rpx;
	font-size: 35rpx;
}
</style>

在 pages/my/my.vue 中添加如下:

<template>
	<view>我的頁面</view>
</template>

<script>
var loginRes;
export default {
	data() {
		return {};
	},
	onLoad() {
		// 加載定義好的方法
		loginRes = this.checkLogin('../my/my', 2);
		// 沒有登錄成功,返回空
		if (!loginRes) {
			return;
		}
	},
	methods: {}
};
</script>

<style></style>

5.PHP 接口 loginApplets

public function loginApplets(Request $request, UserInfo $userInfo)
{
 // 獲取數(shù)據(jù)
 $data['u_openid'] = $request->param('openid', '');
 // 驗證數(shù)據(jù)
 $rule = [
  'u_openid' => 'require|max:200|min:10'
 ];
 $message = [
  'u_openid.require' => 'openid 不能為空',
  'u_openid.max'  => 'openid 格式錯誤',
  'u_openid.min'  => 'openid 格式錯誤'
 ];
 $validate = Validate::rule($rule)->message($message);
 if (!$validate->check($data)) {
  return json(['code' => 1, 'msg' => $validate->getError(), 'res' => null]);
 }
 // 根據(jù) openid 判斷是否存在
 $where['u_openid'] = $data['u_openid'];
 $user = $userInfo->selOne($where);
 if (!$user) {
  return json(['code' => 1, 'msg' => '還沒授權(quán)登錄、請先授權(quán)然后登錄', 'res' => $user]);
 }
 return json(['code' => 0, 'msg' => '已授權(quán)獲取到用戶的數(shù)據(jù)', 'res' => $user]);
}

6.PHP 接口 appletsUserInfo

public function appletsUserInfo(Request $request, UserInfo $userInfo)
{
 // 獲取數(shù)據(jù)
 $data['u_openid'] = $request->param('openid', '');
 $data['u_avatarUrl'] = $request->param('avatarUrl', '');
 $data['u_city'] = $request->param('city', '');
 $data['u_country'] = $request->param('country', '');
 $data['u_gender'] = $request->param('gender', '');
 $data['u_language'] = $request->param('language', '');
 $data['u_nickName'] = $request->param('nickName', '');
 // 驗證數(shù)據(jù)
 $rule = [
  'u_openid' => 'require|max:200|min:10',
  'u_avatarUrl' => 'require',
  'u_nickName' => 'require'
 ];
 $message = [
  'u_openid.require'  => 'openid 不能為空',
  'u_openid.max'   => 'openid 格式錯誤',
  'u_openid.min'   => 'openid 格式錯誤',
  'u_avatarUrl.require' => '用戶頭像 不能為空',
  'u_nickName.max'  => '用戶名 格式錯誤',
 ];
 $validate = Validate::rule($rule)->message($message);
 if (!$validate->check($data)) {
  return json(['code' => 1, 'msg' => $validate->getError(), 'res' => null]);
 }

 // 根據(jù) openid 判斷是否存在
 $where['u_openid'] = $data['u_openid'];
 $user = $userInfo->selOne($where);

 // 存在、執(zhí)行修改
 if ($user) {
  $user_res = $userInfo->updOne($where, $data);
  $res = [];
  $res['u_id'] = $user['u_id'];
  $res['u_regtime'] = $user['u_regtime'];
 }

 // 不存在、執(zhí)行添加
 if (empty($user)) {
  $res = [];
  $res = $data;
  $res['u_regtime'] = time();
  $res['u_id'] = $userInfo->addOne($res);
 }

 // 判斷是否添加成功
 if (empty($res['u_id'])) {
  return json(['code' => 1, 'msg' => '注冊失敗,返回重試', 'res' => null]);
 }
 return json(['code' => 0, 'msg' => 'ok', 'res' => $res]);
}

看完上述內(nèi)容,是不是對使用UniApp實現(xiàn)小程序的微信登錄功能的代碼詳解有進(jìn)一步的了解,如果還想學(xué)習(xí)更多內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

名稱欄目:使用UniApp實現(xiàn)小程序的微信登錄功能的代碼詳解
網(wǎng)站地址:http://www.js-pz168.com/article2/gppoic.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站排名網(wǎng)站策劃商城網(wǎng)站網(wǎng)頁設(shè)計公司面包屑導(dǎo)航Google

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名
久久99久久人婷婷精品综合_超碰aⅴ人人做人人爽欧美_亚洲电影第三页_日韩欧美一中文字暮专区_波多野结衣的一区二区三区_婷婷在线播放_人人视频精品_国产精品日韩精品欧美精品_亚洲免费黄色_欧美性猛交xxxxxxxx
欧美大片顶级少妇| 亚洲美女屁股眼交3| 一区二区三区在线观看国产| 另类小说综合欧美亚洲| 91免费视频大全| 日韩精彩视频| 欧美一二三区在线| 亚洲三级视频在线观看| 精品一区二区国语对白| 国产精品毛片va一区二区三区| 伊人色综合久久天天五月婷| 精品国产区一区| 亚洲综合色网站| 大胆欧美人体老妇| 日本在线免费观看一区| 日韩一二三区视频| 夜夜嗨av一区二区三区中文字幕| 国产乱人伦偷精品视频免下载| 国产视频一区二区三区四区| 在线观看不卡一区| 国产精品素人一区二区| 久久99这里只有精品| 国产精品亚洲综合| 欧美卡1卡2卡| 一区二区三区久久| 成人高清伦理免费影院在线观看| 日韩av在线一区二区三区| 91精品国产综合久久精品性色| 亚洲黄色尤物视频| 成人av网站在线| 中文字幕中文字幕在线中心一区 | 91视频在线观看| 日本丶国产丶欧美色综合| 国产欧美精品一区二区色综合朱莉 | 亚洲人成在线观看一区二区| 国产精品一区免费在线观看| 欧美日韩在线精品| 精品国产乱码久久| 青青草国产精品97视觉盛宴| 国产精品香蕉视屏| 欧美一区午夜精品| 爽爽淫人综合网网站| 成人91视频| 在线播放日韩导航| 亚洲成人tv网| 国产欧美一区二区视频| 91精品国产综合久久福利| 亚洲丶国产丶欧美一区二区三区| 91九色视频在线观看| 欧美日韩高清一区| 亚洲成人av福利| 国产日韩欧美二区| 精品国产欧美一区二区| 另类欧美日韩国产在线| 茄子视频成人在线观看| 久久久久久电影| 国产乱国产乱300精品| 杨幂一区欧美专区| 日韩一区有码在线| 中文字幕中文字幕一区| 国产91精品免费| 欧美专区日韩专区| 亚洲一卡二卡三卡四卡| 丁香五月网久久综合| 欧美变态凌虐bdsm| 激情图片小说一区| 视频在线观看成人| 18成人在线观看| 91免费看视频| 日韩精品一区二区三区在线观看| 麻豆专区一区二区三区四区五区| 日本成人黄色| ...xxx性欧美| 99re在线国产| 欧美va亚洲va| 国产不卡视频一区二区三区| 欧美无人高清视频在线观看| 亚洲成在人线在线播放| 久久99精品久久久久久水蜜桃| 久久久天堂av| 成人av资源站| 日韩欧美国产一区二区在线播放| 国产一区二区视频在线播放| 日本韩国一区二区三区| 亚洲成在人线在线播放| 日本午夜精品电影| 亚洲免费在线播放| 精品午夜一区二区| 国产精品毛片a∨一区二区三区 | 日本亚洲最大的色成网站www| 色视频一区二区三区| 亚洲免费视频成人| 快播亚洲色图| 亚洲乱码国产乱码精品精的特点 | 国产精品一区在线播放| 久久久精品国产99久久精品芒果| 成人久久18免费网站麻豆 | 中文字幕在线不卡一区二区三区| 成人久久18免费网站漫画| 久久久久国色av免费看影院| 9i看片成人免费高清| 精品国产亚洲一区二区三区在线观看| 风间由美一区二区av101| 欧美一级一级性生活免费录像| 国产精品一区在线观看你懂的| 欧美日韩国产另类一区| 精品制服美女丁香| 欧美日韩一本到| 国内精品视频一区二区三区八戒 | 日韩久久不卡| 亚洲国产精品尤物yw在线观看| 日本在线观看一区二区| 亚洲一区二区在线观看视频| 相泽南亚洲一区二区在线播放| 亚洲午夜影视影院在线观看| 一个色的综合| 麻豆国产精品一区二区三区| 欧美日韩极品在线观看一区| 国产精品综合二区| 日韩免费视频一区| 91麻豆免费看片| 国产精品免费视频网站| 久久艳妇乳肉豪妇荡乳av| 一区二区三区成人| 在线免费观看成人网| 另类调教123区| 欧美一区二区久久久| 99免费精品在线| 国产精品视频一二| 欧美日韩免费精品| 日韩高清不卡一区二区三区| 欧美日韩免费不卡视频一区二区三区| 国产精品中文字幕欧美| 精品99999| 国产视色精品亚洲一区二区| 亚洲一线二线三线久久久| 色综合中文字幕国产| 555夜色666亚洲国产免| 成人网在线免费视频| 国产日本一区二区| 欧美精品二区三区四区免费看视频 | 国产精品成人一区二区三区夜夜夜| 蜜桃久久影院| 日韩vs国产vs欧美| 91精品国产综合久久精品app| 91丨国产丨九色丨pron| 亚洲免费观看高清| 日本黄色一区二区| 国产.欧美.日韩| 国产精品丝袜一区| 亚洲一卡二卡| 国产高清精品久久久久| 欧美国产日产图区| 午夜精品一区二区在线观看的 | 欧美日韩aaa| 91丨porny丨在线| 亚洲综合一区在线| 欧美揉bbbbb揉bbbbb| 99久久精品免费看| 一区二区三区日韩精品| 欧美视频一区二区三区| 91在线精品一区二区三区| 亚洲精选视频免费看| 欧美系列在线观看| 91蜜桃免费观看视频| 亚洲影院免费观看| 91精品黄色片免费大全| 国产高清自拍一区| 日韩影院精彩在线| 日韩精品一区二区三区中文不卡 | 欧洲精品在线观看| 91精品国产高清久久久久久91裸体| 一区二区三区在线免费视频| 欧美蜜桃一区二区三区| 国产九色精品| 蜜臀久久99精品久久久久宅男| 久久综合av免费| 亚洲国产精品久久久久久女王| 国产精品一区二区久久不卡| 国产精品卡一卡二卡三| 欧美在线短视频| 国产精品美女黄网| 另类中文字幕网| 国产精品久久777777| 精品视频在线视频| 国产视色精品亚洲一区二区| 麻豆一区二区三| 国产精品理论在线观看| 欧美日韩一区二区三区高清| 国产伦精品一区二区三区四区免费 | 美女视频网站黄色亚洲| 中文字幕乱码亚洲精品一区| 色婷婷国产精品综合在线观看| 91精品网站| 老鸭窝一区二区久久精品| 国产精品美女www爽爽爽| 欧美日韩一区久久| 久久免费99精品久久久久久| 国产福利一区二区三区视频 | 日韩一区二区三区资源|