记录使用EasyWeChat做微信小程序登陆和其他操作

1.微信小程序登陆

关于后端:fastadmin加密生成token-CSDN博客

思路:

通过easywechat+fastadmin,

(1)== 用户端登陆(获取code) -> 请求后端接口获取session_key -> 用户端保存session_key

复制代码
use EasyWeChat\Foundation\Application;
use EasyWeChat\Factory;


public function getSessionKey(){
        $code = $this->request->post('code');
        $config = [
            'app_id' => 'wx65ae3f41d0714e10',
            'secret' => 'e79ea0badcc0a4f1c549c55a530660cf',
            'token' => 'easywechat',
            'aes_key' => '......',

            'http' => [
                'throw'  => true, // 状态码非 200、300 时是否抛出异常,默认为开启
                'timeout' => 5.0,
                'retry' => true, // 使用默认重试配置
            ],
        ];
        $app = Factory::miniProgram($config); // 这个是小程序的
//        $app = Factory::officialAccount($config); // 这个是公众号的
        // 使用 SDK 中的相关功能来获取 session_key
        $data = $app->auth->session($code);
        $this->success('获取session_key成功', $data);
    }

此刻就获取到了:session_key(很重要)、openid。

注意这里的this指向。

复制代码
// 前端uniapp
getSessionKey() {
				var that = this
				uni.login({
					success(info) {
						console.log('login信息', info)
						var postData = {
							code: info.code
						}
						getApp().posturl('Wechat/getSessionKey', postData).then(res => {
							console.log(res)
							that.session_key = res.data.session_key
							console.log('========',that.session_key)
						});
					}
				})
			}
2.微信小程序授权用户信息

用户端获取用户信息(获取 iv + encryptedData + signature + session_key )-> 请求后端接口获取token -> 用户端保存token (可以控制时间)

复制代码
public function getUserInfo(){
        // 获取得到avatarUrl、nickName、openId,进行存储
        $data = $this -> app -> encryptor->decryptData($this -> post['session_key'], $this -> post['iv'], $this -> post['encryptedData']);
        $userModel = new HcdrspUser();
        $result = $userModel->where('openid', $data['openId'])->find();
        if($result){
            $this->success('获取用户信息成功', $data);
        }else{
            $userModel->openid = $data['openId'];
            $userModel->avatarUrl = $data['avatarUrl'];
            $userModel->name = $data['nickName'];
            // 创建时间
            $userModel->createtime = time();
            $userModel->save();
            $this->success('欢迎新用户', $data);
        }
    }

getuserinfo(e){
				console.log('getuserinfo用户信息',e);
				console.log('session_key信息',this.session_key);
				var postData = {
					iv: e.detail.iv,
					encryptedData:e.detail.encryptedData,
					session_key: this.session_key
				}
				getApp().posturl('Wechat/getUserInfo', postData).then(res => {
					console.log(res)
					this.avatarUrl = res.data.avatarUrl
					this.nickName = res.data.avatarUrl
					let openId = res.data.openId
					uni.setStorageSync('openId',openId)
				});
			},
3. 微信小程序获取手机号

前端:

复制代码
<button open-type="getPhoneNumber" @getphonenumber="onGetPhoneNumber">授权并获取手机号</button>

onGetPhoneNumber(e){
				if(this.nickName === ''){
					uni.showToast({
						icon:'none',
						title:'请先登陆'
					})
					return
				}
				console.log('getPhoneNumber用户信息',e);
				console.log('session_key信息',this.session_key);
				var postData = {
					iv: e.detail.iv,
					encryptedData:e.detail.encryptedData,
					session_key: this.session_key
				}
				getApp().posturl('Wechat/getPhoneNumber', postData).then(res => {
					console.log(res)
					this.phoneNumber = res.data.phoneNumber
				});
			},

后端:

复制代码
/*
     * 获取手机号
     */
    public function getPhoneNumber(){
        $data = $this -> app -> encryptor->decryptData($this -> post['session_key'], $this -> post['iv'], $this -> post['encryptedData']);
        $userModel = new HcdrspUser();
        $result = $userModel->where('phone', $data['phoneNumber'])->find();
        if($result){
            $this->success('已存在手机号', $data);
        }else{
            $userModel->phone = $data['phoneNumber'];
            $userModel->save();

            $this->success('获取手机号成功', $data);
        }
    }
相关推荐
克里斯蒂亚诺更新41 分钟前
微信小程序app.js中每30秒调用一次wx.getLocation
javascript·微信小程序·小程序
CChenhire2 小时前
教育机构作图:含拼团 / 课程封面模板,适配小程序
小程序
低代码布道师2 小时前
少儿舞蹈小程序(21)我的页面搭建
低代码·小程序
说私域20 小时前
开源AI大模型、AI智能名片与S2B2C商城小程序:用户需求满足的底层逻辑与实践路径
人工智能·小程序·开源
2501_9160074721 小时前
前端开发工具都有哪些?常用前端开发工具清单与场景化推荐
android·ios·小程序·https·uni-app·iphone·webview
2501_915909061 天前
iOS 应用上架全流程解析,苹果应用发布步骤、ipa 上传工具、TestFlight 测试与 App Store 审核经验
android·macos·ios·小程序·uni-app·cocoa·iphone
Nan_Shu_6142 天前
学习:uniapp全栈微信小程序vue3后台-额外/精彩报错篇
前端·学习·微信小程序·小程序·uni-app·notepad++
尘似鹤2 天前
微信小程序学习(三)补充
学习·微信小程序
老华带你飞2 天前
机电公司管理小程序|基于微信小程序的机电公司管理小程序设计与实现(源码+数据库+文档)
java·数据库·vue.js·spring boot·微信小程序·小程序·机电公司管理小程序
涛声依旧2 天前
基于springBoot鲜花商城小程序
java·spring·微信小程序