This tutorial will teach you how to make a Registration Login form Application using Node JS and MongoDB using MVC architecture. we have created routes,userControler,userServices,useModel.
First you have to Create the Project
npm init
After run the command package.json file has been created.
First Step Create the page which is server.js which use to connect the port and databases.
const express = require('express') const app = express(); const mongoose = require('mongoose'); var routes = require('./routes/routes'); mongoose.set('strictQuery', false); mongoose.connect("mongodb://localhost:27017/gbs",{useNewUrlParser: true, useUnifiedTopology: true },function checkDb(error) { if(error) { console.log("Error Connecting to DB"); } else { console.log("successfully Connected to DB"); } }); app.listen(9002,function check(error) { if(error) console.log("Error....!!!!"); else console.log("Started....!!!!"); }); app.use(express.json()); app.use(routes);
After that create the new Folder routes inside the folder create file routes.js.
var express = require('express'); var userController = require('../src/user/userController'); const router = express.Router(); router.route('/user/login').post(userController.loginUserControllerFn); router.route('/user/create').post(userController.createUserControllerFn); module.exports = router;
after that create folder src inside the src create the newfolder user inside the folder make userControler.js,userServices.js,useModel.js these files.
var userService = require('./userServices'); var createUserControllerFn = async (req, res) => { try { console.log(req.body); var status = await userService.createUserDBService(req.body); console.log(status); if (status) { res.send({ "status": true, "message": "User created successfully" }); } else { res.send({ "status": false, "message": "Error creating user" }); } } catch(err) { console.log(err); } } var loginUserControllerFn = async (req, res) => { var result = null; try { result = await userService.loginuserDBService(req.body); if (result.status) { res.send({ "status": true, "message": result.msg }); } else { res.send({ "status": false, "message": result.msg }); } } catch (error) { console.log(error); res.send({ "status": false, "message": error.msg }); } } module.exports = { createUserControllerFn, loginUserControllerFn };
var userModel = require('./userModel'); var key = '123456789trytryrtyr'; var encryptor = require('simple-encryptor')(key); module.exports.createUserDBService = (userDetails) => { return new Promise(function myFn(resolve, reject) { var userModelData = new userModel(); userModelData.firstname = userDetails.firstname; userModelData.lastname = userDetails.lastname; userModelData.email = userDetails.email; userModelData.password = userDetails.password; var encrypted = encryptor.encrypt(userDetails.password); userModelData.password = encrypted; userModelData.save(function resultHandle(error, result) { if (error) { reject(false); } else { resolve(true); } }); }); } module.exports.loginuserDBService = (employeeDetails)=> { return new Promise(function myFn(resolve, reject) { userModel.findOne({ email: employeeDetails.email},function getresult(errorvalue, result) { if(errorvalue) { reject({status: false, msg: "Invaild Data"}); } else { if(result !=undefined && result !=null) { var decrypted = encryptor.decrypt(result.password); if(decrypted== employeeDetails.password) { resolve({status: true,msg: "Employee Validated Successfully"}); } else { reject({status: false,msg: "Employee Validated failed"}); } } else { reject({status: false,msg: "Invaild Employee Detailssss"}); } } }); }); }
var mongoose = require('mongoose'); var Schema = mongoose.Schema; var userSchema = new Schema({ firstname: { type: String, required: true }, lastname: { type: String, required: true }, email: { type: String, required: true }, password: { type: String, required: true } }); module.exports = mongoose.model('employee', userSchema);
Introduction to Grocery Inventory Apps Managing grocery inventory can be a daunting task, but with…
This article explain how to make a Fish Inventory Management App in Angular.this app explain…
Introduction to Fish Inventory Management In the aquaculture industry, managing fish inventory is crucial for…
Introduction to Java GUI CRUD Java is a powerful programming language widely used for building…
Introduction to Login Form Design Designing an effective and beautiful login form is crucial for…
Introduction In today creating a responsive login form is essential for providing a seamless user…