ใคใกใผใธ็ฎก็ใใซในใฟใใฏ (feat. Node.jsใReactใMongoDBใAWS)
ใ็ปๅใจๅใใใกใคใซใฏใฉใใซใฉใฎใใใซไฟๅญใใใฐใใใฎ๏ผ ใใผใฟใใผในใซไฟๅญ๏ผ ใใใจใใตใผใใผใฎใใผใใใฃในใฏ๏ผ ใตใผใใผใฎ่ฒ ่ทใๆธใใใซใฏใฉใใใใฐใใใฎ๏ผ ใใใใใใใใใจใชใใใใใใใฎ็ปๅใใใฐใใ่ชญใฟ่พผใใซใฏใฉใใใใฐใใใฎ๏ผ AWS S3๏ผ CDN๏ผ๏ผ ๅใซ็ปๅใไฟๅญใใฆ่ชญใฟ่พผใใ ใใชใฎใซใใชใใใใชใซ่ฆ็ด ใๅคใใฎ๏ผ ใฉใฎ่ฆ็ด ใใฉใฎใใใชๅฝนๅฒใๆใใใใฉใฎใใใซ็ตใฟๅใใใใฐใใใฎ๏ผใ ็ปๅใใกใคใซใซ้ข้ฃใใๅฟ ่ฆใช่ฆ็ด ใใใซในใฟใใฏใงๆๅใใๆๅพใพใงๆด็ใใฆ่ชฌๆใใพใ :)
ๅ่ฌ็ 655ๅ
้ฃๆๅบฆ ๅ็ด
ๅ่ฌๆ้ ็กๅถ้

