2020-07-28 uniapp微信登录实现

一、微信登录
1、完整代码

<template>
    <view class="data-xuehu">
        <view class="page data-xuehu" :style="'top:'+navBarHeight+'px'">
            <view class="bg_img data-xuehu">
                <!-- 头像 -->
                <view class="infoWrap data-xuehu">
                    <view class="avatar data-xuehu">
                        <image src="/static/originAvatar.png" class="data-xuehu"></image>
                    </view>
                </view>
            </view>
            <view class="uni-padding-wrap uni-common-mt">
                <button type="primary" @tap="oauth('weixin')">微信用户快速登录</button>
                <button type="default">输入手机号码登录</button>
            </view>
        </view>
    </view>
</template>

<script>
    export default {
        data() {
            return {
                navBarHeight: 0
            }
        },
        methods: {
            oauth(value) {
                uni.login({
                    provider: value,
                    success: function(loginRes) {
                        // console.log(loginRes.authResult);
                        // 获取用户信息
                        uni.getUserInfo({
                            provider: value,
                            success: function(infoRes) {
                                // console.log('用户昵称为:' + infoRes.userInfo.nickName);
                                console.log(infoRes);
                            }
                        });
                    }
                });
            }
        }
    }
</script>

<style>
    @import url("login.css");
    uni-button {
        margin-bottom: 13px;
    }
</style>

2、重点讲解:


image.png

image.png

3、使用HBuilder真机调试中的调试工具查看登录的信息


image.png

二、把获取到的信息保存到数据库
1、向后台方法发送请求
(1)代码

<script>
    export default {
        data() {
            return {
                navBarHeight: 0
            }
        },
        methods: {
            oauth(value) {
                uni.login({
                    provider: value,
                    success: function(loginRes) {
                        // console.log(loginRes.authResult);
                        // 获取用户信息
                        uni.getUserInfo({
                            provider: value,
                            success: function(infoRes) {
                                // console.log('用户昵称为:' + infoRes.userInfo.nickName);
                                console.log(infoRes);
                                let url = 'login/wxlogin';
                                this.$xuehu.request({
                                    url: url,
                                    data: {
                                        'nickname':infoRes.userInfo.nickName,
                                        'avatarurl':infoRes.userInfo.avatarUrl,
                                        'openid':infoRes.userInfo.openId,
                                    },
                                    method: 'POST'
                                }).then(res => {
                                    console.log('返回信息:');
                                    console.log(res.data);
                                    //将返回信息存入缓存 
                                })
                            },
                            fail() {
                                uni.showToast({
                                    icon:'none',
                                    title:'登录失败'
                                })
                            }
                        });
                    },
                    fail(err) {
                        console.error('授权登录失败:'+JSON.stringify(err));
                    }
                });
            }
        }
    }
</script>

2、后台微信登录方法
(1)创建空的控制器
php think make:controller api@User --plain

<?php
namespace app\api\controller;
use app\api\model\User as UserModel;

class User
{
    //微信用户登录
    public function wxLogin() {
        return UserModel::_wxLogin();
    }
}

(2)创建验证器 api\Validate\User.php

namespace app\api\validate;

use think\Validate;

class User extends Validate
{
    /**
     * 定义验证规则
     * 格式:'字段名' =>  ['规则1','规则2'...]
     *
     * @var array
     */ 
    protected $rule = [
        'nickname' => 'require',
        'avatarurl' => 'require',
        'openid' => 'require'
    ];
    
    /**
     * 定义错误信息
     * 格式:'字段名.规则名' =>  '错误信息'
     *
     * @var array
     */ 
    protected $message = [
        'nickname.require' => '昵称不能为空',
        'avatarurl.require' => '头像不能为空',
        'openid.require' => 'openid不能为空',
    ];
}

