๋ฐ˜์‘ํ˜•

Development knowledge/Web 3

[Web] ๋ชจ๋ฐ”์ผ ๊ธฐ๊ธฐ(mobile device) ํ™”๋ฉด ์ž˜๋ฆผ ํ˜„์ƒ ์›์ธ ๋ฐ ํ•ด๊ฒฐ ๋ฐฉ๋ฒ• (+ viewport)

Intro ์•ˆ๋…•ํ•˜์„ธ์š”. ์ด๋ฒˆ์‹œ๊ฐ„์—๋Š” ๋ชจ๋ฐ”์ผ ๊ธฐ๊ธฐ (mobile device) ํ™”๋ฉด ์ž˜๋ฆผ ํ˜„์ƒ์— ๋Œ€ํ•ด ์•Œ์•„๋ณด๊ฒ ์Šต๋‹ˆ๋‹ค. ์ œ ๊ฒฝ์šฐ react next project๋ฅผ ๋งŒ๋“ค์—ˆ์Šต๋‹ˆ๋‹ค. pc local ๊ฐœ๋ฐœ์ž๋„๊ตฌ ํ…Œ์ŠคํŠธ ์‹œ ํ™”๋ฉด ์ž˜๋ฆผ ํ˜„์ƒ ์—†์ด ์ž˜ ๋‚˜์™”์ง€๋งŒ, ์‹ค์ œ ํ•ธ๋“œํฐ์—๋Š” border line์ด ์‚ด์ง ์ž˜๋ฆฐ ํ˜„์ƒ์ด ๋‚˜ํƒ€๋‚˜๋”๋ผ๊ณ ์š”. ํ•ด๋‹น ๋ฌธ์ œ๋ฅผ ํ•ด๊ฒฐํ•˜๊ธฐ ์œ„ํ•ด ๊ตฌ๊ธ€๋ง์„ ํ•ด๋ดค์Šต๋‹ˆ๋‹ค. ๐Ÿค˜ Why? ๋ชจ๋ฐ”์ผ ๊ธฐ๊ธฐ์—์„œ ํ™”๋ฉด ์ž˜๋ฆผ ํ˜„์ƒ์ด ๋‚˜ํƒ€๋‚˜๋Š” ์›์ธ์€ ์—ฌ๋Ÿฌ๊ฐ€์ง€ ์žˆ์„ ์ˆ˜ ์žˆ๊ฒ ๋งŒ, ๋Œ€๊ฒŒ๋Š” ๋ชจ๋ฐ”์ผ ๊ธฐ๊ธฐ ๋ธŒ๋ผ์šฐ์ €์˜ ๋ทฐํฌํŠธ์™€ ๊ด€๋ จ๋œ ๋ฌธ์ œ๋ผ๊ณ  ํ•ฉ๋‹ˆ๋‹ค. ๋ชจ๋ฐ”์ผ ๋ธŒ๋ผ์šฐ์ €๋Š” ํŽ˜์ด์ง€ ๋ Œ๋”๋ง ์‹œ ๋ทฐํผํŠธ์˜ ํฌํ‚ค์— ๋งž๊ฒŒ ์ž๋™ ์กฐ์ •๋ฉ๋‹ˆ๋‹ค. ํ•˜์ง€๋งŒ ๋ธŒ๋ผ์šฐ์ €๊ฐ€ ๋ทฐํฌํŠธ์˜ ํฌ๊ธฐ๋ฅผ ์˜ฌ๋ฐ”๋ฅด๊ฒŒ ๊ณ„์‚ฐํ•˜์ง€ ๋ชปํ•  ๊ฒฝ์šฐ, ํŽ˜์ด์ง€๊ฐ€ ์ œ๋Œ€๋กœ ๋‚˜์˜ค์ง€ ์•Š๋Š” ๊ฒฝ์šฐ๊ฐ€ ๋ฐœ์ƒํ•ฉ๋‹ˆ๋‹ค. ..

[Web] RESTful API๋ž€?