- ๆช่งฃๆฑบ
Router.use ๋๋ฒ์งธ ํ๋ผ๋ฏธํฐ ImageRouter : undefined ์ ๋ฌ ์ค๋ฅ
Router.use() requires a middleware function but got a undefined export require ๊ฒฝ๋ก ํ์ธ ์ ํ๋๋ฐ ์ ๋ฐ์ํ ๊น์...?
reactnode.jsawsmongodbexpresslambdapjhyng0125
ใป
0
93
2
- ๆช่งฃๆฑบ
์์ค์ฝ๋ ์์ฒญ
ํน์ ๊ฐ์ ์์ค์ฝ๋ ๋ฐ์ ์ฌ ์ ์์๊น์?์ ๊ฐ ๋ฐฑ์๋๋ ๋ค ์์ฑ ํ๋๋ฐ ํ๋ก ํธ ์ชฝ ํ์๋ ๋ถ์ด ์ธ๊ตญ ๋ถ์ด๋ผ ์ค๋ช ํ๊ธฐ์๋ ์ด๋ ต๊ณ ํด์ ์์ฒญ๋๋ฆฝ๋๋ค.
reactnode.jsawsmongodbexpresslambdashinjaeo0772
ใป
0
144
1
- ๆช่งฃๆฑบ
ํ๋ก์ ๊ด๋ จ ์ง๋ฌธ
์๋ ํ์ธ์ ๊ฐ์ฌ๋,proxy ์ค์ ์ ํ๋ฉด ์ด๋ ๊ฒ ์ค๋ฅ๊ฐ ๋จ๋ฉด์ ์๋ฒ ์์์ด ์๋ผ์.ํ๋ก์ ๋ถ๋ถ์ ์ง์ฐ๋ฉด ์ ์๋ํ๋๋ฐ์ด๋๊ฐ ์๋ชป๋๊ฑธ๊น์?<img src="https://cdn.inflearn.com/public/files/post
reactnode.jsawsmongodbexpresslambdagyuri9078
ใป
0
143
1
- ๆช่งฃๆฑบ
Presigned URL ์ฌ์ฉ์ ๋ฐ์ดํฐ๋ฒ ์ด์ค ์ ์ฅ ์์
๋ฐ์ดํฐ๋ฒ ์ด์ค ์ ์ฅ ์์ ํ์ฌ ์ด๋ฏธ์ง ์ ๋ก๋ ๊ด๋ จํด์ ํ๋ก์ ํธ๋ฅผ ์งํํ๊ณ ์๋๋ฐ, ์ด๋ฏธ์ง๋ฅผ ๋ถ๋ฌ์ค๊ธฐ ์ํด ๋ณ๋์ ๋ฐ์ดํฐ๋ฒ ์ด์ค ์ ์ฅ์ด ํ์ํด์ ํด๋ผ์ด์ธํธ์์ pr
reactnode.jsawsmongodbexpresslambdajiwonlolz3535
ใป
0
309
1
- ๆช่งฃๆฑบ
์ด๋ฏธ์ง ๋ฑ๋ก์ ์๋ ๋ฑ๋ก ์ค๋ฅ
์ด๋ฏธ์ง ๋ฑ๋ก์์ ์๋ ์ฌ์ง๊ณผ ๊ฐ์ด ์ด๋ฏธ์ง๊ฐ ๋ฆฌ์คํธ์ ๋ฑ๋ก์ด ๋๊ธดํ๋๋ฐ ์ด๋ฏธ์ง ํํ๊ฐ ๊นจ์ ธ์ ๋ฑ๋ก์ด ๋ฉ๋๋ค. ์๋ก๊ณ ์นจ์ ํด์ผ ์ ์์ ์ผ๋ก ๋ฐ์๋๋ ์ค๋ฅ๊ฐ ์๋๋ฐ ์ด๋ ์ฝ๋๊ฐ ์๋ชป๋์ง๋ฅผ ๋ชจ๋ฅด๊ฒ ์ต๋๋คใ ใ <a target="_blank" rel="noopen
reactnode.jsawsmongodbexpresslambdaไฝๆ่ ใชใ
ใป
0
195
1
- ๆช่งฃๆฑบ
๊ฐ์์ ์ฌ์ฉ๋ ์ฝ๋ ๋ค์ด ๋ฐ๋ ์ฌ์ดํธ ์ฃผ์ ์๋์?
๊ฐ์์ ์ฌ์ฉ๋ ์ฝ๋ ๋ค์ด ๋ฐ๋ ์ฌ์ดํธ ์ฃผ์ ์๋์?
reactnode.jsawsmongodbexpresslambdasupport8880
ใป
0
359
2
- ๆช่งฃๆฑบ
axios ์ด์ฉํด์ ๋ฐฑ์๋๋ก ์ด๋ฏธ์ง ์ ์ก ์ค ์๋ก๊ณ ์นจ
<img src="https://cdn.inflearn.com/public/files/posts/dc4c9282-3a4c-4606-8d93-5591b91a59e5/ํ๋ฉด์บก์ฒ2023-09-28223212.png" alt="ํ๋ฉด ์บก์ฒ 2023-09-28 223212.p
reactnode.jsawsmongodbexpresslambdadldh12187987
ใป
0
459
1
- ๆช่งฃๆฑบ
ImageList ์ปดํฌ๋ํธ์์ ์ ๋ก๋ ํ ์ฌ์ง์ ๋ฆฌ์คํธ์์ ๋ฐ๋ก ๋ณด๊ธฐ ์ํด ์ด ๋ฐฉ๋ฒ๋ ๊ด์ฐฎ๋์??
ImageList ์ปดํฌ๋ํธ ์์ ์๋ useEffect ์ข ์๋ฐฐ์ด ์์ images๋ฅผ ๋ฃ๊ฒ ๋๋ฉด images๊ฐ ๋ณ๊ฒฝ๋ ๋๋ง๋ค get์ ํธ์ถํด์ ์ฌ์ง์ ๋ถ๋ฌ์ค๊ธฐ ๋๋ฌธ์ ๊ฒฐ๊ณผ์ ์ผ๋ก ์ฌ์ง์ ์ ๋ก๋ํ๋ฉด ๋ฆฌ์คํธ์ ๋ฐ๋ก ๋ณด์ฌ์ง๊ธด ํ๋๋ฐ ์ ์ข์ ๋ฐฉ๋ฒ์ธ๊ฐ์? ์ ์๋
reactnode.jsawsmongodbexpresslambdamadeinkorea10282025
ใป
0
369
1
- ๆช่งฃๆฑบ
์ด๋ฏธ์ง ์ฒ์ ์ฌ๋ฆด ๋๋ง ๋ํ๋๋ ์ค๋ฅ
์ฌ์ดํธ ์ด๊ณ ์ด๋ฏธ์ง "์ฒ์" ์ฌ๋ฆด ๋ ์ด๋ฐ ์ค๋ฅ๊ฐ ๋ ์,
reactnode.jsawsmongodbexpresslambdajan9jan1ne7704
ใป
0
245
1
- ๆช่งฃๆฑบ
es6 ์คํ์ผ๋ก Import ํ ๋ ๋์ํ์ง ์์ต๋๋ค.
<img src="https://cdn.inflearn.com/pub
reactnode.jsawsmongodbexpresslambdaapk
ใป
0
373
1
- ๆช่งฃๆฑบ
์ด๋ฏธ์ง ์ ๋ก๋์
๋ฆฌ์กํธ์์๋ ์ด๋ฏธ์ง ์ ๋ก๋ํ๋ ค๊ณ ํ ๋ ์ด๋ฏธ์ง๋ฅผ ๋ฏธ๋ฆฌ๋ณด๊ธฐ๋ก ๊ฐ๋ฅํ๊ฑธ๋ก ์๊ณ ์๋๋ฐ ํ ํ๋ฆฟ์์ง hbs์์๋ ์ด๋ฏธ์ง ํ์ผ ์ ํํด์ ์ด๋ฏธ์ง๋ฅผ ๋ฏธ๋ฆฌ ๋ณผ์์๋๋ก ํ ์์๋์?
reactnode.jsawsmongodbexpresslambdadramayeong8278
ใป
0
353
1
- ๆช่งฃๆฑบ
node js๋ฅผ ์ด์ฉํ๊ณ mysql์ ์ด๋ฏธ์ง ๊ฒฝ๋ก ์ ์ฅ
nodejs, multer๋ฅผ ํตํด์ ์ด๋ฏธ์ง๋ฅผ ์ ๋ก๋ํ์ต๋๋คdb์ ํด๋น ํ์ผ๋ช uuid()๋ฅผ ํตํด์ ์ ์ฅ์ ํ๋๋ฐ ์ด๋ฏธ์ง ์ฃผ์๋ณต์ฌ ํด์ ๊ฒ์ํด์ ๋ค์ด๊ฐ๋ฉด ์ด๋ฏธ์ง๊ฐ ๋์ค๋๋ฐ ๊ฒ์ํด๋ ๋ชป๋ค์ด๊ฐ๊ฒ ํ๋ ค๋ฉด ์ด๋ป๊ฒ
reactnode.jsawsmongodbexpresslambdadramayeong8278
ใป
2
1,252
1
- ๆช่งฃๆฑบ
์ ์๋ cloudFront๋ฅผ ์ฌ์ฉํ๊ฒ๋๋ฉด S3๋ private์ผ๋ก ์ฌ์ฉํ๋๊ฒ ์ข์๊น์
s3๋ฅผ ํผ๋ธ๋ฆญ์ผ๋ก ๋๋๊ฒ์ ์ข์ง ์๋ค๊ณ ์๊ฐํ๋๋ฐ,CDN ์ฃผ์๋ก ์ ๊ทผํ๋๊ฑฐ๋ฉด s3๋ private์ผ๋ก ํ๊ณ ์ฌ์ฉํ ์ ์๋๋ก ์ค์ ์ด ๊ฐ๋ฅํ ๊น์?
reactnode.jsawsmongodbexpresslambdajy722hi0683
ใป
0
525
1
- ๆช่งฃๆฑบ
์ ์๋ aws-sdk ๋ชจ๋์ ์ฐพ์ ์ ์๋ค๊ณ ํฉ๋๋ค.
aws-sdk๋ ๋ฐ๋ก ์ค์น๋ฅผ ์ํด๋ ๊ด์ฐฎ๋ ํ์ ์ ์ค์น๋ฅผ ์ํ์ต๋๋ค. ํ์ง๋ง Cannot find module 'aws-sdk' ์๋ฌ๊ฐ ๋ฐ์ํฉ๋๋ค. <img src="https://cdn.infl
reactnode.jsawsmongodbexpresslambdajy722hi0683
ใป
0
642
1
- ๆช่งฃๆฑบ
new aws.S3 version ํ์ธ
"multer-s3": "^2.10", "@types/multer-s3": "^2.7.12", ๋ฒ์ ์ ์์ฒ๋ผ ๊น์์ฃผ์ ์ผ ๊ฐ์์ ํธํ๋
reactnode.jsawsmongodbexpresslambdajy722hi0683
ใป
2
499
1
- ่งฃๆฑบ
react-router-dom v6 useHistory ์ด์
react-router-dom v6 ์ด์์์๋ useHistory ๋์ useNavigate ๋ฅผ ์ฌ์ฉํ์ฌ์ผ ํฉ๋๋ค.v5import { useHistory } from "react-rou
reactnode.jsawsmongodbexpresslambdahoo8799
ใป
7
630
0
- ๆช่งฃๆฑบ
๋๋ค์์ ์๊ฐ ์ด๊ณผ ์๋ฌ๊ฐ ๋น๋๋ค!
<img src="https://cdn.inflearn.com/public/files/posts/5abbfcd1-26d1-44cb-b3f3-ebd0d4e2d854/แแ ณแแ ณแ แ ตแซแแ ฃแบ2023-05-23แแ ฉแแ ฎ4.41.59.png" alt="แแ ณแแ ณแ แ ตแซแแ ฃแบ 202
reactnode.jsawsexpresslambdashinjaeo0772
ใป
0
304
1
- ่งฃๆฑบ
์ฒซ ๋ก๋์ ๋์ผํ ์ด๋ฏธ์ง ๋๋ฒํธ์ถ
์ผ๋จ ์ ๋ ๊ณต๊ฐ/๋น๊ณต๊ฐ๋ ์ ์ธํ๊ณ ๋ง๋ค๊ณ ์์๋๋ฐ ImageContext์์ prevDara๋ฅผ ์ถ๊ฐํ ์ดํ๋ก ์ฒซ ๋ก๋์์ ์ฒซ๋ฒ์งธ ์ด๋ฏธ์ง ๋ฆฌ์คํธ๋ค์ ๋๋ฒ ํธ์ถํ๋๋ฐ ์ด๋ค ๋ฐฉ์์ผ๋ก ํด๊ฒฐํด์ผ ํ ๊น์???์ต์ ๋ฒ๊ฐ ๋ฐ๋ ๋๋ฉด ๋๋ฒ์งธ ํ์ด์ง ๋ฆฌ์คํธ๋ค์ ํ๋ฒ๋ง ํธ
reactnode.jsawsmongodbexpresslambdavzb0011159
ใป
2
475
1
- ่งฃๆฑบ
์ด๋ฏธ์ง ์ ๋ก๋ ์ ๋ฐฐ์ด๋ก
<img src="https://cdn.inflearn.com/public/files/posts/5f7315fd-ec8e-493e-8f98-584ee823abae/แแ ณแแ ณแ แ ตแซแแ ฃแบ2023-03-28แแ ฉแแ ฎ3.56.37.png" alt="แแ ณแแ ณแ แ ตแซแแ ฃแบ 202
reactnode.jsawsmongodbexpresslambdavzb0011159
ใป
2
515
1
- ๆช่งฃๆฑบ
Promise.all์ ๋ํ ์ง๋ฌธ
์ ์๋ ์๋ ํ์ธ์.์ด๋ฒ ๊ฐ์์์ ์ฌ์ฉ๋ Promise.all์ด ๋ญ์ง ๋ชฐ๋ผ์์ฐพ์๋ณด๋ async-await๋ฅผ ์ฌ์ฉํ๋ฉด ๋น๋๊ธฐ ๋์์ ์ํ๊ฐ ์๋ฃ๋ ๋๊น์ง ๊ธฐ๋ค๋ฆฐ ํ ๋ค์ ์ฝ๋๋ฅผ ์์ฐจ์ ์ผ๋ก ์ฝ์ด๋๊ฐ๋ค๋ณด๋ ์ด๋ ๊ฒ ๊ธฐ๋ค๋ฆฌ๋ ์๊ฐ์ ๊ฐ์ ํ๊ธฐ ์ํด Prom
awsnode.jsreactmongodbnodejsexpresslambdakhhan19901239
ใป
0
410
1

