Vue nodejs商城项目-登录模块
一、登录功能
后端server/routes/users.js
- var User = require('./../models/users.js');
- // 二级路由
- // 登录接口
- router.post("/login",function(req, res, next){
- // 获取参数
- var param = {
- userName:req.body.userName,
- userPwd:req.body.userPwd
- }
- User.findOne(param, function(err,doc){ // 根据用户名密码查找数据库
- if(err){
- res.json({
- status:"",
- msg:err.message
- })
- }else{
- if(doc){
- res.cookie("userId",doc.userId,{
- path:'/',
- maxAge:100*60*60
- });
- // res.cookie("userName",doc.userName,{
- // path:'/',
- // maxAge:1000*60*60
- // });
- // req.session.user = doc;
- res.json({
- status:"",
- msg:'',
- result:{
- userName:doc.userName
- }
- })
- }
- }
- })
- })
添加代理config/index.js
- proxyTable: {
- '/users/*':{ // users/路由的下一级路由
- target:'http://localhost:3000'
- }
- },
- 说明:如果是有三级路由,例'/users/cart/del',需要配置'/users/**';否则请求时会出现404错误。
前端NavHeader.vue
- methods:{
- login(){ // 点击登录
- console.log("userName:"+this.userName)
- if(!this.userName || !this.userPwd){
- this.errorTip = true;
- return
- }
- axios.post("/users/login",{
- userName:this.userName,
- userPwd:this.userPwd
- }).then((response)=>{
- let res = response.data;
- "){
- this.errorTip = false;
- this.loginModalFlag = false;
- this.nickName = res.result.userName;
- }else{
- this.errorTip = true;
- }
- })
- }
- }


