代码改变世界

Express4 启航指南

2014-09-24 21:00  聂微东  阅读(32790)  评论(15编辑  收藏  举报

   确实有感而发,Nodejs真的发展太快了,这么说的原因有两点:自己去年冬天买了本《了不起的Node.js》,里面介绍Express的版本还是2.x.x;前些天小伙伴买了本《Node.js实战》,结果依赖的Express是3.x.x。尼玛如果安装目前新版的Express4,那么这些书中的例子连项目都无法正常跑起来。

  Nodejs相关的纸版书一上市就已经过时了!

  

 

  此文的背景是由于俺某天手欠,升级了最新Express V4+后,发现项目不可用了(还好是公司内部的小工具),查找资料后整理了些许总结,介绍如何使用Express4搭建项目。 

  情况差不多就是这样,那么咱们"深入浅出"一把Express项目吧。

 

  

 

  如果看官想了解Express 4之前的安装、使用可查看:http://www.cnblogs.com/Darren_code/p/node_express.html

 

--------------------------- 分割线 ---------------------------

 

目录

  1. 建立工程环境
  2. npm安装细节
  3. 全局模式安装的意义
  4. 创建项目
  5. 目录结构

 

建立工程环境

  先介绍下各种环境吧:

   

 

  进入俺们的项目所在目录:

  cd /home/work/node/project

 

  npm安装express , -g 指令让express进入全局安装:

  $ npm install -g express

 

  如果是express 4.0之前版本,那么执行“express -V”就可以得到版本号了,可express 4.0之后还需要再安装express-generator包,如果没有安装还执行“express -V”命令会报错。

 

  执行安装express-generator包:

  $ npm install -g express-generator

 

  现在执行“$ express -V”可查看express版本信息了。

  

 

  发生这种情况的原因是,express4.0之后把创建一个APP的功能分离出来为express-generator,没它你创建不了应用程序。

 

 

NPM和模块

  以下两张express目录(安装samba,Windows下查看无压力)的图片可以更直观的对比express包的变化,下图左侧是V3.15.0,下图右侧是V4.7.0:

   

 

  目录结构上看就缺少一个bin文件,这个bin目录内存放的就是内部命令(下图),只不过它们都是以独立的文件形式存在的。

  PS:bin是binary的缩写,有关bin和sbin目录的含义需要看官对linux的目录结构有一点点了解,使用Google 百度一下"linux 目录"即可找到对应资料。

  

 

  再从模块信息(node_modules/express/package.json)看它们的重要不同:

  "bin": {
       "express": "./bin/express"
  }

 

  需要注意npm模块中的信息都在package.json里面,包括各种配置信息。

  其中"bin"这个key就是申明用户可以使用“command-name”这个命令,而输入该命令后就会去执行“command-file”这个文件。如下:

  {
       ...
       "bin": {
            "command-name” : “command-file”
       }
       ...
  }

 

  所以在命令行输入express命令时,其实对应的其实是去执行bin目录下的express程序。

  如果自己要制作模块包,且希望可以命令行工具使用时,需要配置好bin字段,当全局模式安装之后就可以在命令行直接执行使用。有关package.json的信息会再配置章节中再详细介绍,"$ npm help json"可以获取官方的详细信息。

 


全局模式安装的意义

  npm安装的时候区分本地模式安装和全局模式安装,“-g”就表示全局模式安装,这种模式会被安装在node安装目录的lib所在目录的node_modules文件夹中,全局使用。

 

  NPM是由Isaac Z.Schlueter创建的,提供给Node服务的Node包管理器,最开始需要独立安装,后来当Nodev0.6.3版本默认集成了NPM作为Node包管理器,所以在那之后,只要使用NPM安装的全局包地址,都可以推算出来。

  如Node在/usr/local/bin/node,那么模块目录就是/usr/local/lib/node_modules/下。

  非全局那么就是本地模式安装,这类模式安装会被安装在当前目录的node_modules文件夹中,非全局使用。

 

  如果express-generator不是全局模式安装怎么办?

  非常不爽的就是命令行工具中直接使用"express [option] [dir]"就没法完成了,只能手动的找到执行文件执行才可以,如本地模式安装的时只能只能在当前目录下执行

  $ ./node_modules/express-generator/bin/express -V
  4.2.0

 

创建项目

  东扯西扯完毕,各方面也已经Ready,创建个Express项目开心一下:)

  再确认一下所在的目录位置

  

 

  express myapp

  

  $ cd myapp && npm install

 

  npm install完成之后就可以run起来咯,执行:

  $ DEBUG=myapp ./bin/www

 

  执行“npm start”其效果一样,下图分别是这两条语句执行情况:

  

  

  PS:红框中的内容是访问时打印的信息。

   

  可以看到俩条命令打印出来的信息有一行不一样,执行完“DEBUG=myapp ./bin/www”后会打印出:“myapp Express server listening on port 8898 +0ms”

 

  让俺们来看看为神马,执行命令:

  $ vi ./bin/www

  

  PS:默认PORT其实3000(红框中的部分),俺手动修改后使用的是8898端口

 

  Express4中引入了著名的debug模块,所以debug模式让我们更方便的玩转Node中的模块,其使用方法介绍起来较长,建议大家看看其官方的介绍:https://www.npmjs.org/package/debug

 

  重要的package.json文件马上会介绍,创建Express4项目俺们就说到这里。

 

