为什么$a++*3里面的今天不上班 加加见不执行?

第三次应邀与董事长一起参加他企业的“客户验厂分析会”,刚一坐下,总经理就递了一份“客户验厂不合格项一览表”过来,我一看,所列20多项缺失项目几乎都是“标识不清、记录不全、文件标准不明、现场管理混乱、产品材料乱放、良品次品混装”等简单得不能再简单的问题,尤为不能理解的是,这些不合格项跟前两次客户验厂的缺失内容都一样。如此简单的问题为何多次都未能解决?又还值得这么多人三番五次地开会检讨吗? &&&&&&
  果不其然,会议刚一开始,老板就一一质问??为什么“仓库会没有标识”?为什么“不合格品与合格品要混放”?为什么“车间要用红色盒子装合格产品”?为什么上次的问题到这次又照样被检查出来?遗憾的是,几位主管都唧唧歪歪地一个劲地诉说理由,没一个人敢直接回答老板的问题,导致急性子的老板拍桌子挨个破口大骂,致使会议无法继续。 & &&&&&&
  原来,董事长请过来的这位老总是搞技术出身的,遇事喜欢追根究底,喜欢找一大群人来分析原因,但是,原因分析出来后却找不到任何可行办法来解决,也不会一一安排下面的人下去执行,更不会运用系统思维进行流程设计和改善,就像一群天天开会商量着怎样给猫挂铃铛的老鼠一样,开会时满口依依呀呀的官腔,官僚得令人恶心不已,根本无人愿意主动进行改善。属于典型的“集体不思考、集体不负责”,所以,尽管会议天天开、可问题却依旧在。 & &&&&&&
  但是,问题的根源却不在此。该企业之所以“集体不负责”,是因为公司至今都还没有人因为“不执行、不负责”而遭到任何的责任追究。也没有任何一条制度规则来规定什么样的行为是失职,而失职又应该受到什么样的惩罚。即是上次因为质量问题而丢失一个客户,上至总经理下至小主管,也都没有任何人受到责任追究。更不会有任何一个管理者会主动为自己的工作缺失负责。上司不会,下属更不会,职位一大堆,企业问题一堆又一堆,因为一个不负责任的上司,其唯一作用就是带会一大堆更不负责的下属,除此无他。相反是制度规则乏力而人人辩解有力。最后是任何失职行为、任何无能行为、任何错误都可以被容忍! & &&&&&&&
  管理的目的是组织目标的达成,而目标的达成需要对责任进行合理分配并层层承担责任。而要求层层承担责任就必须制定层层的追责制度和规则来保障,管理容忍的是人的弱点而绝不是一而再、再而三的错误,对错误的容忍就是对整个组织的伤害,对错误的长期容忍实际就是一种犯罪,对错误的容忍更是对规则的不尊重,而一个长期得不到执行和尊重的规则其力度又会在哪里?试想一下,要是任何错误在一开始就能得到制止和追究,任何问题一开始发生就能得到及时的改善,任何一个渎职行为一开始就能受到及时的惩处,这些简单得不能再简单的问题还能持续存在吗?这些集体不负责的行为又能得以如此发扬吗?
  有职无责是管理的耻辱,执行不力其实是规则乏力,而规则乏力实际就是的最大悲哀
