node学习笔记(七)结合mongodb实现用户注册功能

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/kaw19950302/article/details/78905885

一:app.js(server)

const express = require('express');
const router = require('./router.js');

let app = express();

app.use(router);


app.listen(8000,function () {
    console.log('hello 8000')
});

二:router.js(路由)

const express = require('express');
const router = express.Router();
const querystr = require('querystring');
const MongoClient = require('mongodb').MongoClient;

let url = 'mongodb://127.0.0.1:27017';

router.use(express.static('./public'));

router.get('/',function (req,res) {
    res.sendfile('./public/index.html');
});

router.post('/reg',function (req,res) {
    let data= '';
    req.on('data',function (chunk) {
        data+=chunk;
    });
    req.on('end',function () {
        let info = querystr.parse(data);
        MongoClient.connect(url,function (err,client) {
            let db = client.db('app');
            if(err === null){

                db.collection('user').find({"user":info.user}).toArray(function(err,result) {
                //判断数据库app下的user集合中是否存在info文档
                    if(!result[0] == []){
                        res.send("该用户已被注册")
                        //如果有,则打印"该用户已被注册"
                    }else{
                        //如果无,则添加info文档,并打印"注册成功"
                        db.collection('user').insertOne(info,function () {
                            console.log(info)
                        })
                        client.close();
                        res.send('注册成功')
                    }
                })
            }else {
                client.close();
            }
        });

    })
});

module.exports = router;

三:index.html

//注册div
<div id="box1" style="display: none">
    <form action="http://127.0.0.1:8000/reg" method="post">
        <label for="user">用户名:</label>
        <input type="text" id="user1" name="user" value="">
        <br>
        <label for="pwd">密码:</label>
        <input type="password" id="pwd1" name="pwd" value="">
        <br>
        <button id="btn">注册</button>
    </form>
</div>

//注册登录div
<div id="box2">
    <form action="http://127.0.0.1:8000/form" method="post">
        <label for="user">用户名:</label>
        <input type="text" id="user" name="user" value="">
        <br>
        <label for="pwd">密码:</label>
        <input type="password" id="pwd" name="pwd" value="">
        <br>
        <button id="btn_login">登录</button>
    </form>
    <button id="btn_registered">注册</button>
</div>
</body>
<script>
    var registered = document.getElementById('btn_registered');
    var box1 = document.getElementById('box1');
    var box2 = document.getElementById('box2');

    registered.addEventListener('click',function () {
        box1.style.display = 'block';
        box2.style.display = 'none';
    })
</script>

猜你喜欢

转载自blog.csdn.net/kaw19950302/article/details/78905885
今日推荐