使用 NodeJS+Express 开发服务端的简单介绍


Posted in NodeJs onApril 07, 2017

随着NodeJS的发展,现在已经被很多人熟知,NodeJS已经成为了前端开发人员必备的技能。本文不会对NodeJS过多介绍 如果你感兴趣可以访问NodeJS 官网

本文是利用NodeJS+Express开发一个服务器程序,Express 是一种保持最低程度规模的灵活 Node.js Web 应用程序框架,为 Web 和移动应用程序提供一组强大的功能。详见:官网

一 准备工作

首先你需要安装NodeJS环境 这里不再做介绍,

1.安装Express

npm install express -g
npm install express-generator -g

2.初始化项目

cd /Users/SPRINT/Desktop 进入桌面
express 项目名称

项目名称我们指定为APIServer,从项目名称可以看出 我们是模拟服务器API

在这里我们将提供一个获取用户详情接口 并输出JSON数据。

使用 NodeJS+Express 开发服务端的简单介绍

在终端最后位置 看到输出两个命令

install dependencies:
 $ cd APIServer && npm install //告诉我们进入项目根目录 执行npm install安装依赖模块

run the app:
 $ DEBUG=APIServer:* npm start //告诉我们启动服务器

执行如下命令:

1.cd APIServer //进入项目根目录

2.npm install  //安装依赖

我们回到桌面 你将看到一个APIServer目录 我在这里使用Sublime Text打开

使用 NodeJS+Express 开发服务端的简单介绍

/bin:用来启动应用(服务器)

/public: 存放静态资源目录

/routes:路由用于确定应用程序如何响应对特定端点的客户机请求,包含一个 URI(或路径)和一个特定的 HTTP 请求方法(GET、POST 等)。每个路由可以具有一个或多个处理程序函数,这些函数在路由匹配时执行。

/views: 模板文件所在目录 文件格式为.jade

目录app.js程序main文件 这个是服务器启动的入口

二 启动服务器

首先启动服务器

npm start //启动服务器

使用 NodeJS+Express 开发服务端的简单介绍

启动完成后终端将输出 node ./bin/www

在浏览器中访问 http://localhost:3000/

使用 NodeJS+Express 开发服务端的简单介绍

三 基本使用

打开app.js 这里介绍下主要代码

var express = require('express');
 var path = require('path');
 var favicon = require('serve-favicon');
 var logger = require('morgan');
 var cookieParser = require('cookie-parser');
 var bodyParser = require('body-parser');

 var app = express();


///=======路由信息 (接口地址)开始 存放在./routes目录下===========//
 var routes = require('./routes/index');//home page接口
 var users = require('./routes/users'); //用户接口

 app.use('/', routes); //在app中注册routes该接口 
 app.use('/users', users);//在app中注册users接口
///=======路由信息 (接口地址 介绍===========//



///=======模板 开始===========//
// view engine setup
 app.set('views', path.join(__dirname, 'views'));
 app.set('view engine', 'jade');
///=======模板 结束===========//

当我们在浏览器中 访问 http://localhost:3000/ 调用的就是index中的接口

我们打开index.js就可以看到该接口的定义:

var express = require('express');
var router = express.Router();


//定义一个get请求 path为根目录
/* GET home page. */
router.get('/', function(req, res, next) {
 res.render('index', { title: 'Express' });
});

module.exports = router;

定义一个路由的基本格式为:

app.METHOD(PATH, HANDLER)

其中:

app 是 express 的实例。

METHOD是 HTTP 请求方法。

PATH 是服务器上的路径。

HANDLER 是在路由匹配时执行的函数。

以上的定义代表
在根路由 (/) 上(应用程序的主页)对 GET 请求进行响应:

是不是明白了?

如果我们想要实现一个获取用户信息接口该怎么写呢?

很简单在 routes目录下创建一个user.js文件内容如下:

定义一个User模型

function User() {
  this.name;
  this.city;
  this.age;
}
module.exports = User;

使用 NodeJS+Express 开发服务端的简单介绍

切换到users.js文件

在文件顶部添加

var URL = require('url');

并继续添加如下内容:

router.get('/getUserInfo', function(req, res, next) {

 var user = new User();
 var params = URL.parse(req.url, true).query;

 if(params.id == '1') {

 user.name = "ligh";
 user.age = "1";
 user.city = "北京市";

}else{ 
 user.name = "SPTING";
 user.age = "1";
 user.city = "杭州市";
}

 var response = {status:1,data:user};
 res.send(JSON.stringify(response));

});

解释下重点:

获取url参数 依赖于url模块 使用前需要使用  require('url')

var params = URL.parse(req.url, true).query;

使用 NodeJS+Express 开发服务端的简单介绍

由于users.js路由信息已经在app.js注册

停止服务器 重新start服务器即可直接访问

调用方式

http://localhost:3000/users/getUserInfo?id=1
或者
http://localhost:3000/users/getUserInfo?id=2

