• Laravel OAuth2 (二) 配置与数据库设计


    前言

    使用 OAuth2 进行第三方登陆分为好几种情况,例如完全第三方登陆,不保存任何用户信息,或者第三方登陆后保存用户信息关联本站账号。个人觉得保存一下用户信息比较妥当(虽然这样注册的时候让用户觉得很不方便,但是第二次使用就不会这么麻烦了),如果数据库中不存在该用户则重定向到注册页面,否则查找关联的本站账号,登陆。

    修改回调的URL

    因为要绑定本站账号,所以毁掉的 URL 应该是注册页面。在注册页面判断是否该用户已存在,是则直接登陆,否则填写注册信息。

    对应的.env文件也要修改:GITHUB_REDIRECT_URI=http:http://suip.app/auth/register

    数据库迁移文件

    class CreateSocialUsersTable extends Migration
    {
        public function up()
        {
            Schema::create('social_users', function (Blueprint $table) {
                $table->increments('id');
                $table->string('type');
                $table->integer('social_user_id')->unsigned();
                $table->integer('user_id')->unsigned();
                $table->string('nickname')->nullable();
                $table->string('name')->nullable();
                $table->string('email')->nullable();
                $table->string('avatar')->nullable();
                $table->foreign('user_id')->references('id')->on('users')->onDelete('cascade');
                $table->timestamps();
            });
        }
        
        public function down()
        {
            Schema::drop('social_users');
        }
    }
    

    这里的user_id就是本站账号的 id ,注册成功自然会将第三方的信息与本站账号关联。

    第三方用户模型

    class SocialUser extends Model
    {
        protected $table = 'social_users';
        protected $fillable = [
        	'type',
        	'user_id',
        	'nickname',
        	'name',
        	'email',
        	'avatar'
        	];
        public function user()
        {
            return $this->belongsTo('App\User');
        }
    }
    

    实现第三方登陆绑定本站账号的配置就完成了。

  • 相关阅读:
    计算机网络面试题总结
    为0LTP选择RDMBS时,你都需要考虑哪些?
    Redis集群搭建与简单使用
    Innodb关键特性之自适用Hash索引
    关于MySQL的commit非规律性失败案例的深入分析
    MySQL存储写入性能严重抖动分析
    【Linux】管理文件系统
    【Linux】YUM源搭建
    【Linux】计划任务
    【Linux】日志分析及管理
  • 原文地址:https://www.cnblogs.com/pengzhendong/p/4850927.html
Copyright © 2020-2023  润新知