๐Ÿ‘ฉ‍๐Ÿ’ป ๋ฐฑ์—”๋“œ(Back-End)/Node js

[CRUD์„ ์ด์šฉํ•œ File upload Web] (1) node js๋กœ ๋กœ์ปฌ ์„œ๋ฒ„ ๋„์šฐ๊ธฐ

์ง•์ง•์•ŒํŒŒ์นด 2023. 3. 8. 00:32
728x90
๋ฐ˜์‘ํ˜•

<๋ณธ ๋ธ”๋กœ๊ทธ๋Š” DCodeMania ์˜ ์œ ํŠœ๋ธŒ๋ฅผ ์ฐธ๊ณ ํ•ด์„œ ๊ณต๋ถ€ํ•˜๋ฉฐ ์ž‘์„ฑํ•˜์˜€์Šต๋‹ˆ๋‹ค :-)>

=> CRUD App With Image Upload Using NodeJs, ExpressJs, MongoDB & EJS Templating Engine

 

๐Ÿฅ• ๊ฐœ๋ฐœ ํ™˜๊ฒฝ 

๐Ÿง npm init

- npm : Node Package Manager์˜ ์•ฝ์ž๋กœ nodejs์˜ ๋ชจ๋“ˆ ๊ด€๋ฆฌ

- init : package.json ์ƒ์„ฑ

- package.json : npm์„ ํ†ตํ•ด ์„ค์น˜๋œ ํŒจํ‚ค์ง€ ๋ชฉ๋ก์„ ๊ด€๋ฆฌ, ํ”„๋กœ์ ํŠธ์˜ ์ •๋ณด ๋ฐ ์‹คํ–‰ ์Šคํฌ๋ฆฝํŠธ๋ฅผ ์ž‘์„ฑํ•˜๋Š” ํŒŒ์ผ

๐Ÿง npm install

๐Ÿง npm i express mongoose express-session ejs multer dotenv

- express : ์›น ํ”„๋ ˆ์ž„์›Œํฌ

- mongoose : ๋น„๋™๊ธฐ ํ™˜๊ฒฝ์—์„œ ์ž‘๋™ํ•˜๋„๋ก ์„ค๊ณ„๋œ MongoDB ๊ฐœ์ฒด ๋ชจ๋ธ๋ง ๋„๊ตฌ

- express-session : Express์šฉ ๋‹จ์ˆœ ์„ธ์…˜ ๋ฏธ๋“ค์›จ์–ด

- ejs : ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ๊ฐ€ ๋‚ด์žฅ๋˜์–ด ์žˆ๋Š” html ํŒŒ์ผ (ํ…œํ”Œ๋ฆฟ์—”์ง„), html ์•ˆ์—์„œ <% %>๋ฅผ ์ด์šฉํ•ด์„œ ์„œ๋ฒ„์˜ ๋ฐ์ดํ„ฐ๋ฅผ ์‚ฌ์šฉํ•˜๊ฑฐ๋‚˜ ์ฝ”๋“œ๋ฅผ ์‹คํ–‰

- multer : ํŒŒ์ผ ์—…๋กœ๋“œ๋ฅผ ์œ„ํ•ด ์‚ฌ์šฉ๋˜๋Š” multipart/form-data ๋ฅผ ๋‹ค๋ฃจ๊ธฐ ์œ„ํ•œ node.js ์˜ ๋ฏธ๋“ค์›จ์–ด

- dotenv :  ํ™˜๊ฒฝ ๋ณ€์ˆ˜๋ฅผ ํŒŒ์ผ์— ์ €์žฅํ•ด๋†“๊ณ  ์ ‘๊ทผ ๋„์™€์คŒ

 

๐Ÿง npm i -D nodemon

- nodemon : ํŒŒ์ผ์ด ์ˆ˜์ •๋˜๋ฉด ์ž๋™์œผ๋กœ ๋…ธ๋“œ ์• ํ”Œ๋ฆฌ์ผ€์ด์…˜์„ ์žฌ์‹œ์ž‘

๐Ÿง nodemon index.js

- ์„œ๋ฒ„ ์‹คํ–‰

 

 

๐Ÿฅ• ํŒŒ์ผ ๊ตฌ์กฐ

 

๐Ÿฅ• ์ฝ”๋“œ

๐Ÿง .env

APPLICATION_NAME=gani
PORT=3000
MONGODB_URI=mongodb+srv:~~~

# TOEKN SECRET ๊ฐ’ ๋„ฃ๊ธฐ
SECRET="I6G#D6LiJukWzx1^fw0$"

 

๐Ÿง index.js

// imports
require("dotenv").config();
const express = require("express");
const mongoose = require("mongoose");
const session = require("express-session");

const app = express();
const PORT = process.env.PORT || 8000;

app.get("/", (req, res) => {
    res.send("Hello World");
});

app.listen(PORT, () => {
    console.log(`server started at http://localhost:${PORT}`);
});

728x90
๋ฐ˜์‘ํ˜•