阅读:人次
上一条文章: 下一条文章: 没有了
没有相关文章
培训超市& (5000多套光盘)注册二级建造师考试
1.选择试题2.注册/登陆3.开始答题4.提交试卷5.查看成绩6.答案解析
您的位置:&& && && && && && 试卷题库内容
试题来源:
垫铁错用的问题出在工序检验的哪些环节?该分部工程是否可以参加优良工程评定?说明理由。
正确答案:有, 或者
说明项目经理安排4名焊工上岗符合规定的理由?
正确答案:有, 或者
背景资料中,单机试运行结束后,还应及时完成哪些工作?
正确答案:有, 或者
指出施工记录资料中的不完善部分?
正确答案:有, 或者
您可能感兴趣的试题
第&1&题:案例分析问答题: ()某机电设备安装公司承担了理工大学建筑面积为2万平方米的图书馆工程的通风空调系统施工任务。该工程共有S1~S6六个集中式全空气空调系统,空调风系统设计工作压力为600Pa。空气处理机组均采用带送风机段的组合式空调机,由安装公司采购并组成项目部承担安装任务。风管系统安装完毕后,严密性试验采用漏光法检测合格。
& &当施工进入空调系统调试阶段时,系统出现三个问题:①空气处理机组运转时晃动;②S1系统调试中在风管所有阀门全开情况下,实测送入空调区风量小于设计风量且相差较大,而该系统风机出口风量实测值符合设计要求;③空气处理机组冷却水进出管路上的阀门有滴水,经检查这两个阀门未保冷但无漏水。针对上述问题,施工单位采取了整改措施后才使系统调试合格。空调系统调试完成后,按施工质量验收程序进行了施工质量验收工作。
& &问题 1小题>空气处理机组运转时产生晃动的原因是什么?如何解决?正确答案:有, 或者
2小题>分析S1系统送入空调区的风量与设计风量相差较大的主要原因。正确答案:有, 或者
3小题>解决阀门滴水问题的措施有哪些?正确答案:有, 或者
4小题>按照建筑工程项目划分标准,该通风空调系统应划分为图书馆工程的什么工程?该工程的施工质量验收程序是什么?正确答案:有, 或者 第&2&题:案例分析问答题: ()
某机电设备安装公司承包了一台带换热段的分离塔和附属容器、工艺管道的安装工程。合同约定,分离塔由安装公司制造或订货,建设单位提供制造图样。由于该塔属压力容器,安装公司不具备压力容器制造和现场组焊资格,故向某具备资格的容器制造厂订货。安装公司为了抢工期,未办理任何手续,在分离塔运抵现场卸车后,直接就吊装就位,并进行后续的配管工程。
& &在工程实施过程中,出现了以下事件:
& &事件1:管道系统压力试验中,塔进、出口管道上的多个阀门发生泄漏。检查施工记录,该批由建设单位供货的阀门在安装前未进行试验。安装公司拆卸阀门并处理完后重新试压合格,工期比原计划延误6d。安装单位就工期延误造成的损失向建设单位索赔,遭到建设单位拒绝。
& &事件2:在联动试运行中,分离塔换热段管板与接管连接的多处焊缝泄漏,试运行中止。安装单位对塔泄漏处进行了补焊处理后,再次启动试运行,而塔的原漏点泄漏更加严重,不得不再次停止试运行。分析事故原因,确定是由分离塔质量问题引起,但未查到分离塔的出厂质量证明文件和现场交接记录。由于分离塔待修停工,使该项目推迟竣工投产2个月。为此,建设单位要求安装单位承担质量责任并赔偿全部经济损失。
阀门安装前应由哪个单位进行何种试验?该管道使用的阀门试验的比例是多少?
正确答案:有, 或者
说明建设单位拒绝安装单位对事件1提出索赔的理由。
正确答案:有, 或者
安装单位在分离塔安装前应根据什么规定、申办何种手续?安装单位对分离塔进行补焊作业有什么不妥?
正确答案:有, 或者
在事件2中,安装单位和容器制造厂的质量职责是什么?对事故各自应负什么质量和经济责任?说明理由。
正确答案:有, 或者 第&3&题:案例分析问答题: ()
某建筑空调工程中的冷热源主要设备由某施工单位吊装就位,设备需吊装到地下一层(-7.5m),再牵引至冷冻机房和锅炉房就位。施工单位依据设备一览表(见下表)及施工现场条件(混凝土地坪)等技术参数进行分析、比较,制订了设备吊装施工方案,方案中选用KMK6200汽车式起重机,起重机在工作半径19m、吊杆伸长44.2m时,允许载荷为21.5t,满足设备的吊装要求。锅炉房的泄爆口尺寸为9000mm&4000mm,大于所有设备外形尺寸,设置锅炉房泄爆口为设备的吊装口,所有设备经该吊装口吊入,冷水机组和蓄冰槽需用卷扬机牵引到冷冻机房就位。
& & & & & & & & & & & & & & & & & & &吊装设备一览表
外形尺寸/mm
重量/(t/台)
双工况冷水机组
& 在吊装方案中,绘制了吊装施工平面图,设置吊装区,制定安全技术措施,编制了设备吊装进度计划(见下表)。施工单位按吊装的工程量及进度计划配置足够的施工作业人员。
设备吊装进度计划
& & & & & & & & &
设备吊装工程中应配置哪些主要的施工作业人员?
正确答案:有, 或者
起重机的站立位置的地基应如何处理?
正确答案:有, 或者
指出进度计划中设备吊装顺序不合理之处?说明理由并纠正。
正确答案:有, 或者
在设备的试吊中,应关注哪几个重要步骤?
正确答案:有, 或者
做了该试卷的考友还做了
······& Nodejs开发框架Express3.0开发手记–从零开始
Nodejs开发框架Express3.0开发手记–从零开始
Nodejs给Javascript赋予了服务端应用的生命,Jquery让Javascript成为浏览中开发的利器。 最近学习了Nodejs的Express3.0的开发框架,本来是按照“node.js开发指南”书中介绍,但“node.js开发指南”讲的是Express2.x的,从Express2.x到Express3.0自己模索中还是走了不少弯路的。写篇文章总结一下。
张丹(Conan), 程序员Java,R,PHP,Javacript
weibo:@Conan_Z
blog: http://blog.fens.me
转载请注明出处:
程序代码已经上传到github有需要的同学,自行下载。
从零开始nodejs系列文章
,将介绍如何利Javascript做为服务端脚本,通过Nodejs框架web开发。Nodejs框架是基于V8的引擎,是目前速度最快的Javascript引擎。chrome浏览器就基于V8,同时打开20-30个网页都很流畅。Nodejs标准的web开发框架Express,可以帮助我们迅速建立web站点,比起PHP的开发效率更高,而且学习曲线更低。非常适合小型网站,个性化网站,我们自己的Geek网站!!
此文重点介绍Express3.0的开发框架,其中还会涉及到Mongoose,Ejs,Bootstrap等相关内容。
Express3.0配置文件
Ejs模板使用
Bootstrap界面框架
Session使用
页面访问控制
开发环境:
Win7旗舰版 64bit
MonogoDB: v2.4.3
Tue May 14 09:24:50.118 [initandlisten] MongoDB starting : pid=1716 port=27017 dbpath=./data 64-bit host=PC
Tue May 14 09:24:50.119 [initandlisten] db version v2.4.3
Tue May 14 09:24:50.119 [initandlisten] git version: feea03e91ecbf
Tue May 14 09:24:50.119 [initandlisten] build info: windows sys.getwindowsversion(major=6, minor=1, build=7601, platform=2, service_pack='Service Pack 1') BOOST_LIB_VERSION=1_49
Tue May 14 09:24:50.119 [initandlisten] allocator: system
Tue May 14 09:24:50.119 [initandlisten] options: { dbpath: "./data" }
Tue May 14 09:24:50.188 [initandlisten] journal dir=./data\journal
Tue May 14 09:24:50.189 [initandlisten] recover : no journal files present, no recovery needed
Tue May 14 09:24:50.441 [initandlisten] preallocateIsFaster=true 3.26
Tue May 14 09:24:50.778 [initandlisten] preallocateIsFaster=true 5.88
Tue May 14 09:24:51.827 [initandlisten] waiting for connections on port 27017
Tue May 14 09:24:51.827 [websvr] admin web console waiting for connections on port 28017
nodejs: v0.10.5, npm 1.2.19
1. 建立工程
进入工程目录
cd D:\workspace\project
全局安装express,express作为命令被安装到了系统中
npm install -g express
查看express版本
express -V
使用express命令创建工程,并支持ejs
D:\workspace\project&express -e nodejs-demo
create : nodejs-demo
create : nodejs-demo/package.json
create : nodejs-demo/app.js
create : nodejs-demo/public
create : nodejs-demo/public/javascripts
create : nodejs-demo/public/images
create : nodejs-demo/public/stylesheets
create : nodejs-demo/public/stylesheets/style.css
create : nodejs-demo/routes
create : nodejs-demo/routes/index.js
create : nodejs-demo/routes/user.js
create : nodejs-demo/views
create : nodejs-demo/views/index.ejs
install dependencies:
$ cd nodejs-demo && npm install
run the app:
$ node app
根据提示,下载依赖包
cd nodejs-demo && npm install
express@3.2.2 node_modules\express
├── methods@0.0.1
├── fresh@0.1.0
├── buffer-crc32@0.2.1
├── range-parser@0.0.4
├── cookie-signature@1.0.1
├── cookie@0.0.5
├── qs@0.6.3
├── commander@0.6.1
├── debug@0.7.2
├── mkdirp@0.3.4
├── send@0.1.0 (mime@1.2.6)
└── connect@2.7.8 (pause@0.0.1, bytes@0.2.0, formidable@1.0.13)
模板项目建立成功,启动模板项目。
D:\workspace\project\nodejs-demo&node app.js
Express server listening on port 3000
本地的3000端口被打开,通过浏览器访问: localhost:3000
通过node启动程序,每次代码修改都需要重新启动。 有一个工具supervisor,每次修改代码后会自动重启,会我们开发省很多的时间。
npm install supervisor
再启动服务
D:\workspace\project\nodejs-demo&supervisor app.js
DEBUG: Running node-supervisor with
DEBUG: program 'app.js'
DEBUG: --watch '.'
DEBUG: --ignore 'undefined'
DEBUG: --extensions 'node|js'
DEBUG: --exec 'node'
DEBUG: Starting child process with 'node app.js'
DEBUG: Watching directory 'D:\workspace\project\nodejs-demo' for changes.
Express server listening on port 3000
2. 目录结构
D:\workspace\project\nodejs-demo&dir
09:42 877 app.js
09:48 &DIR& node_modules
09:42 184 package.json
09:42 &DIR& public
09:42 &DIR& routes
09:42 &DIR& views
目录介绍:
node_modules, 存放所有的项目依赖库。(每个项目管理自己的依赖,与Maven,Gradle等不同)
package.json,项目依赖配置及开发者信息
app.js,程序启动文件
public,静态文件(css,js,img)
routes,路由文件(MVC中的C,controller)
Views,页面文件(Ejs模板)
3. Express3.0配置文件
打开app.js文件
* 模块依赖
var express = require('express')
, routes = require('./routes')
, user = require('./routes/user')
, http = require('http')
, path = require('path');
var app = express();
//环境变量
app.set('port', process.env.PORT || 3000);
app.set('views', __dirname + '/views');
app.set('view engine', 'ejs');
app.use(express.favicon());
app.use(express.logger('dev'));
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(app.router);
app.use(express.static(path.join(__dirname, 'public')));
// 开发模式
if ('development' == app.get('env')) {
app.use(express.errorHandler());
// 路径解析
app.get('/', routes.index);
app.get('/users', user.list);
// 启动及端口
http.createServer(app).listen(app.get('port'), function(){
console.log('Express server listening on port ' + app.get('port'));
4. Ejs模板使用
让ejs模板文件,使用扩展名为html的文件。
修改:app.js
app.engine('.html', ejs.__express);
app.set('view engine', 'html');// app.set('view engine', 'ejs');
修改后,ejs变量没有定义,supervisor的程序会一直报错
ReferenceError: ejs is not defined
at Object. (D:\workspace\project\nodejs-demo\app.js:17:21)
at Module._compile (module.js:456:26)
at Object.Module._extensions..js (module.js:474:10)
at Module.load (module.js:356:32)
at Function.Module._load (module.js:312:12)
at Function.Module.runMain (module.js:497:10)
at startup (node.js:119:16)
at node.js:901:3
DEBUG: Program node app.js exited with code 8
在app.js中增加ejs变量
var express = require('express')
, routes = require('./routes')
, user = require('./routes/user')
, http = require('http')
, path = require('path')
, ejs = require('ejs');
访问localhost:3000,程序报错
Error: Failed to lookup view "index"
at Function.app.render (D:\workspace\project\nodejs-demo\node_modules\express\lib\application.js:495:17)
at ServerResponse.res.render (D:\workspace\project\nodejs-demo\node_modules\express\lib\response.js:756:7)
at exports.index (D:\workspace\project\nodejs-demo\routes\index.js:7:7)
at callbacks (D:\workspace\project\nodejs-demo\node_modules\express\lib\router\index.js:161:37)
at param (D:\workspace\project\nodejs-demo\node_modules\express\lib\router\index.js:135:11)
at pass (D:\workspace\project\nodejs-demo\node_modules\express\lib\router\index.js:142:5)
at Router._dispatch (D:\workspace\project\nodejs-demo\node_modules\express\lib\router\index.js:170:5)
at Object.router (D:\workspace\project\nodejs-demo\node_modules\express\lib\router\index.js:33:10)
at next (D:\workspace\project\nodejs-demo\node_modules\express\node_modules\connect\lib\proto.js:190:15)
at Object.methodOverride [as handle] (D:\workspace\project\nodejs-demo\node_modules\express\node_modules\connect\lib\middleware\methodOverride.js:37:5)
GET / 500 26ms
重命名:views/indes.ejs 为 views/index.html
访问localhost:3000正确
5. 增加Bootstrap界面框架
其实就是把js,css文件复制到项目中对应该的目录里。 包括4个文件:
复制到public/stylesheets目录
bootstrap.min.css
bootstrap-responsive.min.css
复制到public/javascripts目录
bootstrap.min.js
jquery-1.9.1.min.js
接下来,我们把index.html页面切分成3个部分:header.html, index.html, footer.html
header.html, 为html页面的头部区域
index.html, 为内容显示区域
footer.html,为页面底部区域
header.html
&!DOCTYPE html&
&html lang="en"&
&meta charset="utf-8"&
&title&&%=: title %&&/title&
&!-- Bootstrap --&
&link href="/stylesheets/bootstrap.min.css" rel="stylesheet" media="screen"&
&!-- &link href="css/bootstrap-responsive.min.css" rel="stylesheet" media="screen"& --&
&body screen_capture_injected="true"&
index.html
&% include header.html %&
&h1&&%= title %&&/h1&
&p&Welcome to &%= title %&&/p&
&% include footer.html %&
注:express3.0时,ejs嵌入其他页面时使用include,express2.x用法不一样。
footer.html
&script src="/javascripts/jquery-1.9.1.min.js"&&/script&
&script src="/javascripts/bootstrap.min.js"&&/script&
访问localhost:3000正确。
我们已经成功的使用了EJS模板的功能,把公共的头部和底部从页面中分离出来了。
并已经引入了bootstrap界面框架,后面讲到“登陆界面”的时候,就会看到bootstrap界面效果了。
6. 路由功能
我们设计一下用户登陆业务需求。
访问路径:/,页面:index.html,不需要登陆,可以直接访问。
访问路径:/home,页面:home.html,必须用户登陆后,才可以访问。
访问路径:/login,页面:login.html,登陆页面,用户名密码输入正确,自动跳转到home.html
访问路径:/logout,页面:无,退出登陆后,自动回到index.html页面
打开app.js文件,在增加路由配置
app.get('/', routes.index);
app.get('/login', routes.login);
app.post('/login', routes.doLogin);
app.get('/logout', routes.logout);
app.get('/home', routes.home);
注:get为get请求,post为post请求,all为所有针对这个路径的请求
我们打开routes/index.js文件,增加对应的方法。
exports.index = function(req, res){
res.render('index', { title: 'Index' });
exports.login = function(req, res){
res.render('login', { title: '用户登陆'});
exports.doLogin = function(req, res){
var user={
username:'admin',
password:'admin'
if(req.body.username===user.username && req.body.password===user.password){
res.redirect('/home');
res.redirect('/login');
exports.logout = function(req, res){
res.redirect('/');
exports.home = function(req, res){
var user={
username:'admin',
password:'admin'
res.render('home', { title: 'Home',user: user});
创建views/login.html和views/home.html两个文件
login.html
&% include header.html %&
&div class="container-fluid"&
&form class="form-horizontal" method="post"&
&fieldset&
&legend&用户登陆&/legend&
&div class="control-group"&
&label class="control-label" for="username"&用户名&/label&
&div class="controls"&
&input type="text" class="input-xlarge" id="username" name="username"&
&div class="control-group"&
&label class="control-label" for="password"&密码&/label&
&div class="controls"&
&input type="password" class="input-xlarge" id="password" name="password"&
&div class="form-actions"&
&button type="submit" class="btn btn-primary"&登陆&/button&
&/fieldset&
&% include footer.html %&
注:使用了bootstrap界面框架,效果还不错吧.
&% include header.html %&
&h1&Welcome &%= user.username %&, 欢迎登陆!!&/h1&
&a claa="btn" href="/logout"&退出&/a&
&% include footer.html %&
修改index.html,增加登陆链接
index.html
&% include header.html %&
&h1&Welcome to &%= title %&&/h1&
&p&&a href="/login"&登陆&/a&&/p&
&% include footer.html %&
路由及页面我们都写好了,快去网站上试试吧。
7. Session使用
从刚来的例子上面看,执行exports.doLogin时,如果用户名和密码正确,我们使用redirect方法跳转到的home
res.redirect('/home');
执行exports.home时,我们又用render渲染页面,并把user对象传给home.html页面
res.render('home', { title: 'Home',user: user});
为什么不能在doLogin时,就把user对象赋值给session,每个页面就不再传值了。
session这个问题,其实是涉及到服务器的底层处理方式。
像Java的web服务器,是多线程调用模型。每用户请求会打开一个线程,每个线程在内容中维护着用户的状态。
像PHP的web服务器,是交行CGI的程序处理,CGI是无状态的,所以一般用cookie在客户的浏览器是维护用户的状态。但cookie在客户端维护的信息是不够的,所以CGI应用要模仿用户session,就需要在服务器端生成一个session文件存储起来,让原本无状态的CGI应用,通过中间文件的方式,达到session的效果。
Nodejs的web服务器,也是CGI的程序无状态的,与PHP不同的地方在于,单线程应用,所有请求都是异步响应,通过callback方式返回数据。如果我们想保存session数据,也是需要找到一个存储,通过文件存储,redis,Mongdb都可以。
接下来,我将演示如何通过mongodb来保存session,并实现登陆后用户对象传递。
app.js文件
var express = require('express')
, routes = require('./routes')
, user = require('./routes/user')
, http = require('http')
, path = require('path')
, ejs = require('ejs')
, SessionStore = require("session-mongoose")(express);
var store = new SessionStore({
url: "mongodb://localhost/session",
interval: 120000
app.use(express.favicon());
app.use(express.logger('dev'));
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(express.cookieParser());
app.use(express.cookieSession({secret : 'fens.me'}));
app.use(express.session({
secret : 'fens.me',
store: store,
cookie: { maxAge: 900000 }
app.use(function(req, res, next){
res.locals.user = req.session.
app.use(app.router);
app.use(express.static(path.join(__dirname, 'public')));
注:app.js文件有顺序要求,一定要注意!!!
安装session-mongoose依赖库
D:\workspace\project\nodejs-demo&npm install session-mongoose
D:\workspace\project\nodejs-demo\node_modules\session-mongoose\node_modules\mongoose\node_modules\mongodb\node_modules\bson&node "D:\toolkit\nodejs\node_modules\npm\bin\node-gyp-bin\\..\..\node_modules\node-gyp\bin\node-gyp.js" rebuild
C:\Program Files (x86)\MSBuild\Microsoft.Cpp\v4.0\Microsoft.Cpp.InvalidPlatform.Targets(23,7): error MSB8007: 项目“kerberos.vcxproj”的平台无效。平台为“x64”。您会看到此消息的可能原因是,您尝试在没有解决方案文件的情况下生成项目,并且为
oose\node_modules\mongoose\node_modules\mongodb\node_modules\bson\build\bson.vcxproj]
session-mongoose@0.2.2 node_modules\session-mongoose
└── mongoose@3.6.10 (mpath@0.1.1, ms@0.1.0, hooks@0.2.1, sliced@0.0.3, muri@0.3.1, mpromise@0.2.1, mongodb@1.3.3)
安装有错误但是没关系。
访问:http://localhost:3000/login,正常
修改routes/index.js文件
exports.doLogin方法
exports.doLogin = function(req, res){
var user={
username:'admin',
password:'admin'
if(req.body.username===user.username && req.body.password===user.password){
req.session.user=
return res.redirect('/home');
return res.redirect('/login');
exports.logout方法
exports.logout = function(req, res){
req.session.user=
res.redirect('/');
exports.home方法
exports.home = function(req, res){
res.render('home', { title: 'Home'});
这个时候session已经起作用了,exports.home的user显示传值已经被去掉了。 是通过app.js中app.use的res.locals变量,通过框架进行的赋值。
app.use(function(req, res, next){
res.locals.user = req.session.
注:这个session是express3.0的写法,与express2.x是不一样的。原理是在框架内每次赋值,把我们刚才手动传值的过程,让框架去完成了。
8. 页面提示
登陆的大体我们都已经讲完了,最后看一下登陆失败的情况。
我们希望如果用户登陆时,用户名或者密码出错了,会给用户提示,应该如何去实现。
打开app.js的,增加res.locals.message
app.use(function(req, res, next){
res.locals.user = req.session.
var err = req.session.
delete req.session.
res.locals.message = '';
if (err) res.locals.message = '&div class="alert alert-error"&' + err + '&/div&';
修改login.html页面,&%- message %&
&% include header.html %&
&div class="container-fluid"&
&form class="form-horizontal" method="post"&
&fieldset&
&legend&用户登陆&/legend&
&%- message %&
&div class="control-group"&
&label class="control-label" for="username"&用户名&/label&
&div class="controls"&
&input type="text" class="input-xlarge" id="username" name="username" value="admin"&
&div class="control-group"&
&label class="control-label" for="password"&密码&/label&
&div class="controls"&
&input type="password" class="input-xlarge" id="password" name="password" value="admin"&
&div class="form-actions"&
&button type="submit" class="btn btn-primary"&登陆&/button&
&/fieldset&
&% include footer.html %&
修改routes/index.js,增加req.session.error
exports.doLogin = function(req, res){
var user={
username:'admin',
password:'admin'
if(req.body.username===user.username && req.body.password===user.password){
req.session.user=
return res.redirect('/home');
req.session.error='用户名或密码不正确';
return res.redirect('/login');
让我们来看看效果: http://localhost:3000/login 输入错误的和密码, 用户名:adminfe,密码:12121
9. 页面访问控制
网站登陆部分按照我们的求已经完成了,但网站并不安全。
localhost:3000/home,页面本来是登陆以后才访问的,现在我们不要登陆,直接在浏览器输入也可访问。
页面报错了,提示&%= user.username %& 变量出错。
GET /home?user==a 500 15ms
TypeError: D:\workspace\project\nodejs-demo\views\home.html:2
1| &% include header.html %&
&& 2| &h1&Welcome &%= user.username %&, 欢迎登陆!!&/h1&
3| &a claa="btn" href="/logout"&退出&/a&
4| &% include header.html %&
Cannot read property 'username' of null
at eval (eval at &anonymous& (D:\workspace\project\nodejs-demo\node_modules\ejs\lib\ejs.js:
at eval (eval at &anonymous& (D:\workspace\project\nodejs-demo\node_modules\ejs\lib\ejs.js:
at D:\workspace\project\nodejs-demo\node_modules\ejs\lib\ejs.js:249:15
at Object.exports.render (D:\workspace\project\nodejs-demo\node_modules\ejs\lib\ejs.js:287:
at View.exports.renderFile [as engine] (D:\workspace\project\nodejs-demo\node_modules\ejs\l
at View.render (D:\workspace\project\nodejs-demo\node_modules\express\lib\view.js:75:8)
at Function.app.render (D:\workspace\project\nodejs-demo\node_modules\express\lib\applicati
at ServerResponse.res.render (D:\workspace\project\nodejs-demo\node_modules\express\lib\res
at exports.home (D:\workspace\project\nodejs-demo\routes\index.js:36:8)
at callbacks (D:\workspace\project\nodejs-demo\node_modules\express\lib\router\index.js:161
这个页面被打开发,因为没有user.username参数。我们避免这样的错误发生。
还记录路由部分里说的get,post,all的作用吗?我现在要回到路由配置中,再做点事情。
修改app.js文件
app.all('/login', notAuthentication);
app.get('/login', routes.login);
app.post('/login', routes.doLogin);
app.get('/logout', authentication);
app.get('/logout', routes.logout);
app.get('/home', authentication);
app.get('/home', routes.home);
访问控制:
/ ,谁访问都行,没有任何控制
/login,用all拦截所有访问/login的请求,先调用authentication,用户登陆检查
/logout,用get拦截访问/login的请求,先调用notAuthentication,用户不登陆检查
/home,用get拦截访问/home的请求,先调用Authentication,用户登陆检查
修改app.js文件,增加authentication,notAuthentication两个方法
function authentication(req, res, next) {
if (!req.session.user) {
req.session.error='请先登陆';
return res.redirect('/login');
function notAuthentication(req, res, next) {
if (req.session.user) {
req.session.error='已登陆';
return res.redirect('/');
配置好后,我们未登陆,直接访问localhost:3000/home时,就会跳到/login页面
如果你也出现图片显示的内容,那么恭喜你了。
Nodejs使用Express3.0框架的第一步你已经完成了,并且还使用了ejs,bootstrap,mongoose库的使用。
希望此文对大家有所帮助。
转载请注明出处:
程序代码已经上传到github有需要的同学,自行下载。
This entry was posted in
Pingback: ()
Pingback: ()
Pingback: ()
Pingback: ()
Pingback: ()
Pingback: ()
Pingback: ()
Designed by

我要回帖

更多关于 加加不路跟 的文章

 

随机推荐