使用 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获取本机内网和外网ip地址的实现代码
Jun 01 NodeJs
初始Nodejs
Nov 08 NodeJs
快速掌握Node.js之Window下配置NodeJs环境
Mar 21 NodeJs
详解nodejs中的process进程
Mar 19 NodeJs
NodeJS自定义模块写法(详解)
Jun 27 NodeJs
详解IWinter 一个路由转控制器的 Nodejs 库
Nov 15 NodeJs
nodejs 简单实现动态html的方法
May 12 NodeJs
详解Nodejs内存治理
May 13 NodeJs
详解nodejs 配置文件处理方案
Jan 02 NodeJs
NodeJs 实现简单WebSocket即时通讯的示例代码
Aug 05 NodeJs
linux 下以二进制的方式安装 nodejs
Feb 12 NodeJs
nodejs利用readline提示输入内容实例代码
Jul 15 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
我的论坛源代码(二)
2006/10/09 PHP
浅谈php serialize()与unserialize()的用法
2013/06/05 PHP
PHP实现多图片上传类实例
2014/07/26 PHP
ThinkPHP模板输出display用法分析
2014/11/26 PHP
Linux系统下PHP-FPM的安装和配置教程
2015/08/17 PHP
PHP判断字符串长度的两种方法很实用
2015/09/22 PHP
jQuery之按钮组件的深入解析
2013/06/19 Javascript
在JavaScript中处理时间之getHours()方法的使用
2015/06/10 Javascript
js获取及修改网页背景色和字体色的方法
2015/12/29 Javascript
jquery中用jsonp实现搜索框功能
2016/10/18 Javascript
js实现按座位号抽奖
2017/04/05 Javascript
JavaScript简单拖拽效果(1)
2017/05/17 Javascript
67 个节约开发时间的前端开发者的工具、库和资源
2017/09/12 Javascript
详解在Vue中有条件地使用CSS类
2017/09/30 Javascript
详解webpack require.ensure与require AMD的区别
2017/12/13 Javascript
vue实现简单loading进度条
2018/06/06 Javascript
js动态设置select下拉菜单的默认选中项实例
2018/08/21 Javascript
使用mpvue搭建一个初始小程序及项目配置方法
2018/12/03 Javascript
Vue基础配置讲解
2019/11/29 Javascript
微信小程序学习总结(二)样式、属性、模板操作分析
2020/06/04 Javascript
用TensorFlow实现多类支持向量机的示例代码
2018/04/28 Python
Python字典循环添加一键多值的用法实例
2019/01/20 Python
12个步骤教你理解Python装饰器
2019/07/01 Python
六种酷炫Python运行进度条效果的实现代码
2020/07/17 Python
详解python命令提示符窗口下如何运行python脚本
2020/09/11 Python
Python实现区域填充的示例代码
2021/02/03 Python
数控机械专业个人的自我评价
2014/01/02 职场文书
简历中的自我评价怎么写
2014/01/29 职场文书
总会计师岗位职责
2014/02/19 职场文书
《吃水不忘挖井人》教学反思
2014/04/15 职场文书
医院反腐倡廉演讲稿
2014/09/16 职场文书
学生自我鉴定格式及范文
2014/09/16 职场文书
辩护词格式
2015/05/22 职场文书
新学期感想
2015/08/10 职场文书
一小时迅速入门Mybatis之bind与多数据源支持 Java API
2021/09/15 Javascript
本地搭建minio文件服务器(使用bat脚本启动)的方法
2022/07/15 Servers