详解Laravel5.6 Passport实现Api接口认证

很多企业做项目使用前后端分离,后端提供接口地址,前端使用接口地址拿数据,并渲染页面。那么,前端用户登录如何使用接口进行认证?网上各种教程写的不堪入目,完全看不懂,所以我根据自己的理解,写下此篇文章,希望能帮助到大家。

后端(Laravel5.6框架)

1、使用 composer 安装 Passport ,打开终端,执行命令:

rush:plain;"> composer require laravel/passport #安装完成后,在composer.json文件中会看到文件版本信息

2、接下来,将 Passport 的服务提供者注册配置文件 config/app.PHPproviders 数组中

rush:plain;"> Laravel\Passport\PassportServiceProvider::class,

3、执行数据库迁移

rush:PHP;"> PHP artisan migrate #数据库中会生成接口认证所需的5张表

4、创建密码授权客户端

rush:PHP;"> PHP artisan passport:client --password #创建了client_id和client_secret,前端登录验证的时候必须把这两个玩意儿带着

5、获取keys

rush:PHP;"> PHP artisan passport:keys

6、配置路由

打开服务提供者 AuthServiceProvider , 在 boot 方法中加入如下代码:

registerPolicies(); Passport::routes(); //接口认证的路由 }

然后将配置文件 config/auth.PHP 中授权看守器 guardsapidriver 选项改为 passport

我这里的 customer 表是前端用户表,但是 laravel 认的是 user 表,所以这里需要做如下配置:

[ 'web' => [ 'driver' => 'session','provider' => 'users',],'api' => [ 'driver' => 'passport','provider' => 'customers',
[ 'users' => [ 'driver' => 'eloquent','model' => App\User::class,'customers' => [ 'driver' => 'eloquent','model' => App\Models\Shop\Customer::class,

7、注册中间件,在 app/Http/Kernel.PHP 文件中的 $routeMiddleware 数组中添加如下中间件

\Laravel\Passport\Http\Middleware\CheckClientCredentials::class,];

然后在需要认证接口路由文件 routes/api.PHP 前面加上这个中间件。

'cart','middleware' => ['client.credentials']],function () { ... });

8、前端用户customer 模型里面做如下配置:

rush:PHP;"> use Illuminate\Foundation\Auth\User as Authenticatable; use Laravel\Passport\HasApiTokens;

class Customer extends Authenticatable
{
use HasApiTokens;
....
}

至此,后端的所有配置已完成。

接下来,打开接口测试工具(postman),输入接口地址: wechat.test/oauth/token,请求类型 POST ,填上如下参数,点击 send 你会看到后台返回了前端所需的 access_token

前端(vue.js)

首先去加载用户登录组件,即用户登录页面

1. 配置路由,在 index.js 文件中写入如下代码

rush:js;"> import Login from '@/components/customer/Login' export default new Router({ routes: [ .... { path: '/customer/login',name: 'Login',component: Login },] })

2、加载组件,在 customer 文件夹的 Login.vue 文件中写入如下代码

rush:js;">

客户端查看 localStorage ,如图:

3、在 http.js 文件中设置拦截器,用于判断用户是否登录,若没有登录跳转登录页面代码如下:

// axios 配置
axios.defaults.timeout = 5000;
axios.defaults.baseURL = 'http://wechat.test/';

// http request 拦截器
axios.interceptors.request.use(
config => { //将所有的axios的header里加上token_type和access_token
config.headers.Authorization = ${localStorage.token_type} ${localStorage.access_token};
return config;
},err => {
return Promise.reject(err);
});

// http response 拦截
axios.interceptors.response.use(
response => {
return response;
},error => {
// 401 清除token信息并跳转登录页面
if (error.response.status == 401) {
alert('您还没有登录,请先登录')
router.replace({ //如果失败,跳转登录页面
name: 'Login'
})
}
return Promise.reject(error.response.data)
});

export default axios;

重新访问项目,在商品详情页面点击加入购物车,你会发觉奇迹已经出现,当你没有登录时,提示跳转登录页面。输入账号密码,登录成功,此时就能拿到用户id。接下来,继续测试。

4、去 Cart 控制器中,找到购物车首页方法获取用户的id,获取方式如下:

user()->id; return $customer_id;

5、在 postman 中输入购物车首页接口地址,并传入所需参数,参数参考地址: http://laravelacademy.org/post/8909.html ,如图:

拿到用户id后,把后端之前定义的customer_id全部改为通过接口方法获取。至此, Passport 接口认证的全部操作已完成。

总结:接口认证逻辑思想

1、安装passport后,生成client_id和 client_secret

2、使用username、password、client_id、client_secret、grant_type参数,调用/oauth/token接口,拿到access_token

3、需要认证的接口,加上中间件。这时候直接访问接口地址,会提示没有认证的。带上access_token后,才能拿到接口的数据。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


laravel的dd函数不生效怎么办
看不懂laravel文档咋办
安装laravel框架出现command怎么办
Laravel开发API怎么使用事务
laravel怎么构建复杂查询条件
laravel如何实现防止被下载
为什么laravel比yii火
一些常见的Laravel定时任务不运行的问题
laravel用路由有什么好处
composer无法安装laravel怎么办
laravel现在还用吗
laravel怎么替换主键id
laravel的appurl有什么用
如何修改Laravel的报错输出形式
laravel怎么避免foreach查表
laravel怎样操作数据库
laravel怎么截取字符串
laravel 是国内的吗
laravel怎么设置请求头
浅析Laravel社区Redis组件报错的问题和解决方法