html页面判断是否登录,egg(103)--egg之定义公共的中间件判断用户是否登录以及去结算页面制作...

判断用户是否登录

中间件

app/middleware/userauth.js

module.exports = (options, app) => {

return async function init(ctx, next) {

//判断前台用户是否登录 如果登录可以进入 ( 去结算 用户中心) 如果没有登录直接跳转到登录

var userinfo = ctx.service.cookies.get('userinfo');

if (userinfo && userinfo._id && userinfo.phone) {

//判断数据库里面有没有当前用户

var userResutl = await ctx.model.User.find({ "_id": userinfo._id, "phone": userinfo.phone });

if (userResutl && userResutl.length > 0) {

//注意

await next();

} else {

ctx.redirect('/login');

}

} else {

ctx.redirect('/login');

}

};

};

router

var userauthMiddleware = app.middleware.userauth({}, app);

router.get('/buy/checkout', initMiddleware, userauthMiddleware, controller.default.buy.checkout);

}

效果

点击结算,如果没有登录,就跳转到登录页面

bVbm4vd?w=1365&h=818

bVbm4vi?w=1206&h=1019

购物车到结算页面

controller

app/controller/default/buy.js

async checkout() {

var orderList = [];

var allPrice = 0;

var cartList = this.service.cookies.get('cartList');

if (cartList && cartList.length > 0) {

for (var i = 0; i < cartList.length; i++) {

if (cartList[i].checked) {

orderList.push(cartList[i]);

allPrice += cartList[i].price * cartList[i].num;

}

}

await this.ctx.render('/default/checkout.html', {

orderList: orderList,

allPrice: allPrice

})

} else {

this.ctx.redirect('/cart')

}

}

view

app/view/default/checkout.html

<%=orderList%5Bi%5D.goods_img%>

元 x

应付总额:

效果

bVbm4wD?w=1476&h=638

bVbm4wG?w=1596&h=916

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/574798.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

3月初的日记:网站工作记录

一直在备考。考一个关于自己本身工作的资格证。也一直在忙碌中&#xff0c;三个项目的并驾齐驱。 可以说&#xff0c;我也很忙。 东北今天下了很大雪&#xff0c;厚厚的&#xff0c;踩上去咯吱咯吱的响&#xff0c;这样的安逸更容易使得心静下来。 但是&#xff0c;其实我是焦虑…

电子科技大学研究生计算机与科学,2019年电子科技大学计算机科学与工程学院考研复试分数线...

据电子科技大学研究生院消息&#xff0c;2019年电子科技大学计算机科学与工程学院考研复试分数线及调剂信息已出&#xff0c;详情如下&#xff1a;专业第一单元第二单元第三单元第四单元总分调剂调剂开放时间调剂结束时间公开招考人数081200计算机科学与技术50458090340不接收2…

debian 重复执行sh_debian 脚本启动方式

同所有的Unix一样,Debian启动时要执行init程序.init的配置文件(/etc/inittab)中指定的第一个执行脚本应该是/etc/init.d/rcS.该脚本执行/etc/rcS.d/目录中各脚本的扩展名指定或衍生进程完成诸如检查并挂载文件系,装载内核模块,启动网络服务,设定时钟等系统初始化工作.接着,为了…

(None resource)-Binary system

Description 给定一个范围[a,b] (0<a<b<10^18) 求出该范围内二进制中1的个数最多的数&#xff0c;如果存在多个答案&#xff0c;输出最小的那个数 Input 输入数据有多组&#xff0c;每组数据输入两个整数a&#xff0c;b&#xff0c;表示区间[a, b]。 Output 输出该区…

计算机应用的时间地点意义,计算机应用在教学中的作用

计算机应用在教学中的作用微课已成为当前我国教育信息化发展的重点和热点。在如今的数字化“微”时代&#xff0c;微课将成为一种新的教学模式和学习方式。下面是小编搜集整理的相关内容的论文&#xff0c;欢迎大家阅读参考。摘要&#xff1a;随着我国科技和技术的不断发展&…

java输出一副扑克牌_JAVA编一副扑克牌

