时间:2021-05-26
前面我们已经了解了可以通过localStorage在客户端(浏览器)保存数据。
我们后端有这样一个接口:
http://localhost/yiiserver/web/index.php/token?client_appid=aaa&client_appkey=bbb
其实就向clients(理解为用户表即可)里面去生成一个token
这里的client_appid就相当于用户名,client_appkey就相当于密码。
这样后端认证之后会生成一个access-token,我们需要把这个access-token保存在客户端。
注意:我们前端一般部署在另外的服务器上,会跨域,后端要处理跨域的问题,在PHP中可以写上如下代码:
//指定允许其他域名访问header("Access-Control-Allow-Origin: *");header("Access-Control-Allow-Methods: GET,POST");header('Access-Control-Allow-Headers: X-Requested-With,content-type,if-modified-since');前端的套路
注意,我们项目既然早已用上了VueX,那么我肯定就要在Store(vuex里的概念)里面来创建一个module。
我们新建了一个UsersModule.js来处理用户登录的业务,注意不要忘记在入口文件users-index.js中引入。如果我们的『会员后台』也需要用户相关数据,也要引入。
在users-index.js里修改:
//引入模块import ResModule from './../Store/modules/ResModules';import UsersModule from "./../Store/modules/UsersModule";const vuex_config = new Vuex.Store({ modules: { res:ResModule, users:UsersModule }});1、UsersModule.js
import Vue from "vue";export default { state:{ currentUser:{ get UserName(){ return localStorage.getItem("currentUser_name"); }, get UserToken(){ return localStorage.getItem("currentUser_token"); } } }, mutations:{ setUser(state,{user_name,user_token}){ // 在这里把用户名和token保存起来 localStorage.setItem("currentUser_name",user_name); localStorage.setItem("currentUser_token",user_token); } }, actions:{ userLogin(context,{user_name,user_pass}){ // 发送get请求做权限认证(真实开发建议用post的方式) let url = "http://localhost/yiiserver/web/index.php/token?client_appid="+user_name+"&client_appkey="+user_pass; console.log(url); Vue.http.get(url) .then((res)=>{ if (res!=null && res.body!=undefined && "access-token" in res.body){ var token = res.body["access-token"]; if (token != ""){ // 后端API验证通过 // 调用上面mutations里定义的方法 context.commit("setUser",{"user_name":user_name,"user_token":token}); } }else{ alert("用户名密码错误"); } },(res)=>{ alert("请求失败进入这里") }); } }}actions部分:我们写了一个userLogin()方法,来发送http请求后端服务器,请求成功返回的数据调用在mutations部分定义的setUser()方法保存到客户端。
注意:actions里的userLogin()方法,是供在用户登录页调用的,也就是userslogin.vue里。
所以来到userlogin.vue,修改如下代码:
我们来测试一下,有没有成功保存到客户端的localStorage中:
2、如果我们的会员后台
http://localhost:8080/member
也需要获取用户的登录信息,比如用户名。来显示到导航栏上。
首先是应该在会员后台模块的入口文件member-index.js中:
//引入Moduleimport ResModule from './../Store/modules/ResModules';import UsersMoule from "./../Store/modules/UsersModule";const vuex_config = new Vuex.Store({ modules: { res:ResModule, users:UsersMoule }});然后我们就可以在,比如导航栏组件navbar.vue中:
<a href="##" rel="external nofollow" >{{this.$store.state.users.currentUser.UserName}}</a>通过这样的方式,访问users里的属性。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Session登陆与Token登陆的区别1、Session登陆是在服务器端生成用户相关session数据,发给客户端session_id存放到cookie中,这
在客户端远程备份的文件保存在数据库所在主机上,不会直接拷贝到客户端。——————————————————————————————————————————首先无论
localStorage是HTML5提供的再客户端实现本地存储的一种方法,但是localStorage方法只能存储字符串数据,有时候我们需要存储对象到本地比如:
在客户端存储数据HTML5提供了两种在客户端存储数据的新方法:•localStorage-没有时间限制的数据存储•sessionStorag
以前实现数据的缓存有很多种方法,有客户端的Cookie,有服务器端的Session和Application。其中Cookie是保存在客户端的一组数据,主要用来保