详解Laravel5.6 Passport实现Api接口认证
很多企业做项目使用前后端分离,后端提供接口地址,前端使用接口地址拿数据,并渲染页面。那么,前端用户登录如何使用接口进行认证?网上各种教程写的不堪入目,完全看不懂,所以我根据自己的理解,写下此篇文章,希望能帮助到大家。 后端(Laravel5.6框架) 1、使用 2、接下来,将 3、执行数据库迁移 4、创建密码授权客户端 5、获取keys 6、配置路由 打开服务提供者 registerPolicies();
Passport::routes(); //接口认证的路由
}
然后将配置文件 我这里的 [
'web' => [
'driver' => 'session','provider' => 'users',],'api' => [
'driver' => 'passport','provider' => 'customers',
[
'users' => [
'driver' => 'eloquent','model' => AppUser::class,'customers' => [
'driver' => 'eloquent','model' => AppModelsShopCustomer::class,
7、注册中间件,在 LaravelPassportHttpMiddlewareCheckClientCredentials::class,];
然后在需要认证接口路由文件 'cart','middleware' => ['client.credentials']],function () {
...
});
8、前端用户表 class Customer extends Authenticatable
{ use HasApiTokens; .... } 至此,后端的所有配置已完成。 接下来,打开接口测试工具(postman),输入接口地址: 前端(vue.js) 首先去加载用户登录组件,即用户登录页面。 1. 配置路由,在 2、加载组件,在 客户端查看 3、在 // axios 配置
axios.defaults.timeout = 5000; axios.defaults.baseURL = 'http://wechat.test/'; // http request 拦截器 // http response 拦截器 export default axios; 重新访问项目,在商品详情页面点击加入购物车,你会发觉奇迹已经出现,当你没有登录时,提示跳转到登录页面。输入账号密码,登录成功,此时就能拿到用户id。接下来,继续测试。 4、去 user()->id;
return $customer_id;
5、在 拿到用户id后,把后端之前定义的customer_id全部改为通过接口方法获取。至此, 总结:接口认证逻辑思想1、安装passport后,生成client_id和 client_secret 2、使用username、password、client_id、client_secret、grant_type参数,调用/oauth/token接口,拿到access_token 3、需要认证的接口,加上中间件。这时候直接访问接口地址,会提示没有认证的。带上access_token后,才能拿到接口的数据。 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |