一、配置環(huán)境
1、WebStorm安裝
下載地址:https://www.jetbrains.com/webstorm/
激活地址:http://idea.lanyus.com/
獲得注冊碼,注冊碼激活前務(wù)必將“0.0.0.0 account.jetbrains.com”添加到hosts文件中
//gg 跳到文件第一行
//Shift + g 跳到文件最后一行
$ vim /etc/hosts
2、NodeJS安裝
下載地址:https://nodejs.org/en/
安裝完成后執(zhí)行下面的命令,顯示版本號,則安裝成功
$ node -v
3、MongoDB安裝
1、安裝MongoDB
下載MongoDB:https://www.mongodb.com/download-center?jmp=nav#community
進(jìn)入下載目錄
$ cd ~/Downloads
解壓文件
$ tar -zxvf mongodb-osx-ssl-x86_64-3.6.5.tgz
將解壓完的文件移動到想要的目錄
$ mv -n ~/Downloads/mongodb-osx-ssl-x86_64-3.6.5 ~/Applications/mongodb/
將MongoDB目錄寫入配置文件,在~./bashrc或~/.bash_profile中加入下面一行
$ vim ~./bash_profile
將下面一行加入配置文件中
export PATH=<mongodb-install-directory>/bin:$PATH
將<mongodb-install-directory>替換為MongoDB的安裝目錄
2、啟動MongoDB
1、使用默認(rèn)/data/db文件夾(需要有讀寫權(quán)限)
$ sudo mkdir -p /data/db
啟動MongoDB
$ mongod
2、將指定文件夾作為數(shù)據(jù)文件夾
$ mongod --dbpath <path to data directory>
啟動成功,在Terminal看到如下提示:
[initandlisten] waiting for connections on port 27017
另開一個Terminal窗口,啟動客戶端
$ mongo
在Terminal看到如下提示,啟動成功
MongoDB shell version v3.6.4
connecting to: mongodb://127.0.0.1:27017
MongoDB server version: 3.6.4
Server has startup warnings:
2018-06-22T17:59:07.520+0800 I CONTROL [initandlisten]
2018-06-22T17:59:07.521+0800 I CONTROL [initandlisten] ** WARNING: Access control is not enabled for the database.
2018-06-22T17:59:07.521+0800 I CONTROL [initandlisten] ** Read and write access to data and configuration is unrestricted.
2018-06-22T17:59:07.521+0800 I CONTROL [initandlisten] ** WARNING: You are running this process as the root user, which is not recommended.
2018-06-22T17:59:07.521+0800 I CONTROL [initandlisten]
2018-06-22T17:59:07.521+0800 I CONTROL [initandlisten] ** WARNING: This server is bound to localhost.
2018-06-22T17:59:07.521+0800 I CONTROL [initandlisten] ** Remote systems will be unable to connect to this server.
2018-06-22T17:59:07.521+0800 I CONTROL [initandlisten] ** Start the server with --bind_ip <address> to specify which IP
2018-06-22T17:59:07.521+0800 I CONTROL [initandlisten] ** addresses it should serve responses from, or with --bind_ip_all to
2018-06-22T17:59:07.521+0800 I CONTROL [initandlisten] ** bind to all interfaces. If this behavior is desired, start the
2018-06-22T17:59:07.521+0800 I CONTROL [initandlisten] ** server with --bind_ip 127.0.0.1 to disable this warning.
2018-06-22T17:59:07.521+0800 I CONTROL [initandlisten]
2018-06-22T17:59:07.521+0800 I CONTROL [initandlisten]
2018-06-22T17:59:07.521+0800 I CONTROL [initandlisten] ** WARNING: soft rlimits too low. Number of files is 256, should be at least 1000
>
通過瀏覽器訪問http://127.0.0.1:27017/
It looks like you are trying to access MongoDB over HTTP on the native driver port.
參考文章
Mac OS X 用 MongoDB 安裝包進(jìn)行手工安裝
Install MongoDB Community Edition on macOS
二、構(gòu)建項目
1、快速構(gòu)建項目
通過Express 應(yīng)用生成器可以快速創(chuàng)建一個應(yīng)用的骨架。
通過如下命令安裝:
$ npm install express-generator -g
創(chuàng)建一個testapp項目
$ express testapp
$ cd testapp
$ npm install
$ DEBUG=testapp npm start
在瀏覽器中打開 http://localhost:3000/ 網(wǎng)址就可以看到這個應(yīng)用了。
2、實現(xiàn)一個簡單的登錄注冊功能
Mongoose
- MongoDB是一個對象數(shù)據(jù)庫,是用來存儲數(shù)據(jù)的;存儲的數(shù)據(jù)格式為JSON。
- Mongoose是封裝了MongoDB操作(增刪改查等)的一個對象模型庫,是用來操作這些數(shù)據(jù)的。
安裝mongoose
$ npm install mongoose
在項目根目錄下新建/models/index.js,testapp就是我們要連接的數(shù)據(jù)庫。
var mongoose = require('mongoose');
var testDB = "mongodb://localhost:27017/testapp";
mongoose.connect(testDB, function (err) {
if (err) {
console.log('connect fail');
} else {
console.log('connect success');
}
});
module.exports = mongoose;
在models新建一個user.js,新建一個用戶Schema。
var mongoose = require("./index");
var Schema = mongoose.Schema;
var UserSchema = new Schema({
name: {type: String},
mobile: {type: String},
pwd: {type: String}
});
module.exports = mongoose.model('User', UserSchema);
在項目根目錄下新建/api/user.js,實現(xiàn)注冊和登錄功能。當(dāng)注冊添加數(shù)據(jù)時如果users表已經(jīng)存在,則會保存到表中,如果不存在,則會創(chuàng)建users表,然后再保存數(shù)據(jù)。
var User = require('../models/user');
module.exports.userReg = function (req, res, next) {
var mobile = req.body.mobile;
var regUser = new User({
mobile: req.body.mobile,
pwd: req.body.pwd,
name: req.body.name
});
regUser.save(function (err, content) {
if (err) {
return res.send({status: 0, msg: err || '注冊失敗'});
} else {
return res.send({status: 1, msg: "注冊成功"});
}
})
};
module.exports.userLogin = function (req, res, next) {
var userMobile = req.body.mobile;
var userPwd = req.body.pwd;
User.findOne({mobile: userMobile}, function (err, content) {
if (err) {
return res.send({status: 0, msg: err || '登錄失敗'});
} else {
var pwd = content.pwd;
if (pwd === userPwd) {
var userData = {"user_id": content._id,
"name": content.name,
"mobile": content.mobile};
return res.send({status: 1, msg: "登錄成功", data: userData});
} else {
return res.send({status: 1, msg: "登錄失敗,密碼錯誤"});
}
}
});
};
在routes新建user.js。
var express = require('express');
var router = express.Router();
var User = require("../api/user");
router.post('/register', User.userReg);
router.post('/login', User.userLogin);
module.exports = router;
在app.js中新增router。
var indexRouter = require('./routes/index');
var usersRouter = require('./routes/users');
var testRouter = require('./routes/user');
var app = express();
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);
});
// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');
app.use(logger('dev'));
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));
app.use('/', indexRouter);
app.use('/users', usersRouter);
app.use('/user', testRouter);
啟動數(shù)據(jù)庫,然后運行當(dāng)前項目。
通過訪問http://localhost:3000/user/register進(jìn)行注冊;http://localhost:3000/user/login進(jìn)行登錄。
項目GitHub地址:https://github.com/hornet1990/node-test