b t no 1已经登入怎么tmt3播放器啊

This site in other countries/regions:带你认识更牛的人下载即送20张免费照片冲印
扫码下载App
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!&&|&&
LOFTER精选
网易考拉推荐
#设置启动脚本的账号为vuser
sudo&-u vuser ./fcgi_perl2&&
设置启动fcgi_perl的账号为uvser,要不然在web界面上发送邮件时新保存到邮件目录下的文件属主为root:root,会造成文件权限上的一些问题。
c.全部配置完毕后登陆Extmail时出现”Unix::Syslog not found”错误
给perl安装Unix::Syslog包
perl&-MCPAN -e&'install Unix::Syslog'
d.登陆extman时,验证码图片没有显示
缺少perl-GD包,安装后问题消失
wget&http://packages.sw.be/perl-GD/perl-GD-2.43-1.el5.rf.i386.rpm
rpm -ivh perl-GD-2.43-1.el5.rf.i386.rpm
e.打开extmail邮件系统的web页面加载很慢
经过分析,发现是由于页面加载时调用了extmail.net的rpc服务。修改 /var/www/extsuite/extmail/html/plugins/rpc_init.js 文件,去除其中rpc的使用.
rpc_url_list = [
// & &"http://rpc-srv01.extmail.net/phprpc/rpc.php",
// & &"http://rpc-srv02.extmail.net/phprpc/rpc.php",
// & &"http://rpc-srv03.extmail.net/phprpc/rpc.php",
rpc_plg_list = [
// & &"coolweather",
// & &"etnews",
// & &"chkupdate",
修改 /var/www/extsuite/extman/html/plugins/rpc_init.js 文件,去除其中rpc的使用.
rpc_url_list = [
// & &"http://rpc-srv01.extmail.net/phprpc/rpc.php",
// & &"http://rpc-srv02.extmail.net/phprpc/rpc.php",
修改后,再次打开extmail的Web页面,没有任何停顿的感觉,说明是之前的访问速度慢是由于程序调用extmail的rpc服务造成的
Extmail登录时,页面长期停在loading的可能原因
登录extmail有时候总是停在loading,好长时间才能登录,原因可能是因为天气,新闻等插件的原因:确认方法:1.将extmail\html\default\welcome.html里面的几行,注释掉,&script type="text/javascript" src="/extmail/plugins/phprpc_client.js"&&/script&&script type="text/javascript" src="/extmail/plugins/rpc_init.js"&&/script&&script type="text/javascript" src="/extmail/plugins/coolweather/coolweather.js"&&/script&&script type="text/javascript" src="/extmail/plugins/etnews/etnews.js"&&/script&&script type="text/javascript" src="/extmail/plugins/chkupdate/chkupdate.js"&&/script&&script language=javascript&rpc_chklng();&/script&
如果还是显示内部服务器错误,apache的error_log还提示:suexec policy violation: see suexec log for more detailsPremature end of script headers: index.cgi提示查看su日志:----------------------------------关于suexec的FAQ1.出现以下错误&& command not in docroot编译的时候加入--with-suexec-docroot&&&& 以后虚拟主机运行suexec的目录必须包含指定的目录里,通过
suexec -V 可以察看docroot目录是哪儿
2.出现以下错误&& user mismatch (daemon instead of www)编译的时候加入--with-suexec-caller=daemon&& 默认是www,但一般apache的运行用户是nobody或者daemon,这里我们是httpd2.2.2,用户是daemon,所以指定这个参数,否则suexec不能被运行。
3.出现以下错误&& cannot run as forbidden uid (1001/index.cgi)在虚拟主机配置SuexecUserGroup时,指定的用户和组,必须高于--with-suexec-uidmin --with-suexec-gidmin 指定的用户uid和gid,否则被限制使用。------------------------------------------------编译Apache的时候要加上:&& --enable-suexec \&&&&&&&&&&&&&&&&&&&&&&& --with-suexec-caller=daemon \&& --with-suexec-docroot=/var/www/extsuite/
重启apache httpd服务,service httpd start,访问,出现了邮箱登陆界面不胜欢喜,输入用户名、密码、域信息点“登陆”,
出现错误信息: Can't open
/var/www/extsuite/extmail/tmp/sid_ed2ba93c4a107, No such file or directory,
将extmail备份包里的tmp文件夹复制到extmail目录下,重新登陆,
&&&&& 出现新的错误信息:Can't open
&&&&&&&& /var/www/extsuite/extmail/tmp/sid_73abd511a192bf2c63bd6e, Permission denied,于是给vuser:vgroup授权:
&Extmail进后台不能正常显示系统的信息的解决办法
进入后台不显示目录信息提示"No such file or directory"
进入extman/daemon/cmdserver --daemon& 运行启来就能显示了
&DBI connect('database=host=mysql_socket=/var/lib/mysql/mysql.sock','extmail',...) failed: Access denied for user
to database 'localhost' at /var/www/extsuite/extmail/libs/Ext/Auth/MySQL.pm line 45
刚刚安装的服务器,账号登陆Extmail报错: DBI connect('database=extmail;host=mysql_socket=/var/lib/mysql/mysql.sock','db_user',...) failed: Access denied for user 'db_user'@'localhost' (using password: YES) at /var/www/extsuite/extmail/libs/Ext/Auth/MySQL.pm line 45
&终于搞定了,在 中遨游了2天,发现犯了低级的错误!!!!1.vi&& /var/www/extsuite/extmail/webmail.cf 中的配置:
SYS_MYSQL_USER = extmail ,
SYS_MYSQL_PASS = extmail ,
SYS_MYSQL_DB = extmail ,
要仔细核对配置;2.vi /etc/postfix/main.cf 中
mynetworks = 127.0.0.0/8 ,192.168.x.x/24 (加入整个网段);3.vi /etc/authlib/authdaemonrc 中
27行 authmodulelist = "authmysql";
34行:authmondulelistorig = "authmysql" ,
75行中 :DEBUG_LOGIN = 2
root@tmail tmail]# /tmail/postfix/sbin/postfix startpostsuper: fatal: scan_dir_push: open directory defer: Permission deniedpostfix/postfix-script: fatal: Postfix integrity check failed!tail -f /var/log/maillog报如:May&& 4 15:16:10 tmail postfix/postsuper[2323]: fatal: scan_dir_push: open directory defer: Permission deniedMay&& 4 15:16:11 tmail postfix/postfix-script[2324]: fatal: Postfix integrity check failed!
chmod -R postfix:root&&&&&&&&&&&& /tmail/postfix/spool/.chown postfix:postdrop&&&&&&&&& /tmail/postfix/spool/maildropchown postfix:postdrop&&&&&&&&& /tmail/postfix/spool/publicchmod g+s&&&&&&&&&&&&&&&&&&&&&&&&&& /tmail/postfix/sbin/postdropchmod g+s&&&&&&&&&&&&&&&&&&&&&&&&& /tmail/postfix/sbin/postqueue
&没有收信&Jun 12 17:22:06 mail postfix/smtpd[14995]: connect from localhost.localdomain[127.0.0.1]Jun 12 17:22:06 mail postfix/smtpd[14995]: F: client=localhost.localdomain[127.0.0.1]Jun 12 17:22:06 mail postfix/cleanup[14998]: F: message-id=&&Jun 12 17:22:06 mail postfix/qmgr[13827]: F: from=&&, size=603, nrcpt=1 (queue active)Jun 12 17:22:06 mail postfix/smtpd[14995]: disconnect from localhost.localdomain[127.0.0.1]Jun 12 17:22:06 mail postfix/smtp[14999]: F: to=&&, relay=none, delay=0.1, delays=0.06/0.04/0/0, dsn=5.4.6, status=bounced (mail
loops back to myself)Jun 12 17:22:06 mail postfix/cleanup[14998]: D8EB1456396: message-id=&&Jun 12 17:22:06 mail postfix/qmgr[13827]: D8EB1456396: from=&&, size=2391, nrcpt=1 (queue active)Jun 12 17:22:06 mail postfix/bounce[15001]: F: sender non-delivery notification: D8EB1456396Jun 12 17:22:06 mail postfix/qmgr[13827]: F: removedJun 12 17:22:06 mail postfix/smtp[14999]: D8EB1456396: to=&&, relay=none, delay=0.01, delays=0/0/0/0, dsn=5.4.6, status=bounced (mail
loops back to myself)Jun 12 17:22:06 mail postfix/qmgr[13827]: D8EB1456396: removed
&=========================================================
如果还是显示内部服务器错误,apache的error_log还提示:suexec policy violation: see suexec log for more detailsPremature end of script headers: index.cgi提示查看su日志:----------------------------------关于suexec的FAQ1.出现以下错误&& command not in docroot编译的时候加入--with-suexec-docroot&&&& 以后虚拟主机运行suexec的目录必须包含指定的目录里,通过suexec -V 可以察看docroot目录是哪儿
2.出现以下错误&& user mismatch (daemon instead of www)编译的时候加入--with-suexec-caller=daemon&& 默认是www,但一般apache的运行用户是nobody或者daemon,这里我们是httpd2.2.2,用户是daemon,所以指定这个参数,否则suexec不能被运行。
3.出现以下错误&& cannot run as forbidden uid (1001/index.cgi)在虚拟主机配置SuexecUserGroup时,指定的用户和组,必须高于--with-suexec-uidmin --with-suexec-gidmin 指定的用户uid和gid,否则被限制使用。------------------------------------------------编译Apache的时候要加上:&& --enable-suexec \&&&&&&&&&&&&&&&&&&&&&&& --with-suexec-caller=daemon \&& --with-suexec-docroot=/var/www/extsuite/
临时用postfix,再去su:
5,又提示:DBI connect('database=host=mysql_socket=/var/lib/mysql/mysql.sock','extmail',...)failed: Can't connect to local MySQL server
vi /var/www/extsuite/extmail/webmail.cf改:SYS_MYSQL_SOCKET = /tmp/mysql.sockvi /var/www/extsuite/extman/webman.cf (同上)(再打开ok)
6,Can't open /tmp/extman//sid_94462c48dcd98b655843, No such file or directory mkdir /tmp/extmanchown -R postfix:postfix /tmp/extman
7,进入extman无法显示校验码图片:tail -f error_logBEGIN failed--compilation aborted at /var/www/extsuite/extman/libs/Ext/GD.pm line 14
perl Makefile.PL提示gd装在哪/usr/local/gd2/lib(选图片支持)
Where is libgd installed? [/usr/lib] /usr/local/gd2
Build JPEG support? [y] yBuild PNG support? [y] yBuild FreeType support? [y] yBuild GIF support? [y] yBuild support for animated GIFs? [y] yBuild XPM support? [y] n
makemake install错误:cannot find -lpngln -vs /usr/local/libpng2/lib/* /usr/lib错误:cannot find -lfreetypeln -vs /usr/local/freetype2/lib/* /usr/lib错误:cannot find -ljpegln -vs /usr/local/jpeg6/lib/* /usr/lib再重新make cleanperl Makefile.PL (成功)
或是:extman登录不要校验码:在 webman.cf 将 SYS_CAPTCHA_ON=0 即可,要重启 Apache
8,新建两个域,各建帐号测试发信:
测试帐号和密码是否正常:/usr/local/courier-authlib/sbin/authtest
user1变更密码;./authtest -s localhost
user user1
错误FAQ:Can't chdir to /var/.cn/user1/Maildir/, No such file or directory 查看extman的:SYS_MAILDIR_BASE = /var/mailbox配置是否正确,删除域名再重建,在新建用户的时候会自动在/var/mailbox/下创建该用户的域名和邮件目录
登入extmail进行各种发信测试:
发给自己发给同域帐号发给不同域帐号发给163收信用163收信给自己
再使用outlook/foxmail进行如上测试:
----------------------------------通过日志分析发信过程:tail -f /var/log/maillog成功的日志如下:postfix/pickup[2215]: D: uid=255 from=&&postfix/cleanup[3267]: D: message-id=&&postfix/qmgr: D: from=&&, size=515,nrcpt=1 (queue active)postfix/virtual[3271]: D: to=&&, relay=mx.mail.163. ,delay=0.13,delays=0.1/0.02/0.0.01,dsn=2.0.0,status=send (delivered to maildir)postfix/qmgr[2214]: D: removed
发信错误FAQ:
1,不能发送邮件:warning: do not list
in BOTH mydestination and virtual_mailbox_domains明显是指这个域名不在mydestination许可的列表
解决方法:在有多域的服务器上直接把mydestination选项在/etc/postfix/main.cf注释掉:
2,虚拟域不能发送邮件给自己:Sep 28 14:01:10 rohto postfix/local[2377]: 07AC332E69: to=&&, relay=local, delay=0.71, delays=0.41/0.16/0/0.14, dsn=5.1.1, status=bounced (unknown user: "user2")
1)首先确定:extman/webman.cf文件中:SYS_DEFAULT_GID = 2525修改后进入/var/.cn中rm -rf *
2)原来是在main.cf文件中myhostname与mydomain不能一样,要不然虚拟域和main.cf中设的域名一样就会出现问题:(kao)
myhostname = .cnmydomain = .cn修改如下:myhostname = .cnmydomain = .cn
3,两台extmail互发邮件拒绝:Recipient address rejected: Try again, see
(inreply to RCPT TO command)
//接收地址拒绝,再次尝试,查看
上面的解释:您的主机将被greylist临时封锁 (300 秒
这是您第一次发信给收件人,请隔一段时间重试 前后两次发信间隔小于阀值 (300秒)
等待300秒再发送,没有问题。解决办法:修改:/usr/local/slockd/config/whitelist
4,无法向其它服务器发送邮件提示:
Host or domain name not found. Name service error for
type=MX: Host not found, try againmail服务器resolv.conf未设好
5,向163发信提示:
(in reply to end of DATA command)
------------------------------------小技巧:
1,反解不存在的机器将被拦截:smtpd_client_restrictions = reject_unknown_client ( 如果是postfix 2.3或以上,则是reject_unknown_client_hostname)
2,日志分析技巧:
1)postfix日志成功接收到邮件:(交货到邮件目录)cat /var/log/maillog |grep "delivered to maildir"cat /var/log/maillog |grep "delivered to maildir" | egrep -o "(\w+)([@]{1}\w+[.]{1,})(\w+)"
2)取当天日志:cat /var/log/maillog | egrep "`data | awk "`'{print ""$2" "$3""}'`"
3)取指定日期的错误日志:cat /var/log/maill | grep "^Sep\ 25" | egrep "reject|warning|error|fatal|panic" | more
postfix 安装报错整理
阅读(6974)|
用微信&&“扫一扫”
将文章分享到朋友圈。
用易信&&“扫一扫”
将文章分享到朋友圈。
历史上的今天
在LOFTER的更多文章
loftPermalink:'',
id:'fks_',
blogTitle:'在RHEL5.3上安装EXTMAIL邮件系统过程中碰到的问题以及解决方法(加载很慢)',
blogAbstract:'
{elseif x.moveFrom=='iphone'}
{elseif x.moveFrom=='android'}
{elseif x.moveFrom=='mobile'}
${a.selfIntro|escape}{if great260}${suplement}{/if}
{list a as x}
推荐过这篇日志的人:
{list a as x}
{if !!b&&b.length>0}
他们还推荐了:
{list b as y}
转载记录:
{list d as x}
{list a as x}
{list a as x}
{list a as x}
{list a as x}
{if x_index>4}{break}{/if}
${fn2(x.publishTime,'yyyy-MM-dd HH:mm:ss')}
{list a as x}
{if !!(blogDetail.preBlogPermalink)}
{if !!(blogDetail.nextBlogPermalink)}
{list a as x}
{if defined('newslist')&&newslist.length>0}
{list newslist as x}
{if x_index>7}{break}{/if}
{list a as x}
{var first_option =}
{list x.voteDetailList as voteToOption}
{if voteToOption==1}
{if first_option==false},{/if}&&“${b[voteToOption_index]}”&&
{if (x.role!="-1") },“我是${c[x.role]}”&&{/if}
&&&&&&&&${fn1(x.voteTime)}
{if x.userName==''}{/if}
网易公司版权所有&&
{list x.l as y}
{if defined('wl')}
{list wl as x}{/list}新星之战 Battleno不能登入
新星之战 Battleno
更新时间:
下载:163次
平台:Android
宏碁Iconia B1-A71 Tab新星之战 Battleno不能登入
游戏不能登入怎么办?最近有些玩家抱怨游戏不能登入的问题,小编建议遇到这个问题的玩家先检查一下手机的网络设置问题。再者是检查一下手机里游戏的版本是否是最新版本。如果是安装之后从未成功登入过,则应检查下载的安装包与自己的手机机型是否适配,或者重新下载一个安装包。
请选择品牌
请选择机型Iconia B1-A71 Tab
小贴士:建议您想先设置机型,设置后您就直接浏览全部适合您手机的游戏,下载使用更放心。
九游()是手机游戏下载第一门户,提供最新宏碁宏碁Iconia B1-A71 Tab下载、礼包、激活码,最好玩的新星之战 Battleno攻略,欢迎访问与玩家交流。
新星之战是一款界面华丽的策略类的游戏,以未来的太空世界为主要背景,你需要建设自己的城市,培养自己的英雄,发展自己的技能,同时组建自己的军队,并安排自己的作战单位。游戏中一共有三个种族可以选择:人类、外星人和圣灵,人类是的防守比较薄弱,但是拥有强大的火力;外星人拥有极快的攻击速度,但是火力较弱;圣灵拥有强大的防御能力,但是攻击力偏弱。玩家可以在任何时候攻击其他的种族,夺取他们的资源和城市。
安卓 新星之战 游戏背景:
哈利原本是一名科学家,但是在一次实验事故中,他被感染了一种未知生物的DNA。作为星际政府的隔离措施,哈利将会被杀死,不过他很快就逃到了外太空中,并意外的获取了一些技能。在外太空中,哈利建立了自己的军队,现在正联合外星种族,打算报复和侵略地球。哈利的前大学同学,伟大的物理学家尼克博士在这个时候站了出来,研制能够打败外星人的武器系统,同时也要召唤出一种古老的军队——圣灵军团,打算要阻止哈利,保护自己的家园。
点击查看更多
您可能还想关注:
看了新星之战 Battleno不能登入的用户还看了:
关于宏碁Iconia B1-A71 Tab
宏碁集团(acer)创立于1976年,是全球第二大个人电脑品牌,宏碁以性价比优势在2009年以来销量一直占据全球前两名。主要从事自主品牌的笔记本电脑、台式机、液晶显示器、服务器及数字家庭等产品的研发、设计、行销与服务,持续提供全球消费者易用、可靠的资讯产品。 专区提供最新手机游戏免费下载。
Iconia B1-A71 Tab的分辨率为600*1024,是宏碁生产的一款触屏手机。宏碁Iconia B1-A71 Tab手机用户可通过九游下载。Béla Bartók: Erdélyi táncok (Transylvanian Dances), BB 102b - No. 1. Allegretto-Béla Bartók, Béla Bartók: Erdélyi táncok (Transylvanian Dances), BB 102b - No. 1. AllegrettoMP3下载,歌词下载 - 虾米音乐
Loading...
Béla Bartók: Erdélyi táncok (Transylvanian Dances), BB 102b - No. 1. Allegretto
@微博好友,送歌给Ta!
Sorry,此歌曲暂无歌词。
喜欢Béla Bartók: Erdélyi táncok (Transylvanian Dances), BB 102b - No. 1. Allegretto的人们也喜欢...
您需要登录后才可以留言,请用虾米帐号
听Béla Bartók: Erd的人也听
关注虾米:& 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等相关内容。
Express已经升级到4.x,请同时参考文章,
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库的使用。
希望此文对大家有所帮助。
Express已经升级到4.x,请同时参考文章,
转载请注明出处:
程序代码已经上传到github有需要的同学,自行下载。
This entry was posted in
Pingback: ()
Pingback: ()
Pingback: ()
Pingback: ()
Pingback: ()
Pingback: ()
Pingback: ()
Pingback: ()
Designed by

我要回帖

更多关于 realcodec播放器插件 的文章

 

随机推荐