nonneng.ee
Daeun-rithm
nonneng.ee
์ „์ฒด ๋ฐฉ๋ฌธ์ž
์˜ค๋Š˜
์–ด์ œ
  • ๋ถ„๋ฅ˜ ์ „์ฒด๋ณด๊ธฐ (51)
    • Back-end (17)
      • Server (3)
      • Database (3)
      • Spring (9)
      • Node.js (1)
    • Book (1)
      • ์ดํŽ™ํ‹ฐ๋ธŒ ์ž๋ฐ” (0)
      • ๋Œ€๊ทœ๋ชจ ์‹œ์Šคํ…œ ์„ค๊ณ„ (1)
    • Algorithm (1)
      • Greedy, Implementation (6)
      • Dynamic Programming (5)
      • Data Structure (3)
      • Sorting (2)
      • Concept (1)
    • TIL (11)
    • Software (3)
      • Design Pattern (3)
    • Computer Science (1)

๋ธ”๋กœ๊ทธ ๋ฉ”๋‰ด

  • ํ™ˆ
  • ํƒœ๊ทธ
  • ๋ฐฉ๋ช…๋ก

๊ณต์ง€์‚ฌํ•ญ

์ธ๊ธฐ ๊ธ€

ํƒœ๊ทธ

  • APM
  • ํŒŒ์ด์ฌ
  • ๊ฐ€์ƒ๋จธ์‹ 
  • ์ˆ˜๋™์„ค์น˜
  • node js
  • Postman
  • ์•„์ดํ…œ8
  • MySQL
  • ์ž๋ฐ”
  • ๋ฐฑ์ค€
  • ์„œ๋ฒ„
  • ์šฐ๋ถ„ํˆฌ
  • ์ปดํŒŒ์ผ์„ค์น˜
  • ๋ธŒ๋ฃจํŠธํฌ์Šค
  • JPA
  • DP
  • Restful API
  • ๊ตฌ๋™์›๋ฆฌ
  • Java
  • ์•„์ดํ…œ9
  • ์ดํŽ™ํ‹ฐ๋ธŒ ์ž๋ฐ”
  • ์•„์ดํ…œ 25
  • ์†Œ์Šค์„ค์น˜
  • ์•„์ดํ…œ 23
  • jwt
  • Spring
  • ์—๋Ÿฌ
  • API
  • ์•„์ดํ…œ6
  • ๊ตฌํ˜„

์ตœ๊ทผ ๋Œ“๊ธ€

์ตœ๊ทผ ๊ธ€

ํ‹ฐ์Šคํ† ๋ฆฌ

hELLO ยท Designed By ์ •์ƒ์šฐ.
nonneng.ee

Daeun-rithm

TIL

[TIL] 2021-08-27

2021. 8. 28. 05:31

๐Ÿ˜Š Today I Learned

1. ์˜์ƒ ์กฐํšŒ ํ•„ํ„ฐ๋ง ์ถ”๊ฐ€ - ์ตœ์‹ ์ˆœ, ์˜ค๋ž˜๋œ์ˆœ, ์กฐํšŒ์ˆœ

  • filter๋ฒˆํ˜ธ๋ฅผ query params๋กœ ๋ฐ›์•„์˜ด → swith๋ฌธ์— ๋„˜๊ฒจ์คŒ → Dao๋กœ ์—ฐ๊ฒฐ๋˜์–ด ๊ฐ๊ฐ ๋‹ค๋ฅธ ์ฟผ๋ฆฌ ์‹คํ–‰
let videoRows;
        switch (filter) {
            case '1':
                videoRows = await videoDao.getOldVideo(userIdx);
                return res.json({ result: videoRows, isSuccess: true, code: 200, message: "์˜ค๋ž˜๋œ ์ˆœ ์˜์ƒ ์กฐํšŒ ์„ฑ๊ณต" });
            case '2':
                videoRows = await videoDao.getPopularVideo(userIdx);
                return res.json({ result: videoRows, isSuccess: true, code: 201, message: "์กฐํšŒ ์ˆœ ์˜์ƒ ์กฐํšŒ ์„ฑ๊ณต" });
            case '3':
                videoRows = await videoDao.getRecentVideo(userIdx);
                return res.json({ result: videoRows, isSuccess: true, code: 202, message: "์ตœ๊ทผ ์ˆœ ์˜์ƒ ์กฐํšŒ ์„ฑ๊ณต" });
            default:
                return res.json({ isSuccess: false, code: 303, message: "์˜์ƒ ์กฐํšŒ ์‹คํŒจ" });
        }

 

