vue 用户登录 路由拦截 vuex cookie

功能:
// 页面跳转后发送ajax请求给后端 请求详细信息
//点击课程推荐跳转到推荐课程详细
// 页面刚加载立即执行函数 = mounted
<template>
<div>
<img :src="detail.img" />
<h1>{{ detail.title }}</h1>
<h3>{{detail.slogon }}</h3>
<h5>{{ detail.level }}</h5>
<p>{{ detail.why }}</p>
<div>
<ul v-for="item in detail.chapter">
<li>{{ item.title }}</li>
</ul>
</div>
<br/>
推荐课程:
<div>
<ul v-for="item in detail.recommends">
<!-- 这个方式有问题 -->
<!-- <li><router-link :to="{name:'index',query:{id:item.id}}">{{ item.title }}</router-link></li> -->
<li @click="changeDetail(item.id)">{{ item.title }}</li>
</ul>
</div>
</div>
</template> <script>
export default {
name: "CourseDetail",
data() {
return {
index: "CourseDetail", detail: {
course: null,
img: null,
level: null,
slogon: null,
title: null,
why: null,
chapter: [],
recommends: []
}
};
},
// created:在模板渲染成html前调用
mounted() { var id = this.$route.query.id;
this.getRouterData(id); },
methods: {
getRouterData(nid) { // 发送ajax请求给后端 请求详细信息
var _this = this; this.$axios
.request({
url: this.$store.state.apiList.coursedetail+nid+'/',
methods: "GET"
})
.then(function(ret) {
// ajax请求发送成功后,获取的响应内容
// ret.data=
if (ret.data.code === 1000) {
_this.detail = ret.data.data;
}
})
.catch(function(ret) {
// ajax请求发送失败后,获取的响应内容
});
},
//点击课程推荐跳转到推荐课程详细
changeDetail(id){
// 我需要重新调用getRouterData 向后端请求数据,不然不然会显示为空
this.getRouterData(id)
this.$router.push({name:'CourseDetail',query:{id:id}}) }
}
};
</script> <style scoped>
</style>
功能(2)
// 登录
//使用$store
// router.beforeEach 全局页面阻拦钩子
// router.beforeEach 局部认证钩子
// cookie 设置
// router.beforeEach 全局页面认证钩子
import Vue from 'vue'
import App from './App'
import router from './router' // 导入store组件
import store from './store/store' // 导入axios用于发送数据给后端
import axios from 'axios'
//在vue的全局变量中设置了 $axios = axios
// 以后每个组件使用时: this.$axios
Vue.prototype.$axios = axios Vue.config.productionTip = false /* eslint-disable no-new */
new Vue({
el: '#app',
router,
store,
components: { App },
template: '<App/>'
}) // 这是一个全局路由限制钩子 一般用来做一些进入页面前的限制
router.beforeEach(function(to, from, next){
// to 表示即将要进入的路由对象
//from 表示即将要离开的路由对象
//next 是继续跳转或中断的方法
// 如果路由meta.requireAuth参数 为ture 我需要检查下他的token值有才能让他访问
if (to.meta.requireAuth) {
// // 要去的url只有登录成功后才能访问
if (store.state.token){
// // /我就往下走
next()
}else{
next(
// 页面跳转 传了个值 一个路径 ,to.fullPath = 你当前要点击要跳转的路径
next({name: 'Login',query: {backUrl: to.fullPath}}) )
}
// 如果 路由中 没有定义要 校验限制进入,就直接进入
}else{
next()
}
})
cookie 设置
import Vue from 'vue'
import Vuex from 'Vuex'
import Cookie from 'vue-cookies' Vue.use(Vuex) // 组件中通过 this.$store.state.username 调用
const state = {
// Cookie里面有值的话我就在cookie里面取值,没有我就自动注销
username: Cookie.get('username'),
token: Cookie.get('token'),
apiList: {
course: "http://127.0.0.1:8000/api/v1/course/",
coursedetail:`http://127.0.0.1:8000/api/v1/coursedetail/` ,
auth:'http://127.0.0.1:8000/api/v1/auth/', },
} const mutations = {
// 组件中通过this.$store.commit(参数)调用
//设置kookie
saveToken(state, userToken) { // userToken 传过来的是一个对象,我可以通过点取值
state.username = userToken.username;
state.token = userToken.token;
Cookie.set('username', userToken.username, "20min")
Cookie.set('token', userToken.token, "20min")
},
// 清除 cookie
clearToken: function (state) {
state.username = null
state.token = null
Cookie.remove('username')
Cookie.remove('token')
}
} export default new Vuex.Store({
state,
mutations, })
功能(3)
// 登录 (登录后我就直接 跳转到他之前点击的页面)
<template>
<div>
<h1>登录页面</h1>
<div>账号
<input type="text" placeholder="请输入用户名" v-model="username">
</div>
<div>
密码
<input type="password" placeholder="请输入密码" v-model="password">
</div>
<div>
<input type="button" value="登录" @click="doLogin"> </div> </div>
</template> <script>
export default {
name:'Login',
data(){
return{
username:'',
password:'', }
},
methods:{
doLogin:function(){
var _this = this this.$axios.request({
url:this.$store.state.apiList.auth,
method:'POST',
data:{
user:this.username,
pwd:this.password
},
headers:{
'Content-Type':'application/json'
}
}).then(function(arg){
// 拿到后端的状态码进行判断
if(arg.data.code === 1000){
// 把token 放到state中共享
// _this.$store.state.token = arg.data.token
// _this.$store.state.username = _this.username // saveToken 是一个参数,第二个参数我传了一个对象进去
_this.$store.commit('saveToken',{'token':arg.data.token,'username':_this.username}) //这个是我点击后发现没有登录 跳转过来的页面$route.query.backUrl是有值的
//登录后我就直接 跳转到他之前点击的页面
var url = _this.$route.query.backUrl
if(url){
_this.$router.push({path:url})
// 如果是直接登录的话 我就跳转到主页面
}else{
_this.$route.push({path:'/'}) }
}else{
alert(arg.data.error) } }).catch(function(arg){
console.log(发生错误) })
}
}
}
</script>> <style scoped> </style>
// (局部限制) 你必须带token 才能访问我
mounted(){
if(!this.$store.state.token){
this.$router.push({name:'login'})
}
}
路由中的设置
import Vue from 'vue'
import Router from 'vue-router' // 引入路由页面
import Homepag from '@/components/Homepag'
import Course from '@/components/Course'
import CourseDetail from '@/components/CourseDetail'
import Login from '@/components/Login'
import FeatureLeesion from '@/components/FeatureLeesion' //引入elment快速搭建
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css'; //使用elment组件
Vue.use(ElementUI); Vue.use(Router); export default new Router({
routes: [
{
path: '/',
name: 'Homepag',
component: Homepag,
meta:{
requireAuth:true
}
},
{
path: '/course',
name: 'Course',
component: Course,
meta:{
requireAuth:true
}
},
{
path: '/coursedetail/:id',
name: 'CourseDetail',
component: CourseDetail,
meta:{
requireAuth:true
}
},
{
path: '/login',
name: 'Login',
component: Login,
meta:{
requireAuth:false
}
},
{
path: '/featureleesion',
name: 'FeatureLeesion',
component: FeatureLeesion,
meta:{
requireAuth:true
}
},
]
})
vue 用户登录 路由拦截 vuex cookie的更多相关文章
- vue实现登录路由拦截
第一步 在router.js里面 把需要判断是否登录的路由添加meta对象属性 在meta对象里面自定义一个属性值 第二步 : 在router.js里面 与const router = new Rou ...
- 初学node.js-nodejs中实现用户登录路由
经过前面几次的学习,已经可以做下小功能,今天要实现的事用户登录路由. 一.users_model.js 功能:定义用户对象模型 var mongoose=require('mongoose'), S ...
- taotao用户登录springMVC拦截器的实现
在springMVC中写拦截器,只需要两步: 一.写 java 拦截器类,实现 interceptor 拦截器接口. 二.在 springMVC 的xml配置文件中,配置我们创建的拦截器对象及其拦截目 ...
- 关于django用户登录认证中的cookie和session
最近弄django的时候在用户登录这一块遇到了困难,网上的资料也都不完整或者存在缺陷. 写这篇文章的主要目的是对一些刚学django的新手朋友提供一些帮助.前提是你对django中的session和c ...
- 初识ABP vNext(4):vue用户登录&菜单权限
Tips:本篇已加入系列文章阅读目录,可点击查看更多相关文章. 目录 前言 开始 登录 菜单权限 运行测试 最后 前言 上一篇已经创建好了前后端项目,本篇开始编码部分. 开始 几乎所有的系统都绕不开登 ...
- vue用户登录状态判断
之前项目中用来判断是否登录我写了多种方案,但是最终只有一个方案是比较好的,这篇博客就是分享该方案; 先说基本要求: 项目中的登录状态是依据服务器里的状态来作为判断依据; 每一个需要登录后才能操作的接口 ...
- 关于用户登录状态存session,cookie还是数据库或者memcache的优劣
session中保存登陆状态: 优:整个应用可以从session中获取用户信息,并且查询时很方便.在session中保存用户信息是不可缺少的(web应用中) 缺:session中不宜保存大量信息,会增 ...
- 「Vue」登陆-路由拦截器
1.main.js设置拦截器 router.beforeEach(function (to,from,next) { if (to.meta.requireAuth) { if (store.stat ...
- 用户登录之asp.net cookie的写入、读取与操作
页面前面: <div id="login" runat="server"> <span class="log_title" ...
随机推荐
- 多生产者多消费者(第一种方式),基于synchronized,wait,notifyAll
生产者消费者模式描述的是协调与协作关系.比如一个人正在准备食物(生产者),而另一个人正在吃(消费者),他们使用一个共用 的桌子用于放置盘子和取走盘子,生产者准备食物,如果桌子上已经满了就等待,消费者( ...
- heroku 的用法
heroku 安装cli npm install -g heroku ubuntu 下 sudo snap install --classic heroku 安装 npm init -y heroku ...
- Python31之类和对象1(三大特征:多封继——多疯子)
一.对象: Python即是面向对象的编程也是面向过程的编程语言,其内部可谓是无处不对象,我们所熟知的列表,字符串等工厂函数本质上都是对象.对象其实是对属性和方法的封装. 属性是对象的静态特征 方法是 ...
- ILSVRC比赛带来的算法
李飞飞和它的团队搜集了ImageNet一个超过15 million的图像数据集,大约有22,000类.这个文件集合对深度卷积网络极大地推进深度学习各领域的发展. ILSVRC是对ImageNet进行分 ...
- SQL Sever 刪除重複數據只剩一條
use book go create table ##T1( n int, a nvarchar(20) ) --查詢重複記錄,插入臨時表 insert into ##T1(n,a) select s ...
- selenium2自动化测试实战--基于Python语言
自动化测试基础 一. 软件测试分类 1.1 根据项目流程阶段划分软件测试 1.1.1 单元测试 单元测试(或模块测试)是对程序中的单个子程序或具有独立功能的代码段进行测试的过程. 1.1.2 集成测试 ...
- alt和title的区别
alt是html标签的属性,而title既是html标签,又是html属性. 在图像标签img中,除了常用的宽度width和高度height属性之外,还有两个比较重要并且也会用到的属性,就是alt和t ...
- PCI总线学习
PCI总线概述: 因为不实际操作了,所以就写一些方法论上的东西,纪念一下. PCI总线有三个非常显著的优点: 1. 在计算机和外设传输数据时具有更好的性能. 2. 能够尽量独立于具体的平台. 3. 可 ...
- 【Zookeeper】基础学习概览【汇总】
一.概述 1.1 简介 1.2 Zookeeper集群机制 1.3 Zookeeper特性 二.Zookeeper应用场景 三.Zookeeper数据结构 四.Zookeeper安装 五.Java操作 ...
- 【SpringMVC】Validation校验
一.概述 二.步骤 2.1 引入 Hibernate Validator 2.2 配置 2.3 创建CustomValidationMessages 2.4 校验规则 2.5 捕获错误 2.6 在页面 ...