首页 > 作文

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

更新时间:2023-04-06 17:21:02 阅读: 评论:0

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

后端(laravel5.6框架)

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

compor require laravel/passport  #安装完成后,在compor.json文件中会看到文件版本信息

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

laravel\passport\passportrviceprovider::class,

3、执行数据库迁移

php artisan migrate #数据库中会生成接口认证所需的5张表

4、创建密码授权客户端

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

5、获取keys

php artisan passport:keys

6、配置路由

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

u laravel\passport\passport;public function boot() {   $this->registerpolicies();   passport::routes(); //接口认证的路由}

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

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

'guards' => [  'web' => [    'driver' => 'ssion',    'provider' => 'urs',  ],  'api' => [    'driver' => 'passport',    'provider' => 'customers',  ],],
'providers' => [  'urs' => [    'driver' => 'eloquent',    'model' => app\ur::class,  ],  'customers' => [    'driver' => 'eloquent',    'model' => app\models\shop\customer::class,  ],],

7、注册中间件,在 app/http/kernel.php 文件中的 $写信的作文routemiddleware 数组中添加如下中间件

protected $routemiddleware = ['client.credentials'=>\laravel\passport\http\middleware\checkclientcredentials::class,];

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

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

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

u illuminate\foundation\auth\ur as authenticatable;u laravel\passport\hasapitokens;class customer extends authenticatable{  u hasapitokens;   ....  }

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

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

前端(vue.js)

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

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

import login from '@/components/customer/login'export default new router({ routes: [    ....  {   path: '/customer/login',   name: 'login',   component: login  }, ]})

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

<template> <div>  <input type="email" v-model="customer.email" placeholder="请输入邮箱">  <input type="password" v-model="customer.password" placeholder="请输入密码">  <button @click.prevent="submit">登 录</button> </div></template><script> export default {  data() {   return {    customer: {     email: '',     password: ''    }教资考场   }  },  methods: {   submit() {   自我评价材料 //将数据配置好    const data = {     grant_type: 'password', //oauth的模式     client_id: 1,  //上面所说的client_id     client_cret: 'co331ca1mqikggvvgidzpxh4cuu19viqxm7lhd',//同上     urname: this.customer.email,     password: this.customer.password,    }    this.axios.post('/oauth/token', data)     .then(res => {      if (res.status == 200) { //如果成功了,就把access_token存入localstorage       localstorage.token_type = res.data.token_type       localstorage.access_token = res.data.access_token       this.$router.push({name:'index'})      }     })   }  } }</script>

客户端查看 localstorage ,如图:

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

//#创建http.js文件import axios from 'axios'import router from '@/router'// axios 配置axios.defaults.tim描写人物的词语eout = 5000;axios.defaults.baurl = 'http://wechat.test/';// http request 拦截器axios.interceptors.request.u( config => { //将所有的axios的header里加上token_type和access_token  config.headers.authorization = `${localstorage.token_type} ${localstorage.access_token}`;  return config; }, err => {  return promi.reject(err); });// http respon 拦截器axios.interceptors.respon.u( respon => {  return respon; }, error => {  // 401 清除token信息并跳转到登录页面  if (error.respon.status == 401) {   alert('您还没有登录,请先登录')   router.replace({  //如果失败,跳转到登录页面    name: 'login'   })  }  return promi.reject(error.respon.data) });export default axios;

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

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

$customer_id = auth('api')->ur()->id;return $customer_id;

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

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

总结:接口认证逻辑思想

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

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

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

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

本文发布于:2023-04-06 17:20:51,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/3f628b80c7e8ab4a9e03db49cf383e65.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:详解Laravel5.6 Passport实现Api接口认证.doc

本文 PDF 下载地址:详解Laravel5.6 Passport实现Api接口认证.pdf

标签:接口   文件   页面   地址
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图