(3)创建模型,模型还需要引入验证类型
知识点:
1.模型中有调用common.php公共文件的消息返回方法shouMsg;
2.对请求的数据nickname、openid、avatarurl进行了验证判断,引用validateField,注意要引入验证类
3.创建了设置token方法 setToken并在 _wxLogin方法中进行了引用;
4.setToken方法通过获取id和nickname并根据设定的规则生成token,把(id、存活时间、生成的唯一token)写入到redis中进行缓存;
5.模型对openid是否存在(微信登录会自动获取见3,)是否存在进行判断,存在登录成功写入radis,不存在储存基本信息存入信息至radis;
php think make:mode api@User

<?php
declare (strict_types = 1);

namespace app\api\model;

use think\Model;
use app\api\validate\User as UserValidate;
use Redis;

/**
 * @mixin think\Model
 */
class User extends Model
{
    //微信用户登录实现
    public static function _wxLogin(){
        //验证用户提交的数据
        $data = request()->post();

        $result = self::validateField($data);
        if($result === true){
//        判断 user_bind openid 是否存在
//        存在,生成token,返回数据
            $user_bind = UserBind::where('openid', $data['openid'])->find();
            if($user_bind){
                // 设置token,写入redis
                $token = self::setToken($user_bind['id'], $data['nickname']);
                return showMsg(1,'登录成功', ['user_id'=>$user_bind['user_id'], 'token'=>$token]);
            }else{
                // 不存在,新增一条记录,生成token,返回数据
                $userBind = UserBind::create([
                    'openid' => $data['openid'],
                    'nickname' => $data['nickname'],
                    'avatarurl' => $data['avatarurl']
                ]);
                if($userBind){
                    // 设置token,写入redis
                    $token = self::setToken($userBind->id, $data['nickname']);
                    return showMsg(1,'登录成功', ['user_id'=>0, 'token'=>$token]);
                }else{
                    return showMsg(0,'登录失败', null);
                }
            }

        }else{
            return $result;
        }
    }

    // 设置token
    private static function setToken($id=0, $nickname=''){
        $token = md5($nickname.time().rand(1000,9999));

        $redis = new Redis();
        $redis->connect(config('cache.stores.redis.host'), config('cache.stores.redis.port'));
        $redis->auth(config('cache.stores.redis.password'));
        $redis->setex('weixin:'.$id, 86400, $token); //有效期一天

        return $token;
    }

    //数据验证功能
    public static function validateField($data){
        //        验证数据
        try {
            validate(UserValidate::class)->check($data);
        } catch (ValidateException $e) {
            return error($e->getError());
        }
        return true;
    }
}

(4)添加访问路由,前台才可以正常请求

<?php
use think\facade\Route;

Route::group(function () {
// 获取Banner广告信息 
    Route::get('/banner', 'Index/banner');
// 微信用户登录
    Route::Post('user/wxlogin','User/wxlogin');
})->allowCrossDomain();

(5)extend文件夹放入Redis.php文件
(6)在config/cache.php文件夹中配置redis基本信息

// 更多的缓存连接
        'redis' => [
            // 驱动方式
            'type'       => 'File',
            'host'       => '127.0.0.1',
            'port'       => '6379',
            'password'       => '123456',
            // 缓存前缀
            'prefix'     => '',
            // 缓存有效期 0表示永久缓存
            'expire'     => 0,
        ],

image.png

(7)model\User.php模型中引入redis
use Redis;

(8)使用ApiPost调试api接口


使用ApiPost调试api接口.png

(9)redis中有数据了


redis中有缓存数据.png

踩坑记:
1、使用phpstudy pro版本,发现radis不生效,要在对应php版本配置中打开redis扩展,phpstudy_pro的默认php版本是7.3.4,具体看下报错信息中会显示php版本。
2、Postman和ApiPost测试api接口没有注意POST和GET的区别,导致请求提示路由不存在,一直在找到Thinkphp6的路由配置问题。

三、uniapp微信登录调用接口

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,997评论 6 502
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,603评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,359评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,309评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,346评论 6 390
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,258评论 1 300
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,122评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,970评论 0 275
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,403评论 1 313
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,596评论 3 334
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,769评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,464评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,075评论 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,705评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,848评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,831评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,678评论 2 354