nodejs写接口- 初探

转载自文章配置node服务器环境

首先需要基础环境nodejs的全局安装:可通过(https://nodejs.org/en/download/)安装,安装过程基本是全程"NEXT"就ok了
安装完成后可在控制台(win+R输入cmd进入)测试是否已安装成功(node -v)
新版的nodejs已经集成了npm,所以npm也一并安装好了,可以在cmd命令行输入"npm -v"来测试是否成功安装。
0 在目录下:“npm init” 初始化nodejs项目,生成package.json文件

  1. 通过CMD cd到自定义目录(放后台数据库表和数据库链接,以及API接口等)下 : npm install express
    安装express框架
  1. 在自定义文件夹中创建index.js文件
var express = require('express');//引入express模块
var app = express();


//定义方法
app.get('/',function(req,res){
    res.send('HellowWorld')
});

//定义端口,此处所用为3000端口,可自行更改
var server = app.listen(3000,function(){
    var host = server.address().address;
    var port = server.address().port;

    console.log('Example app listening at http://%s:%s',host,port);
})
  1. 可在‘Postman’中进行数据尝试,验证是否代码成功运行
    1)在控制台页面 node index 运行index.js
    2)显示“Example app listening at http://:::3000”则成功开启3000端口
    3)Postman中选用GET方法 输入“localhost:3000/”,若显示“HellowWorld”则成功
  1. 在CMD下继续安装 body-parser模块,命令npm install body-parser --save
    (注:post请求要借助body-parser模块。使用后,将可以用req.body得到参数)
//引入  bodyParser 方法
const bodyParser = require('body-parser');

//post 参数解析
//parse application/x-www-form-urlencoded
app.use(bodyParser.urlencoded({extended:false}))

//parse application/json
app.use(bodyParser.json())

//定义方法
app.get('/',function(req,res){
    res.send('HellowWorld')
});


app.post('/post',function(req,res){
    console.log(req.body);
    res.send('HellowWorld')
});
  1. 定义静态资源路径文件夹(在index.js同级目录下创建一个static的放置静态资源的目录)
//定义静态资源路径文件夹
 app.use('/static',express.static('./static'));
  1. 路由的分发:定义路由后GET和POST方法全部放在路由里所以在index.js中声明路由并引用
var express = require('express');//引入express模块
var app = express();

//引入  bodyParser 方法
const bodyParser = require('body-parser');

//post 参数解析
//parse application/x-www-form-urlencoded
app.use(bodyParser.urlencoded({extended:false}))

//parse application/json
app.use(bodyParser.json())

//路由相关
 const home = require('./router/home');//定义路由
 app.use('/home',home)//使用路由

//定义静态资源路径文件夹
 app.use('/static',express.static('./static'));

//定义方法
// app.get('/',function(req,res){
//  res.send('HellowWorld')
// });

// app.post('/post',function(req,res){
//  console.log(req.body);
//  res.send('HellowWorld')
// });

//定义端口口,此处所用为3000端口,可自行更改
var server = app.listen(3000,function(){
    var host = server.address().address;
    var port = server.address().port;

    console.log('Example app listening at http://%s:%s',host,port);
})

路由页面home.js页面(在index.js的同级router文件夹下),作用:放置“方法”

测试是否路由分发成功

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

router.use((req,res,next)=>{
    next()
})

router.get('/classic/lastest',(req,res)=>{
    let result={
        err:0,
        msg:'ok',
        data:{
            "name":"wangyi",
            "age":"99",
            "type":"man",
            "title":"pi"
        }
    }
    res.send(result)
})

router.post('/',(req,res)=>{
    res.send(req.body)
})
module.exports=router;

关于所用软件: Sublime Text 3和Postman说明
Sublime Text 3(为付费软件,但可免费使用):http://www.sublimetext.com/3可在官网下载
Postman:https://www.getpostman.com/可在此处下载
关于API接口实例:https://download.csdn.net/download/qq_42275455/10657352可在此处下载,或者留言联系本人

注:!!!
顺序很重要!!!
顺序很重要!!!
顺序很重要!!!
重要的事说三遍
配置路由要放置在配置方法下
只有加载完所有方法在进入路由分发

app.use(bodyParser.urlencoded({extended:false}))
app.use(bodyParser.json())
//路由相关
 const home = require('./router/home');
 app.use('/home',home)

作者:命名不规范者
来源:CSDN
原文:https://blog.csdn.net/qq_42275455/article/details/82690854
版权声明:本文为博主原创文章,转载请附上博文链接!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,907评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,987评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,298评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,586评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,633评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,488评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,275评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,176评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,619评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,819评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,932评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,655评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,265评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,871评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,994评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,095评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,884评论 2 354

推荐阅读更多精彩内容