杭州数澜科技招聘Node.js工程师【可实习】、UE/UI设计师【实习】、前端React工程师【实习】,联系方式可见评论区

Vue.js + Element UI + MongoDB

P1 安装Vue-CLI

# 全局安装 vue-cli

$ npm install --global vue-cli

# 创建一个基于 webpack 模板的新项目

$ vue init webpack my-project

# 安装依赖,走你

$ cd my-project

$ npm install

$ npm run dev

Vue.js 主要目录结构

.

├── build # 一些webpack的文件,配置参数什么的,一般不用动

├── config # vue项目的基本配置文件

├── index.html # 主页

├── node_modules # 项目中安装的依赖模块

├── package.json # 项目文件,记载着一些命令和依赖还有简要的项目描述信息

├── README.md

├── server # 自己创建的后端文件,可以忽视

├── src # 源码文件夹,基本上文件都应该放在这里

├── App.vue # App.vue组件

├── assets # 资源文件夹,里面放一些静态资源

├── components # 这里放的都是各个组件文件

├── main.js # 入口文件

└── router # vue-router 路由配置

├── static # 生成好的文件会放在这个目录下

├── test # 测试文件夹,测试都写在这里

├── .babelrc # babel编译参数,vue开发需要babel编译

├── .gitignore

└── .eslintignore

