nodejs+mongodb實現(xiàn)登錄注冊功能

一、配置環(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

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容