Intro ์•ˆ๋…•ํ•˜์„ธ์š”. ์ด๋ฒˆ ์‹œ๊ฐ„์—๋Š” RESTful API์— ๋Œ€ํ•ด ์•Œ์•„๋ณด๊ฒ ์Šต๋‹ˆ๋‹ค. RESTful API (REST API) RESTful API๋ž€ Representational State Transfer(ํ‘œํ˜„ ์ƒํƒœ ์ „์ด) ์•„ํ‚คํ…์ณ๋ฅผ ๋”ฐ๋ฅด๋Š” API์ž…๋‹ˆ๋‹ค. REST๋Š” ์›น ๊ธฐ๋ฐ˜ ์‹œ์Šคํ…œ์—์„œ ๋ฆฌ์†Œ์Šค๋ฅผ ์ •์˜ํ•˜๊ณ , ์ด๋ฅผ HTTP ํ”„๋กœํ† ์ฝœ์„ ํ†ตํ•ด CRUD(Create, Read, Update, Delete) ์ž‘์—…์„ ์ˆ˜ํ–‰ํ•˜๊ธฐ ์œ„ํ•œ ๊ทœ์น™์ด๋‚˜ ์ œ์•ฝ ์กฐ๊ฑด์„ ์ œ๊ณตํ•ฉ๋‹ˆ๋‹ค. RESTful API ํŠน์ง• HTTP ํ”„๋กœํ† ์ฝœ์„ ์‚ฌ์šฉํ•˜์—ฌ ํด๋ผ์ด์–ธํŠธ์™€ ์„œ๋ฒ„ ๊ฐ„์˜ ํ†ต์‹ ์„ ์ฒ˜๋ฆฌํ•ฉ๋‹ˆ๋‹ค. ํด๋ผ์ด์–ธํŠธ๋Š” URL์„ ํ†ตํ•ด ์„œ๋ฒ„์˜ ๋ฆฌ์†Œ์Šค์— ์ ‘๊ทผํ•˜๊ณ , HTTP ๋ฉ”์†Œ๋“œ(GET, POST, PUT, DELETE ๋“ฑ)๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ํ•ด๋‹น ๋ฆฌ์†Œ์Šค๋ฅผ ์กฐ์ž‘ํ•ฉ๋‹ˆ๋‹ค. ์ด๋Ÿฌํ•œ ..

[Web] JWT(JSON Web Token)๋ž€?

Intro ์•ˆ๋…•ํ•˜์„ธ์š”. ์ด๋ฒˆ ์‹œ๊ฐ„์—๋Š” JWT(JSON Web Token) ์— ๋Œ€ํ•ด ์•Œ์•„๋ณด๊ฒ ์Šต๋‹ˆ๋‹ค. JWT(JSON Web Token) JWT๋ž€ ์ธ์ฆ ๋ฐ ๊ถŒํ•œ ๋ถ€์—ฌ๋ฅผ ์œ„ํ•ด ์‚ฌ์šฉ๋˜๋Š” ํ‘œ์ค€ ๊ธฐ๋ฐ˜์˜ ๋ฐ์ดํ„ฐ ํ˜•์‹์ž…๋‹ˆ๋‹ค. JWT๋Š” JSON ํ˜•์‹์œผ๋กœ ํ‘œํ˜„๋˜๋ฉฐ, ๋ฐ์ดํ„ฐ๋ฅผ ์•ˆ์ „ํ•˜๊ฒŒ ์ „์†กํ•˜๊ณ  ๊ฒ€์ฆํ•˜๊ธฐ ์œ„ํ•œ ๋””์ง€ํ„ธ ์„œ๋ช…์ด ํฌํ•จ๋ฉ๋‹ˆ๋‹ค. JWT ๊ตฌ์กฐ JWT๋Š” ์„ธ ๊ฐ€์ง€ ํŒŒํŠธ๋กœ ๊ตฌ์„ฑ๋ฉ๋‹ˆ๋‹ค. ํ—ค๋”, ํŽ˜์ด๋กœ๋“œ, ์„œ๋ช…์ž…๋‹ˆ๋‹ค. ํ—ค๋” (Headder) ํ—ค๋”๋Š” ํ† ํฐ์˜ ํƒ€์ž…๊ณผ ์‚ฌ์šฉ๋˜๋Š” ํ•ด์‹ฑ ์•Œ๊ณ ๋ฆฌ์ฆ˜์„ ์ง€์ •ํ•˜๋Š” ์—ญํ• ์„ ํ•ฉ๋‹ˆ๋‹ค. ํŽ˜์ด๋กœ๋“œ (Payload) ํŽ˜์ด๋กœ๋“œ๋Š” ํ† ํฐ์— ํฌํ•จ๋  ๋ฐ์ดํ„ฐ๋ฅผ ์ •์˜ํ•ฉ๋‹ˆ๋‹ค. ์„œ๋ช… (Signature) ์„œ๋ช…์€ ํ—ค๋”์™€ ํŽ˜์ด๋กœ๋“œ๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ์ƒ์„ฑ๋˜๋ฉฐ, ์ด๋ฅผ ์ด์šฉํ•ด ๋ฐ์ดํ„ฐ์˜ ๋ฌด๊ฒฐ์„ฑ (๋ฐ์ดํ„ฐ์˜ ์ •ํ™•์„ฑ, ์ผ๊ด€์„ฑ, ์œ ํšจ์„ฑ์ด ์œ ์ง€๋˜๋Š” ..

๋ฐ˜์‘ํ˜•