2. Dao์—์„œ ์‹คํ–‰๋œ ์ฟผ๋ฆฌ ๊ฒฐ๊ณผ๊ฐ’์„ ๋ณ€์ˆ˜์— ๋ฐ›์•„์˜ค๊ธฐ

  • mySQL ์ฟผ๋ฆฌ ์ˆ˜ํ–‰ ๊ฒฐ๊ณผ๋ฅผ ๋ฐ”๋กœ ๋ณ€์ˆ˜๋กœ ๋ฐ›์•„์˜ค๊ณ  ์‹ถ์—ˆ์œผ๋‚˜, javascript๋ฌธ๋ฒ•๊ณผ ํ•จ์ˆ˜์— ๋Œ€ํ•œ ์ดํ•ด๋„๊ฐ€ ๋ถ€์กฑํ•˜์—ฌ ์•„์ง ๊ตฌํ˜„ํ•˜์ง€ ๋ชปํ–ˆ๋‹ค.
    Untitled
    Untitled 1
    Untitled 2
    ์•„์ง ์–ด๋ ต๊ณ  ํ—ท๊ฐˆ๋ฆฐ๋‹ค..

 

๐Ÿ˜ข Today's error

Untitled 3
console.log(๋ฐ›์•„์˜จ ์ธ๋ฑ์Šค : ${userIdxFromJWT});
Untitled 4
  • postman์—์„œ userIdx : 9๋ฅผ ๋„˜๊ฒจ์ฃผ์—ˆ๊ณ , jwtํ† ํฐ์„ ํ†ตํ•ด userIdxFromJWT์—๋„ 9๋ฅผ ์ €์žฅํ–ˆ๋Š”๋ฐ, ์กฐํšŒ ๊ถŒํ•œ์ด ์—†๋‹ค๊ณ  ๋–ด๋‹ค. ์™œ??????

 

console.log(`userIdxFromJWT type : ${typeof (userIdxFromJWT)}, userIdx type : ${typeof (userIdx)}`);
Untitled 5
  • console.log๋ฅผ ํ†ตํ•ด ๋‘˜์˜ ๋ณ€์ˆ˜ํ˜•์„ ํ™•์ธํ•ด๋ณด์•˜๋”๋‹ˆ, ๊ฐ’์€ 9๋กœ ๊ฐ™์ง€๋งŒ ๊ฐ๊ฐ number์™€ string์ด์—ˆ๋‹ค.
  • != ์—ฐ์‚ฐ์ž → ํƒ€์ž…๊ณผ ๊ด€๊ณ„์—†์ด ๊ฐ’๋งŒ ๋น„๊ต
  • !== ์—ฐ์‚ฐ์ž → ํƒ€์ž…๊นŒ์ง€ ๋น„๊ต

์—ฐ์‚ฐ์ž๋ฅผ !==์—์„œ !=๋กœ ์ˆ˜์ •ํ–ˆ๋”๋‹ˆ ๋ฐ”๋กœ ์„ฑ๊ณตํ–ˆ๋‹ค.

if (userIdx != userIdxFromJWT){
        return res.json({console.log(`userIdxFromJWT type : ${typeof (userIdxFromJWT)}, userIdx type : ${typeof (userIdx)}`);
            isSuccess : false,
            code : 305,
            message : "์ˆ˜์ • ๊ถŒํ•œ์ด ์—†์Šต๋‹ˆ๋‹ค"
        });
    }
Untitled 6

 

๐Ÿ˜… Comment

๋‚ด์ผ์€ ์ฟผ๋ฆฌ, validation ํ•จ์ˆ˜ํ™”๋ฅผ ์„ฑ๊ณตํ•˜๊ณ  ์‹ถ๋‹ค.

'TIL' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€

[TIL] 2021-08-29  (1) 2021.08.30
[TIL] 2021-08-26  (2) 2021.08.27
[TIL] 2021-08-25  (2) 2021.08.26
    'TIL' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
    • [TIL] 2021-10-09
    • [TIL] 2021-08-29
    • [TIL] 2021-08-26
    • [TIL] 2021-08-25
    nonneng.ee
    nonneng.ee

    ํ‹ฐ์Šคํ† ๋ฆฌํˆด๋ฐ”