一直以来,我都是用PHP写一些后端的代码,在不断变换PHP与JS语法的过程中,常常把自己弄得晕头转向,又想到JavaScript马上要统治世界了,于是就入坑Node.js。
安装node.js
环境是Mac OSX 10.11.6
brew install node
运行node -v
,出现版本号v7.1.0,说明安装成功
安装依赖包
npm install express mongoose
一个简单的返回JSON的demo
var express = require('express');
var app = express();
app.listen(3000);
app.get('/', function (req, res) {
var data = {'name': 'huangxj'};
res.writeHead(200, { "Content-Type": "application/json;charset=utf-8" });
res.end(JSON.stringify(data));
console.log('hello' + req.name);
});
这里,我犯一个错误,忘记写上app.listen(3000);
,导致没有启动成功。
加上listen,再访问localhost:3000,输出
{
"name": "huangxj"
}
测试通过。
疑问 res.end与res.send同样能够输出,有什么区别?
解惑:网上关于它们的文章有很多,经过我的实验,它们的其中有一个区别是res.send不必设定header,默认便是application/json;还存在一个相近方法,res.json,它接受一个json对象作为参数,输出的header默认也是是application/json。
使用nodemon运行让服务自动重启
npm install -g nodemon
果断改用nodemon app.js
运行,同样可以做到修改了文件让程序自动刷新,就像PHP那样的热部署
>nodemon app.js
[nodemon] 1.11.0
[nodemon] to restart at any time, enter `rs`
[nodemon] watching: *.*
[nodemon] starting `node app.js`
[nodemon] restarting due to changes...
添加一条商品信息
商品包含一个标题与价格
1、创建Schema文件
/* schema/goods.js */
var mongoose = require('mongoose');
var GoodsSchema = new mongoose.Schema({
title: String,
price: Number
});
module.exports = GoodsSchema
2、创建Model
/* model/goods.js */
var mongoose = require('mongoose');
var GoodsSchema = require('../schema/goods')
var Goods = mongoose.model('Goods', GoodsSchema)
module.exports = Goods
3、Schema/Model建立好后,试图添加一条数据
app.post('/goods/add', function (request, response) {
// response.end('hello, world, Jay');
// 保存数据
var goods = new Goods({
title: 'iPhone 7',
price: 5888
});
goods.save(function (err) {
if (err) {console.log(err)}
});
})
于是就开启了一路寻bug之旅
1)运行nodemon app.js
报了如下的错误,大意是数据库连接失败
MongoError: failed to connect to server [localhost:27017] on first connect [MongoError: connect ECONNREFUSED 127.0.0.1:27017]
at Pool.<anonymous> (/Users/huangxiujie/Documents/Node/lendoo-node/node_modules/.2.1.11@mongodb-core/lib/topologies/server.js:328:35)
2)在Terminal中运行mongo
,告知连接被拒
MongoDB shell version v3.4.2
connecting to: mongodb://127.0.0.1:27017
2017-07-03T16:58:34.658+0800 W NETWORK [thread1] Failed to connect to 127.0.0.1:27017, in(checking socket for error after poll), reason: Connection refused
2017-07-03T16:58:34.658+0800 E QUERY [thread1] Error: couldn't connect to server 127.0.0.1:27017, connection attempt failed :
connect@src/mongo/shell/mongo.js:237:13
以管理员身份sudo登录运行,依然无效
3)尝试手工建立数据库目录
在~目录下建立一个database
mongod --dbpath ~/database
,带参运行mongo就能成功启动了。
4)接着运行mongo
通过命令行查看当前的数据库
> show dbs
admin 0.000GB
local 0.000GB
>
5)到此已经连接上mongo了,运行最初的插入数据Goods信息,成功了
>use lendoo
>db.goods.find()
{ "_id" : ObjectId("595a0abd3a255a0f11ac1464"), "__v" : 0 }
{ "_id" : ObjectId("595a0abd3a255a0f11ac1465"), "__v" : 0 }
貌似添加成功了,细看发现title与price没写入
通过检查,发现忘了导出Schema了
在schema/goods.js末尾添加如下代码解决
module.exports = GoodsSchema
这回再访问localhost:3000/goods/add
查看结果,一切正常
> db.goods.find()
{ "_id" : ObjectId("595a0abd3a255a0f11ac1464"), "__v" : 0 }
{ "_id" : ObjectId("595a0d1d00f9a40f7595b7ef"), "title" : "iPhone 7", "price" : 5888, "__v" : 0 }
最后,附上app.js代码
// app.js
var express = require('express');
var app = express();
// var bodyParser = require('body-parser');
// app.set('port', 3000);
var mongoose = require('mongoose')
var Goods = require('./model/goods')
mongoose.connect('mongodb://localhost/lendoo');
app.listen(3000);
// get index
app.get('/', function (req, res) {
var data = {'name': 'huangxj'};
// res.writeHead(200, { "Content-Type": "application/json;charset=utf-8" });
// res.end();
res.json(data);
res.end(JSON.stringify(data));
// return;
console.log('hello node');
});
// post insert
app.post('/goods/add', function (request, response) {
// response.end('hello, world, Jay');
// 保存数据
var goods = new Goods({
title: 'iPhone 7',
price: 5888
});
goods.save(function (err) {
if (err) {console.log(err)}
});
})