二、登出功能
后端server/routes/users.j
- / 登出接口
- router.post("/logout",function(req,res,next){
- res.cookie("userId","",{
- path:"/",
- maxAge:-1 // 生命周期
- })
- res.json({
- status:"",
- msg:'',
- result:''
- })
- })
前端NavHeader.vue
- methods:{
- logOut(){ // 点击logout登出
- axios.post("/users/logout").then((response)=>{
- let res = response.data;
- "){
- this.nickName = '';
- }
- })
- }
- }
三、登录拦截功能
server/app.js
- // 捕获登录状态
- app.use(function(req,res,next){ // 进入路由之前优先进入function
- if(req.cookies.userId){ // 有cookies,说明已经登录
- next();
- }else{
- console.log("url:"+req.originalUrl);
- if(req.originalUrl =='/users/login' || req.originalUrl == '/users/logout' || req.originalUrl == '/goods/list'){ // 未登录时可以点击登录login登出logout和查看商品列表
- next();
- }else{
- res.json({
- status:'1001',
- msg:'当前未登录',
- result:''
- })
- }
- }
- })
四、校验登录
server/routes/users.js
- 登录接口添加userName的cookie
- res.cookie("userName",doc.userName,{
- path:'/',
- maxAge:1000*60*60
- });
- // 校验是否登录
- router.get("/checkLogin",function(req,res,next){
- if(req.cookies.userId){
- res.json({
- status:'0',
- msg:'',
- result:req.cookies.userName || ''
- });
- }else{
- res.json({
- status:'1',
- msg:'未登录',
- result:''
- })
- }
- })
src/components/NavHeader.vue
- mounted(){
- this.checkLogin();
- },
- methods:{
- checkLogin(){ // 检查是否登录
- axios.get("/users/checkLogin").then((response)=>{
- let res = response.data;
- if(res.status == '0'){
- this.nickName = res.result;
- }
- })
- }
- }
Vue nodejs商城项目-登录模块的更多相关文章
- Vue nodejs商城项目-项目概述
项目概况 用vue2.0 +node.js +MongonDB 做了一个商城系统 技术选型 Vue2.0+node.js+express+MongoDB+axios+vuex 构建工具 Webpack ...
- Vue nodejs商城项目- 前后端数据传递
.利用Mongoose查询MongoDB 通过mongoose插件可以简捷地从mondodb中获取数据,首先安装mongoose: cnpm install mongoose --save 使用m ...
- Vue nodejs商城项目-商品列表价格过滤和加入购物车功能
一.价格过滤功能 GoodsList.vue >>点击价格区间时发送请求 methods:{ getGoodsList(flag){ var param = { ...
- Vue nodejs商城项目-商品的分页、排序、筛选
.分页 ,要查第3页的数据,则跳过2*8条数据,然后返回8条数据. 在实现滚动加载时,页面刚一加载完成并不需要请求所有数据,当用户下拉到页面底部时,再去请求数据并拼接到商品数据列表中. 通过vue-i ...
- Vue nodejs商城项目-商品列表页面组件
data(){ return { goodsList:[], // 商品列表 priceFilter:[ // 价格区间数组 ...
- Vue nodejs商城项目-搭建express框架环境
1.express-project 搭建express框架环境 安装express generator生成器 通过生成器自动创建项目 配置分析 安装 cnpm i -g express-generat ...
- iOS不得姐项目--登录模块的布局,设置文本框占位文字颜色,自定义内部控件竖直排列的按钮
一.登录模块的布局 将一整部分切割成若干部分来完成,如图分成了三部分来完成 设置顶部状态栏为白色的方法 二.设置文本框占位文字颜色 <1>方法一与方法二实现原理是同一种,都是通过设置pla ...
- Vue nodejs商城-订单模块
一.订单列表渲染 新建OrderConfirm.vue订单确认页面,添加路由 src/router/index.js添加路由 import OrderConfirm from '@/views/Ord ...
- Vue nodejs商城-地址模块
一.地址列表渲染 ,则不可以点击. src/views/Cart.vue <a class="btn btn--red" v-bind:class="{'btn-- ...
随机推荐
- Linux kernel workqueue机制分析
Linux kernel workqueue机制分析 在内核编程中,workqueue机制是最常用的异步处理方式.本文主要基于linux kernel 3.10.108的workqueue文档分析其基 ...
- oracle 报错:ORA-02019 未找到数据库的连接说明
一.问题描述 我之前连的是别的数据库,现在更换了数据库的连接,然后就报了如下的错误: 我使用的是NHibernate,我找到映射文件后发现我用了dblink,代码中table="COM_OR ...
- Java网络编程二--基于UDP的编程
DatagramSocket对象为基于UDP协议的Socket 构造器提供可以选择性绑定到指定端口和ip 创建完对象后调用:receive(DatagramPacket p) send(Dategra ...
- CentOS初使用命令总结
最近买了一台aliyun(ECS服务器)用来学习使用,初次使用难免要走弯路.遇到一些问题好长时间解决不了,结果经人指点豁然开朗.于是乎,总结了一些新生上路经验. 首先要解决的问题是:通过PuTTY.S ...
- C# 实现OrderBy按多个字段排序
//倒序 list.OrderByDescending(i => i.a).ThenByDescending(i => i.b); //顺序 list.OrderBy(i => i. ...
- mybatis简单示例
1.引入mybatis.jar mysql-connector-java-5.1.47.jar <dependency> <groupId>org.mybatis</gr ...
- ef linq 查询某时间段内数据 踩的坑
var now = DateTime.Now;var list =db.Jinbi_TypeLimit.Where(x => x.IsAvailable && x.JinbiTy ...
- 前端之CSS——盒子模型和浮动
一.CSS盒子模型 HTML文档中的每个元素都被描绘成矩形盒子,这些矩形盒子通过一个模型来描述其占用空间,这个模型称为盒子模型. 盒子模型通过四个边界来描述:margin(外边距),border(边框 ...
- [转]滚动视差?CSS 不在话下/background attachment
何为滚动视差 视差滚动(Parallax Scrolling)是指让多层背景以不同的速度移动,形成立体的运动效果,带来非常出色的视觉体验. 作为网页设计的热点趋势,越来越多的网站应用了这项技术. ...
- jQuery 添加样式属性的优先级别
jQuery类中添加多个属性 $('#five .a') .css({ color:'blue', border:'2px solid green', background:'blue' }); jQ ...