完成后就可以在/src/components/*.vue模板中写代码,ctrl+s保存后页面会自动刷新,若无效请检查端口是否被占用

P2 安装Element UI

npm i element-ui -S

完成后在main.js中添加如下代码完整引入Element,就能在/src/components/*.vue模板中使用Element UI的组件

// main.js

import ElementUI from 'element-ui'

import 'element-ui/lib/theme-default/index.css'

Vue.use(ElementUI)

P3 登录注册功能

登录界面

界面代码及注册略

思路

得益于vue的数据双向绑定,让我们不用操作DOM就能边输入边验证字符串合法性

利用axios实现前后端的数据交互

利用jsonwebtoken实现登录验证,结合vue-router的beforeEnter导航钩子在跳转前拦截验证access_token的有效性

验证输入的账号和密码是否合法(利用elementui的form表单)

export default {

name: 'register',

data () {

var validateUser = (rule, value, cb) => {

var pattern = /^[\w\u4e00-\u9fa5]{3,10}$/g

if (value === '') {

cb(new Error('请输入用户名'))

} else if (!pattern.test(value)) {

cb(new Error('请输入3-10个字母/汉字/数字/下划线'))

} else {

cb()

}

}

var validatePwd = (rule, value, cb) => {

var pattern = /^\S{3,20}$/g

if (value === '') {

cb(new Error('请输入密码'))

} else if (!pattern.test(value)) {

cb(new Error('请输入3-20个非空白字符'))

} else {

if (this.registerForm.checkPwd !== '') {

this.$refs.registerForm.validateField('checkPwd')

}

cb()

}

}

var validateCheckPwd = (rule, value, cb) => {

if (value === '') {

cb(new Error('请再次输入密码'))

} else if (value !== this.registerForm.pwd) {

cb(new Error('两次输入密码不一致!'))

} else {

cb()

}

}

return {

registerForm: {

userName: '',

pwd: '',

checkPwd: ''

},

registerRule: {

userName: [

{ validator: validateUser, trigger: 'blur' }

],

pwd: [

{ validator: validatePwd, trigger: 'blur' }

],

checkPwd: [

{ validator: validateCheckPwd, trigger: 'blur' }

]

}

}

},

methods: {

submitForm (formName) {

this.$refs[formName].validate((valid) => {

if (valid) {

...

} else {

return false

}

})

}

}

}

利用axios实现与后端数据的交互

Axios.post('http://localhost:3000/register', data)

.then(res => {

console.log(res.data)

if (res.data.code === 0) {

this.$message({

showClose: true,

message: '注册成功',

type: 'success'

})

router.push({name: 'Login'})

} else {

this.$message({

showClose: true,

message: '注册失败',

type: 'error'

})

}

})

使用 JSON WEB Tokens 实现登录验证

由于node后端和vue前端是两个不同的端口(:3000和:8090),对于跨域(我已经允许跨域访问),session和cookie就不要想了,并不是设置一个什么就能解决的,花了一下午才发现,所以使用了token来做api请求,而且还能加密。

后端处理登录

// sever/db/dbHelper.js

exports.findUser = function(data, cb) {

User.findOne({

username: data.usr

}, function(err, doc) {

// 用户密码都正确

// jwt.encode({加密对象, 持续时间}, 密钥字符串)

entries.data = user

entries.code = 0

var time = moment().add(1, 'days').valueOf()

entries.access_token = jwt.encode({

iss: user._id,

exp: time

}, jwtTokenSecret)

cb(true, entries)

})

}

加密后的entries.access_token:

access_token

前端获取到后端传递过来的access_token,将其保存进sessionStorage。这个导航钩子我放在/p路由独享的钩子下,在进入/p/:id前拦截导航,通过axios向后端传递access_token,根据后台返回值判断是否已经登录。

router.beforeEach确保要调用next方法,否则钩子就不会被 resolved,但after钩子没有 next方法,不能改变导航

beforeEnter: (to, from, next) => {

let pattern = /^(\/p)/g

let token = sessionStorage.getItem('accessToken') //保存token

if (pattern.test(to.path)) {

Axios.post('http://localhost:3000/isLogin', {access_token: token})

.then(res => {

if (res.data.code === 0) {

console.log(from)

console.log(to)

next()

} else {

router.push({name: 'Login'})

next()

}

})

.catch(err => {

console.log(err)

})

}

}

后端处理token是否合法

后台获取到传递的token值,利用jwt.decode(token, jwtTokenSecret)对其解码,解码结果就是当初我们加密的对象{iss, exp},首先根据exp判断token是否过期,然后根据_id查询数据库是否有这个用户

// 登录验证

exports.authority = function (req, cb) {

// JWT 允许客户端使用一下3个方法附加token:

// 作为请求链接(query)的参数,作为主体的参数(body),

// 和作为请求头(Header)的参数。

var token = (req.body && req.body.access_token) || (req.query && req.query.access_token) || req.headers['access-token']

if (token) {

try {

var decoded = jwt.decode(token, jwtTokenSecret) // 解码

if (decoded.exp <= Date.now()) { // 判断token是否过期

entries.code = 99

cb(false, entries)

} else { // 之前加密对象是 user._id

User.findOne({ _id: decoded.iss }, function(err, user) {

if (err) {

console.log(err)

} else if (user !== null) {

entries.code = 0

cb(true, entries)

}

})

}

} catch (err) {

console.log(err)

}

} else {

entries.code = 99

cb(false, entries)

}

}

vue 数据库 登录界面_Vue学习之路之登录注册相关推荐

  1. 不同风格的网页登录界面设计学习

    今天小编整理了一些有意思的不同风格的登陆界面,供大家鉴赏和学习. 1.点点轻博客登录 界面整体使用了高级灰,所有的图标文字都是淡淡的,简洁.干净,让人浏览时会感觉平静,静下心来才能好好的去思考,去记录 ...

  2. java网格式布局登录界面_Java学习笔记------自己书写的登录界面实例

    package com.package_view; import  com.package_model.*; import javax.swing.*; import java.awt.*; impo ...

  3. oracle怎么创建登录用户,Oracle学习第一课(登录oracle和创建用户)

    博客10:housen1987 housen1987.iteye.com/blog/1345496 [学习是螺旋上升的过程,由易到难,由少到多,由点到面,每一个步骤,每一个脚印,每一个见闻,每一个错误 ...

  4. 登录界面的滑动_电脑同时登录两个微信,原来这么简单?3步搞定!

    关注我?发送[模板],送海量精选 PPT 模板! 作者:小斯 策划:视频小分队 编辑:小胖 Hey hey,what's up? what's up! 这里是小斯,AKA差一点玩转PPT,也要给你分享 ...

  5. java仿qq登录 界面设计,Java Swing仿QQ登录界面效果

    本文实例为大家分享了Java Swing仿QQ登录界面展示的具体代码,供大家参考,具体内容如下 闲来无事将早些时候已实现的QQ登录界面再实现了一遍,纯手工打造(意思是没有用NetBeans.MyEcl ...

  6. php mysql ajax登录界面_PHP+jQuery+Ajax实现用户登录与退出

    本文使用Ajax无刷新登录和退出,从而提升了用户体验. 若用户为登录状态,则显示用户相关登录信息,否则显示登录表单. 用户登录与退出功能应用在很多地方,而在有些项目中,我们需要使用Ajax方式进行登录 ...

  7. HTML+CSS+JavaScript制作登录页面_科幻后台登录界面html模板_科技感登录界面html模板

    科幻后台登录界面html模板 原始HTML+CSS+JS页面设计,这是一个不错的登录网页制作,画面精明,非常适合初学者学习使用. 作品介绍 1.网页作品简介方面 :蓝色科技风格后台登录框,科幻的网站后 ...

  8. HTML+CSS+JavaScript制作登录页面_科幻后台登录界面html模板_科技感登录界面html模板...

    科幻后台登录界面html模板 原始HTML+CSS+JS页面设计,这是一个不错的登录网页制作,画面精明,非常适合初学者学习使用. 作品介绍 1.网页作品简介方面 :蓝色科技风格后台登录框,科幻的网站后 ...

  9. java qq登录界面_用java实现QQ登录界面怎么写

    展开全部 用32313133353236313431303231363533e78988e69d8331333365646263java做QQ登录界面的写法如下: package ch10; impo ...

最新文章

  1. 干货|重磅发布:人工智能行业应用价值报告(PDF报告下载)
  2. oracle 三列数值相加,Oracle SQL/PLSQL:按货币拆分和求和值的分层查询
  3. C#获取类名为Internet_Explorer_Server控件的内容
  4. vue-cli webpack配置分析 - chenBright - SegmentFault 思否
  5. html二级下拉菜单模板,基于jQuery实现二级下拉菜单效果
  6. 作者:姚前(1970-),男,中国人民银行征信中心副主任、高级工程师,主要研究方向为分布式系统和计算机安全。...
  7. JS事件、对象基础篇
  8. iptraf:一个实用的TCP/UDP网络监控工具
  9. 例子:10秒后同意按钮可点击
  10. vue3.0实现地图功能
  11. java 获取html title_java htmlparser 获取网页title
  12. 用QQ聊天记录生成一个词云
  13. 键盘输入正六边形边长,输出对应的正六边形
  14. 简述python文件操作_Python 文件操作
  15. 由于使用计算机编制会计报表,《计算机会计学》1
  16. 全球顶级白帽子:美女、通缉犯、公务员
  17. 用莫比乌斯带巧解内接矩形问题:拓扑学的用处
  18. 数据管理解决方案 | 零售行业如何搭建全渠道大数据平台?
  19. docker部署excalidraw画图工具
  20. 软件工程 第一章 软件工程概述

热门文章

  1. Python生成图灵智能小助手,打发你工作生活中无聊时间
  2. 解决Apache提示没有权限访问的问题
  3. 逃离塔克夫TT辅助注入器再次更新0.56
  4. Java后台生成图表——主代码(折线图,饼状图,柱状图,-》并产出图片PDF或其他格式的图片内容)
  5. 网站优化有哪些方法和技巧
  6. 【C++】c++ 11中的随机数 ——random
  7. 耐克阿迪颓势之下,增势向好的特步做对了什么?
  8. 北京2008年奥运会门票价格详细一览表
  9. 项目案例分享一:客户端无法拿到WSUS补丁
  10. 手机短信息被误删怎么办?最常用的恢复小技巧