匿名用户7级2011-05-03 回答public static void main(String [] args){List li new ArrayList();List li2 new ArrayList();List li3 new ArrayList();li.add("黑桃");li.add("红心");li.add("梅花");li.add("方片");for(int i 2 …

qpython能使用json吗l_Python pyjsonq包_程序模块 - PyPI - Python中文网

py jsonqpy jsonq是一个简单、优雅的python包&#xff0c;可以查询任何类型的json数据。通过在json上提供类似orm的查询&#xff0c;这将使您的生活更轻松。安装pip install pyjsonq用法只需在开始使用前导入软件包即可。作为python包&#xff1a;frompyjsonqimportJsonQ通过从…

虚拟跳线软件干什么用的_跳线的作用

跳线就是主板上的一个个小开关&#xff0c;(其它板卡上也有)&#xff0c;用来手动完成一些软件不能实现的操作&#xff0c;比如手动清空BIOS&#xff0c;超频等。如果主板上的跳线跳接得不正确&#xff0c;大多情况下都可能引起没有显示的故障。有些情况下&#xff0c;虽然也显…

启继承父位在什么时候_为什么少儿口才现在越来越受到家长们的重视

情商口才是个人素养、能力和智慧的一种综合反映&#xff0c;随着社会的发展&#xff0c;少年儿童的早期教育越来越受到家长的重视&#xff0c;特别是在培养孩子的语言表达能力中&#xff0c;更多的家长开始寻求各种方法来锻炼孩子的语言表达能力。源自于美国教育演说家卡耐基的…

x光肺部分割数据集_吴恩达发布了大型X光数据集,斯坦福AI诊断部分超越人类 | AAAI 2019...

数栗子 发自 凹非寺量子位 报道 | 公众号 QbitAI最近&#xff0c;吴恩达的斯坦福团队发布了一个叫做CheXpert的大型数据集&#xff0c;论文中选了AAAI 2019。它包含了224,316张标注好的胸部X光片&#xff0c;以及放射科医师为每张胸片写的病理报告。虽然&#xff0c;像从前NIH发…

python rpc webservice_关于RPC、HTTP、WebService的区别

关于 REST 介绍的文章已经很多了&#xff0c;这里只对 RPC 部分做一个介绍&#xff1a;RPC(远程过程调用)是什么简单的说&#xff0c;RPC就是从一台机器(客户端)上通过参数传递的方式调用另一台机器(服务器)上的一个函数或方法(可以统称为服务)并得到返回的结果。RPC 会隐藏底层…

python程序发布 ubuntu_将Windows项目发布到Ubuntu服务器详细教程(Windows编程,Ubuntu服务器做解释器)...

前期准备(1)专业版Pycharm(社区版没有deployment功能)&#xff0c;学生&#xff0c;教师可申请免费专业版&#xff0c;详情可看我的博客。(2)可通过SSH连接Ubuntu服务器&#xff0c;并且服务器安装了Python解释器。部署本地Pycharm项目到Ubuntu服务器1.点击Tools - Deployment …

nios 双核 烧录_nios程序烧写到epcs方法

折腾了好久&#xff0c;才把nios程序烧写到epcs的方法弄明白。开始先在网上搜了下&#xff0c;这方面资料很多&#xff0c;看了半天也没怎么弄明白&#xff0c;无奈&#xff0c;只好去找官方文档&#xff0c;看完后&#xff0c;只想说&#xff0c;官方文档确实给力。下面列出参…

access百度翻译 get_Asp.NET调用百度翻译

Asp.NET调用百度翻译&#xff0c;图示&#xff1a;HTML:OA翻译TextMode"MultiLine">源语言&#xff1a;自动检测中文英文日文目标语言&#xff1a;自动检测中文英文日文runat"server" Text"翻译" οnclick"Translate_Click" />C…

angular js 默认选中_AngularJS Select(选择框)

下拉框默认的值为 key-value 对中的 value &#xff0c;也可以用 as 来修改下拉框的值。也就是 x for (x, y) 相当于是 y as x for (x, y)。as 前面的为下拉框的值&#xff0c;后面的为下拉框显示的内容。​也可以不使用key-value 对中的 value 作为下拉框的值, 直接使用对象的…

【Qt之Quick模块】6. QML语法详解_1 基础语法与三种导入语句

前言 通过以上1-5文档的介绍&#xff0c;Quick与QML的概念及QML语法、类型、文件作用等已叙述个大概&#xff0c;接下来是对QML语法进行展开来说。 其实&#xff0c;学习任何一门语言或者做任何一件事情&#xff0c;并不用一开始就要求尽善尽美&#xff0c;做个无懈可击&…

datagrip将一个数据库中的数据_跨平台数据库管理神器DataGrip,用上就爱不释手...

原文链接&#xff1a;https://www.ffeeii.com/2041.htmlDataGrip是Jetbrains旗下众多优秀的效率生产工具之一。下载地址&#xff1a;https://www.jetbrains.com/datagrip/DataGrip是多引擎数据库环境&#xff0c;支持几乎常见的数据库类型&#xff1a;PostgreSQL、MySQL、Oracl…

栅格单元值的选取方法_ArcGIS中栅格数据重采样方法

2.用ArcGIS中的Resampling工具进行栅格重采样操作在ArcToolbox中依次找到Data Management Tools—>Raster—>RasterProcessing—>Resample工具&#xff0c;工具界面如下图所示&#xff1a;其中各参数含义如下&#xff1a;Input raster: 输入栅格数据集Output raster d…

城市轨道交通运营管理属于什么院系_专业介绍|城市轨道交通运营管理专业

原标题&#xff1a;专业介绍|城市轨道交通运营管理专业专业介绍丨城市轨道交通运营管理专业▲▲▲汽车工程系简介THE FIRST汽车工程系目前开设了汽车检测与维修技术、城市轨道交通运营管理、城市轨道交通通信信号技术等专业&#xff0c;在校学生700余人。汽车工程系突出复合型技…

idea 鼠标变量_IntelliJ IDEA鼠标悬停方法显示Java Doc

本问题已经有最佳答案&#xff0c;请猛点这里访问。我正在使用IntelliJ IDEA 9&#xff0c;是否可以配置IDEA&#xff0c;以便在将鼠标悬停在某个方法上时&#xff0c;IDEA会调出Javadoc(与CTRL Q相同)&#xff1f;看来&#xff0c;此功能可能最终会进入IntelliJ IDEA 12.1或1…