使用 NodeJS+Express 开发服务端的简单介绍

你是不是注意到我们访问的方式为users/getUserInfo?id=1 而不是基于根

原因是我们在app.js注册方式为app.use('/users', users);

我们可以利用这种方式 开发模块功能 比如 你有另外一个模块为msg

我们注册为:app.use('/msgs', msgs);

调用方式为http://localhost:3000/msgs/getUserMsgs?id=1

这里我们写死了返回数据 并没有查询数据库

当然NodeJS具备访问mysql的能力 但不是本篇文章的介绍范围,可以参考此篇文章:https://3water.com/article/110616.htm

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

NodeJs 相关文章推荐
NodeJs中的非阻塞方法介绍
Jun 05 NodeJs
nodejs的require模块(文件模块/核心模块)及路径介绍
Jan 14 NodeJs
我的NodeJs学习小结(一)
Jul 06 NodeJs
Nodejs进阶:基于express+multer的文件上传实例
Nov 21 NodeJs
nodejs服务搭建教程 nodejs访问本地站点文件
Apr 07 NodeJs
nodejs批量下载图片的实现方法
May 19 NodeJs
CentOS 安装NodeJS V8.0.0的方法
Jun 15 NodeJs
详解Nodejs 通过 fs.createWriteStream 保存文件
Oct 10 NodeJs
nodejs微信扫码支付功能实现
Feb 17 NodeJs
nodejs中内置模块fs,path常见的用法说明
Nov 07 NodeJs
NodeJS模块Buffer原理及使用方法解析
Nov 11 NodeJs
初识NodeJS服务端开发入门(Express+MySQL)
Apr 07 #NodeJs
nodejs服务搭建教程 nodejs访问本地站点文件
Apr 07 #NodeJs
nodejs爬虫遇到的乱码问题汇总
Apr 07 #NodeJs
详解nodejs爬虫程序解决gbk等中文编码问题
Apr 06 #NodeJs
NodeJS基础API搭建服务器详细过程记录
Apr 01 #NodeJs
Ajax异步文件上传与NodeJS express服务端处理
Apr 01 #NodeJs
3分钟快速搭建nodejs本地服务器方法运行测试html/js
Apr 01 #NodeJs
You might like
php中sprintf与printf函数用法区别解析
2014/02/17 PHP
php中get_cfg_var()和ini_get()的用法及区别
2015/03/04 PHP
PHP数组操作――获取数组最后一个值的方法
2015/04/14 PHP
浅谈PHP中output_buffering
2015/07/13 PHP
phpStudy访问速度慢和启动失败的解决办法
2015/11/19 PHP
JS Array对象入门分析
2008/10/30 Javascript
js内置对象 学习笔记
2011/08/01 Javascript
JQuery页面的表格数据的增加与分页的实现
2013/12/10 Javascript
Javascript保存网页为图片借助于html2canvas库实现
2014/09/05 Javascript
jquery插件corner实现圆角边框的方法
2015/03/09 Javascript
jQuery插件EnPlaceholder实现输入框提示文字
2015/06/05 Javascript
JavaScript 性能优化小结
2015/10/12 Javascript
js读取并解析JSON类型数据的方法
2015/11/14 Javascript
JS实现把鼠标放到链接上出现滚动文字的方法
2016/04/06 Javascript
Javascript中apply、call、bind的巧妙使用
2016/08/18 Javascript
jquery操作ul的一些操作笔记整理(干货)
2017/08/31 jQuery
JavaScript判断变量名是否存在数组中的实例
2017/12/28 Javascript
Vue 中axios配置实例详解
2018/07/27 Javascript
浏览器事件循环与vue nextTicket的实现
2019/04/16 Javascript
vue+element实现表单校验功能
2019/05/20 Javascript
jquery树形插件zTree高级使用详解
2019/08/16 jQuery
微信小程序 生成携带参数的二维码
2019/10/23 Javascript
详解Python:面向对象编程
2019/04/10 Python
python elasticsearch环境搭建详解
2019/09/02 Python
Django静态文件加载失败解决方案
2020/08/26 Python
Django利用elasticsearch(搜索引擎)实现搜索功能
2020/11/26 Python
德国机场停车位比较和预订网站:Ich-parke-billiger
2018/01/08 全球购物
实习教师自我鉴定
2013/12/09 职场文书
园林资料员岗位职责
2013/12/30 职场文书
小孩百日宴答谢词
2014/01/15 职场文书
七匹狼男装广告词
2014/03/21 职场文书
法定授权委托证明书
2014/09/27 职场文书
2015秋学期开学寄语
2015/05/28 职场文书
详解Apache SkyWalking 告警配置指南
2021/04/22 Servers
pycharm无法安装cv2模块问题
2022/05/20 Python
vue ant design 封装弹窗表单的使用
2022/06/01 Vue.js