Node.js创建一个Express服务的方法详解

 更新时间:2020年01月06日 09:12:03   作者:theVicTory  
这篇文章主要介绍了Node.js创建一个Express服务的方法,结合实例形式分析了node.js创建Express服务的具体步骤、实现方法及相关操作技巧,需要的朋友可以参考下

本文实例讲述了Node.js创建一个Express服务的方法。分享给大家供大家参考,具体如下:

1、创建一个HttpServer服务端

在node.js官网下载好node的Windows版本后一路下一步安装好了node,新建一个server.js文件,开始第一个node文件。首先在文件开头需要使用require包含所需要的模块,然后利用http.createServer创建一个server,并执行回调函数。在回调函数内对请求req进行处理,并返回res结果。

利用url的parse方法将req请求中的url转换为json后,得到其中的请求文件名pathname。然后利用fs的readFile方法读取文件,在回掉函数中进行错误判断并设定文件头的状态码以及"Content-Type",之后将文件写入res返回。最后记得在createServer的回掉方法内结束res.end();

在文件最后调用server.listen();一直监听localhost的3000端口。

启动node服务,在文件夹内通过控制台输入:node server.js。打开浏览器的localhost:3000/index.html,通过server.js访问index.html页面内容。  

const http=require('http');
const url=require('url');
const fs=require('fs');
//1、创建server
let server=http.createServer((req,res)=>{
//2、获取网页请求的文件路径
 let pathname=url.parse(req.url).pathname;
//3、利用fs读取文件
 fs.readFile(pathname.substring(1),function (err,data) {
  if (err){             //有错误err,文件未找到,返回状态404
   res.writeHead(404,{
    "Content-Type":"text/html"
   });
  }else{              //否则正常,设定返回状态为200
   res.writeHead(200,{
    "Content-Type":"text/html"
   });   
   res.write(data.toString());  //将找到的文件写入返回
  }
  res.end();           //在函数readFile()内关闭链接
 });
});
//4、让server一直监听localhost的3000端口的请求
server.listen(3000,'localhost');

2、Node请求数据

Node作为服务器有时候还需要请求其他服务器的数据,此时node就成了“客户端”了,通过HTTP的get方法可以对指定的网址接口进行api调用、数据请求,例如:

const http=require('http');
//利用HTTP请求第三方接口服务
http.get('http://www.imooc.com/u/card',(res)=>{
 let data='';
 res.on('data',(temp)=>{        //检测到数据,追加到data中
  data+=temp;
 });
 res.on('end',()=>{          //检测到数据传输结束,控制台输出数据
  console.log(data);
 });
});

在get的回调函数中对res进行处理,如果有数据传输on('data'),则将temp追加到data,如果传输完成on('end'),则进行相关处理。

3、搭建Express框架

①、安装Express

Node安装之后自带npm软件包管理工具,通过npm命令可以获取npm平台上的插件、软件,由于被墙,国内可以使用淘宝镜像进行安装,通过以下命令设置,就可以使用cnpm代替npm了。

npm install -g cnpm --registry=https://registry.npm.taobao.org

通过cnpm全局安装express框架:

cnpm install -g express-generator

安装完成后可以通过express --version来查看express版本。

②、初始化项目

通过express命令来初始化一个服务框架:express server,之后就可以看到生成了一个server文件夹。

其中bin/www.js用于创建一个HTTP的服务器并且启动、监听某个端口,一般不用修改。public文件夹用于存放img、js、css等静态文件,routes文件夹存放路由js文件。view中存放视图文件,默认提供的是用jade类型文件。app.js文件中设置视图及通过app.use()调用相关模块。例如:

//app.js文件内指定根目录
var index = require('./routes/index');
app.use('/', index);
//index.js文件内渲染index页面
router.get('/', function(req, res, next) {
 res.render('index', { title: 'Express' });
}); 

首先在app.js内将网站的根目录指定为routes下的index.js文件,在index.js中调用router.get方法请求view下的视图文件,在回调函数render中渲染index.jade界面,从而当你在浏览器输入localhost:3000时会默认显示view/index.jade页面。

express官方提供.jade文件作为网页默认视图,因此如果需要使用html则需要进行配置:

首先通过cnpm install ejs --save安装ejs插件,然后在app.js文件中view engine setup下进行配置引擎:

之后在views文件夹下删除原有.jade文件,新建你想要展示的index.html文件即可。例如:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>express index</title>
</head>
<body>
  <h1>Express</h1>
  <p>Welcome use express in HTML</p>
</body>
</html>

3、启动Express,在server所在文件夹下执行命令:node bin/www,在浏览器localhost:3000显示为:

希望本文所述对大家node.js程序设计有所帮助。

相关文章

  • 使用node.js中的Buffer类处理二进制数据的方法

    使用node.js中的Buffer类处理二进制数据的方法

    大家应该都知道在客户端JavaScript脚本代码中,对二进制数据并没有提供一个很好的支持。然而,在处理TCP流或文件流时,必须要处理二进制数据。因此,下面通过这篇文章来一起看看利用node.js中的Buffer类处理二进制数据的方法,有需要的朋友们可以参考借鉴。
    2016-11-11
  • 详解nodejs微信公众号开发——1.接入微信公众号

    详解nodejs微信公众号开发——1.接入微信公众号

    本篇文章主要介绍了详解nodejs微信公众号开发——1.接入微信公众号,非常具有实用价值,需要的朋友可以参考下
    2017-04-04
  • node 文件上传接口的转发的实现

    node 文件上传接口的转发的实现

    这篇文章主要介绍了node 文件上传接口的转发的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-09-09
  • Express使用html模板的详细代码

    Express使用html模板的详细代码

    本篇文章主要介绍了Express使用html模板的详细代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-09-09
  • Node.js EventEmmitter事件监听器用法实例分析

    Node.js EventEmmitter事件监听器用法实例分析

    这篇文章主要介绍了Node.js EventEmmitter事件监听器用法,结合实例形式分析了EventEmmitter事件监听器相关函数与使用技巧,需要的朋友可以参考下
    2019-01-01
  • 基于Nodejs的Tcp封包和解包的理解

    基于Nodejs的Tcp封包和解包的理解

    这篇文章主要介绍了基于Nodejs的Tcp封包和解包的理解,详细的介绍了tcp的分包与拆包并实现,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-09-09
  • 利用node+koa+axios实现图片上传和回显功能

    利用node+koa+axios实现图片上传和回显功能

    这篇文章为大家详细介绍了如何利用node+koa+axios实现图片上传和回显功能,主要实现简单的图片上传和静态内容的访问,感兴趣的可以了解一下
    2022-05-05
  • NodeJS之优缺点及适用场景讨论

    NodeJS之优缺点及适用场景讨论

    这篇文章主要介绍了NodeJS之优缺点及适用场景讨论,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • 如何设置process.env.NODE_ENV生产环境模式

    如何设置process.env.NODE_ENV生产环境模式

    process.env.NODE_ENV默认只有两种状态即development和production,本文主要介绍了process.env.NODE_ENV设置生产环境模式,感兴趣的可以了解一下
    2021-09-09
  • node.js+express留言板功能实现示例

    node.js+express留言板功能实现示例

    本文介绍基于nodejs+express+art-template的留言板功能。包含列表界面、添加界面和发送留言功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09

最新评论