详解用vue.js和laravel实现微信授权登陆


Posted in Javascript onJune 23, 2017

在laravel框架我们使用安正超的package

网址:https://easywechat.org/

有专门的针对laravel的安装包,请参见如下网址:https://github.com/overtrue/laravel-wechat

下面来说说具体的安装:

1.安装package

composer require overtrue/wechat

2.在app/config/app.php 中注册 ServiceProvider

Overtrue\LaravelWechat\ServiceProvider::class,

3.创建配置文件

php artisan vendor:publish --provider="Overtrue\LaravelWechat\ServiceProvider"

请修改应用根目录下的 config/wechat.php 中对应的项即可

4.添加外观到 config/app.php 中的 aliases 部分:

'wechat' => Overtrue\LaravelWechat\Facade::class,

5.添加路由

Route::any('/wechat', 'WechatController@serve');//控制器请按自己的实际情况填写

特别注意:因为laravel自带token验证,建议使用laravel-cors解决跨域问题,具体安装见github地址:https://github.com/barryvdh/laravel-cors

6.控制器添加如下代码:

/**
   * 处理微信的请求消息
   *
   * @return string
   */
  public function serve()
  {
    $wechat = app('wechat');
    $wechat->server->setMessageHandler(function($message){
      return "欢迎关注 overtrue!";
    });

    return $wechat->server->serve();
  }

7.配置好了路由和控制器,就得到了微信授权所需的URL,此时打开微信公众平台,在“开发—基本配置”页面,点击“修改配置”按钮,得到:

详解用vue.js和laravel实现微信授权登陆

修改配置页面

1) 将刚才的URL填入URL输入框内

2) token可自定义

3) EncodingAESKey 可随机生成

4) 消息加密用安全模式

8.在.env文件中配置以下参数

#微信配置,若不知道WECHAT_TOKEN和WECHAT_AES_KEY请继续往下看
WECHAT_APPID=
WECHAT_SECRET=
WECHAT_TOKEN=
WECHAT_AES_KEY=
#微信支付用
WECHAT_PAYMENT_MERCHANT_ID=
WECHAT_PAYMENT_KEY=

最后一步,填写完成后提交,微信将会调用此URL接口来验证,如果验证成功,就通过配置。

在公众平台,还有一项重要配置,如下:

在微信公众平台“接口权限”—“网页授权”—“网页授权域名”,填上服务器端域名(注:请仔细阅读平台上要求,特别注意得是,这里是服务器域名,不是客户端域名!)

接下来就可以实现微信授权登陆的功能了

10.在 app/Http/Kernel.php 中添加路由中间件:

protected $routeMiddleware = [
  // ...
  'wechat.oauth' => \Overtrue\LaravelWechat\Middleware\OAuthAuthenticate::class,
];

10.在路由中添加授权登陆的路由

Route::group(['middleware' => ['wechat.oauth']], function () {
  Route::get('/auth','UsersController@wechatAuth');
});

11.在以上路由相应的控制器中添加wechatAuth方法

public function wechatAuth(Request $request)
  {
    $userinfo = session('wechat.oauth_user')->original; // 拿到授权用户资料

    //这里写用户注册到mysql的相关逻辑代码,请自行补充

  }

12.在微信中打开此路由下的url就发现出现微信认证的界面,如未成功请自行检查你的配置和代码。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
锋利的jQuery 要点归纳(二) jQuery中的DOM操作(下)
Mar 23 Javascript
js中return false(阻止)的用法
Aug 14 Javascript
javascript实用小函数使用介绍
Nov 11 Javascript
JavaScript中的toLocaleDateString()方法使用简介
Jun 12 Javascript
js中遍历对象的属性和值的方法
Jul 27 Javascript
详解如何使用Node.js编写命令工具——以vue-cli为例
Jun 29 Javascript
vue生成随机验证码的示例代码
Sep 29 Javascript
vue 挂载路由到头部导航的方法
Nov 13 Javascript
vue-cli脚手架引入图片的几种方法总结
Mar 13 Javascript
傻瓜式vuex语法糖kiss-vuex整理
Dec 21 Javascript
详解用JS添加和删除class类名
Mar 25 Javascript
vue+导航锚点联动-滚动监听和点击平滑滚动跳转实例
Nov 13 Javascript
妙用Angularjs实现表格按指定列排序
Jun 23 #Javascript
VUE中v-model和v-for指令详解
Jun 23 #Javascript
JavaScript正则表达式简单实用实例
Jun 23 #Javascript
js中的事件委托或是事件代理使用详解
Jun 23 #Javascript
JS判断非空至少输入两个字符的简单实现方法
Jun 23 #Javascript
详解Vue.js之视图和数据的双向绑定(v-model)
Jun 23 #Javascript
微信小程序组件 marquee实例详解
Jun 23 #Javascript
You might like
用php实现选择排序的解决方法
2013/05/04 PHP
基于php无限分类的深入理解
2013/06/02 PHP
CURL的学习和应用(附多线程实现)
2013/06/03 PHP
解析php中curl_multi的应用
2013/07/17 PHP
PHP采用自定义函数实现遍历目录下所有文件的方法
2014/08/19 PHP
PHP中的Trait 特性及作用
2016/04/03 PHP
PHP用FTP类上传文件视频等的简单实现方法
2016/09/23 PHP
PHP数据库操作三:redis用法分析
2017/08/16 PHP
PHP 文件上传限制问题
2019/09/01 PHP
Javascript this关键字使用分析
2008/10/21 Javascript
javascript document.execCommand() 常用解析
2009/12/14 Javascript
通过Jscript中@cc_on 语句识别IE浏览器及版本的代码
2011/05/07 Javascript
Node.js的Web模板引擎ejs的入门使用教程
2016/06/06 Javascript
Js apply方法详解
2017/02/16 Javascript
JavaScript初学者必看“new”
2017/06/12 Javascript
JavaScript登录验证基础教程
2017/11/01 Javascript
vue组件编写之todolist组件实例详解
2018/01/22 Javascript
浅谈vue加载优化策略
2019/03/19 Javascript
微信提示 在浏览器打开 效果实现过程解析
2019/09/10 Javascript
使用Python编写简单网络爬虫抓取视频下载资源
2014/11/04 Python
Python实现类似比特币的加密货币区块链的创建与交易实例
2018/03/20 Python
python实现图书借阅系统
2019/02/20 Python
Python3.0中普通方法、类方法和静态方法的比较
2019/05/03 Python
python接口调用已训练好的caffe模型测试分类方法
2019/08/26 Python
Python3以GitHub为例来实现模拟登录和爬取的实例讲解
2020/07/30 Python
工厂门卫岗位职责
2013/11/25 职场文书
领导党性分析材料
2014/02/15 职场文书
荷叶母亲教学反思
2014/04/30 职场文书
借款担保书范文
2014/05/13 职场文书
设计师求职信
2014/07/01 职场文书
违纪检讨书
2015/01/27 职场文书
同学会邀请函模板
2015/01/30 职场文书
小学英语教师研修感悟
2015/11/18 职场文书
2016年教师节特级教师获奖感言
2015/12/09 职场文书
网络研修心得体会
2016/01/08 职场文书
一年级下册数学教学反思
2016/02/16 职场文书