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 In this section, we will guide you step by step in the development of an image upload registration system in Java using MySQL and JDBC. In the application, users register…
The Touchable Shop POS (Point of Sale) system is a sophisticated software solution developed using…
Creating a responsive login form is a crucial skill for any web developer. In this…
In this tutorial will teach Laravel 12 CRUD API by step. Laravel 10 CRUD Application …
In this lesson we talk about laravel 12 image uploading and display the image step…
In this tutorial will teach Laravel 12 CRUD Application step by step. Laravel 12 CRUD…