目录结构

   了解目录结构是玩转一切项目的第一步:

  

  • app.js,程序启动文件
  • bin,创建项目时已经提到,是真实的执行程序
  • node_modules, 存放所有的项目依赖库
  • package.json,项目依赖配置及开发者信息
  • public,静态文件(css,js,img)
  • routes,路由文件
  • views,页面文件

 

配置文件之神奇的package.json

  在Nodejs项目中,package.json文件用来声明项目基本信息和使用的模块,这样在新的环境部署时,只要在package.json文件所在的目录执行npm install命令即可按照所需要的模块啦。

  下面俺们通过这个package.json文件再Build Express项目玩玩(生命不息折腾不止嘛)。

 

  回到project目录:

  

  在project目录下新加testpackage项目

  $ mkdir testpackage && cd testpackage

  

  把myapp中的package.json copy过来

  $ cp ../myapp/package.json ./

  

  创建个server.js,写入简单的几行代码,运行一把:

  var express =  require('express');                                                                      
  var app = express();                                                                                  
  app.get('/', function(req, res){                                                                      
      res.send('Hello World');                                                                          
  });                                                                                                   
  var server = app.listen(8808, function() {                                                            
      console.log('Listening on port %d', server.address().port);                                       
  }); 
  app.get('/sayhi', function(req, res){                                                                                                                                       
     res.send('狗狗 黑喂狗');                                                                          
  }); 

 

   

  上面俩图就是运行结果。

 

  查看package.json中的内容如下

  

  会议下由package.json实现的快速项目搭建,俺们再来了解其内容意义:

  • name
    ~ 在package.json中最重要的就是name和version字段。他们都是必须的,如果没有就无法install;
    ~ 想好名字之前先去npm registry查看一下这个名字是否已经被使用了,http://registry.npmjs.org/
  • version
    ~ version必须能被 node-semver解析,它被包在npm的依赖中;
    ~ name和version一起组成的标识在假设中是唯一的。改变包应该同时改变version
  • private
    ~ 如果你设置"private": true,npm就不会发布它;
    ~ 这是一个防止意外发布私有库的方式。如果你要确定给定的包是只发布在特定registry(如内部registry)的,用publishConfighash的描述来重写registry的publish-time配置参数
  • scripts
    ~ “scripts”是一个由脚本命令组成的hash对象,他们在包不同的生命周期中被执行。key是生命周期事件,value是要运行的命令。
  • dependencies
    ~ 依赖是给一组包名指定版本范围的一个hash。这个版本范围是一个由一个或多个空格分隔的字符串。依赖还可以用tarball或者git URL

  以上五项仅仅是Express4 package.json使用的,其他细节可参考文档 传送门https://www.npmjs.org/doc/files/package.json.html

 

小结一下

  文章在偏应用的层面上介绍了NPM和模块信息,希望能对大家了解有所帮忙吧。

  8月份的文章补上,俺们下一章再来介绍用Express+mongodb搭建个人网站,保佑老子千万别跳票了...吼吼:)

  

 

  资料