DB를 이용하여 채널 전체 조회하기 유효성 검사 body("user_id").notEmpty().withMessage("user_id를 입력해주세요") .isInt().withMessage("user_id 데이터가 잘못입력되었습니다.") 채널 전체 조회 이미 유효성 검사를 통해서 user_id 값이 undefined로 넘어오는것이 아니기 때문에 해당 부분을 if(data.length === 0)으로 조건을 넘겼고, 해당 조건이 일치할경우는 user_id값을 갖고있는 채널이 존재하지 않다는 뜻이기 때문에 notFoundChannel함수를 사용하였습니다. const { user_id } = req.body; try { const select_sql = "select * from channels where u..
API
DB를 이용하여 채널 개별 수정하기 유효성 검사 채널 개별 수정의 경우에는 param을 통해 채널번호를 받고, body값으로는 title과 description을 받지만 description은 필수항목이 아니기 때문에 유효성검사에서는 제외하였습니다. param("id").notEmpty().withMessage("채널번호가 없습니다."), body("title").notEmpty().withMessage("제목을 입력하세요"), 채널 개별 수정 let { id } = req.params; id = parseInt(id); const { title, description } = req.body; const update_sql ="update channels set title = ? , description..
DB를 이용하여 채널 개별 삭제하기 유효성 검사 param("id").notEmpty().withMessage("채널번호 필요") 채널 개별 삭제 let { id } = req.params; id = parseInt(id); const delete_sql = "delete from channels where id = ?"; try { const [data] = await conn.query(delete_sql, id); if (data.affectedRows == 0) { return notFoundChannel(res); } res.status(200).json({ message: `그동안 유튜브를 이용해 주셔서 감사합니다.` }); } catch (err) { return res.status(400)..
DB를 이용하여 채널 개별 조회하기 유효성 검사(express-validator) 이번 유효성 검사는 params로 받아오기때문에 param을 통해서 비어있지 않은 경우를 확인하기로 했습니다. [param("id").notEmpty().withMessage("id 값이 없습니다.")] 채널 개별 조회 조회는 SELECT문을 사용하는데요 id값이 존재 하지 않는 경우에는 undefined를 받기 때문에 if문에 걸려서 notFoundChannel이 호출이 되고 return시켜 아래 코드를 읽지 않게 됩니다. let { id } = req.params; id = parseInt(id); const select_sql = "select * from channels where id = ?"; try { cons..
DB 이용하여 채널 생성하기 유효성 검사(express-validator) if (!email) { return res.status(400).json({ message: "이메일을 입력해주세요" }); } if (!title) { return res.status(400).json({ message: "채널명을 입력해주세요." }); } 이존의 이 코드들을 validator를 이용하여 유효성 검사로 빠지게 되었습니다. 유효성 검사 코드는 아래 코드로 대체하였습니다. [body("email").notEmpty().withMessage("이메일을 입력해주세요") .isEmail().withMessage("이메일 형식이 아닙니다."), body("title").notEmpty().withMessage("채널명을..
앞서 공부한 회원가입, 회원 개별 조회, 회원 개별 탈퇴와는 다르게 id가 존재하는지 password가 일치하는지를 확인을 하는 작업을 로그인 핸들링함수에서 작성을 해주셔야 하는데요. 때문에 조회, 탈퇴, 가입과 다르게 코드가 조금 복잡해져서 맨 마지막으로 작업하게 되었습니다. 로그인 왜 회원 조회를 하는데 get이 아닌 post를 사용하나요? 로그인할때 우리가 받아오는 id와 password 값의 노출을 막기 위해 안전한 body에 넣어서 사용하는데요. 보통 body 값은 사용자가 form을 통해서 전송을 했을 때 전달을 받을 수 있습니다. 즉 form을 통해서 전달을 받으면 post를 사용한다는 것을 알 수 있습니다. app.post("/login", (req, res) => { const { id,..
개별조회와 삭제는 경로가 일치하기 때문에 .route를 이용하여 묶어서 작업하려고 합니다. app .route('경로') .get(핸들러함수) .delete(핸들러함수) 이 코드에서 핸들러 함수를 작성한다고 봐주시면 좋을 것 같습니다. 회원 개별 탈퇴 .route('/users/:num') .delete((req,res)=>{ let { num } = req.params; num = parseInt(num); if (!db.has(num)) { res.status(404).json({ message: "찾는 유저가 없습니다." }); return; } const user = db.get(num); db.delete(num); res.status(200).json({ message: `${user.name..
개별조회와 삭제는 경로가 일치하기때문에 .route를 이용하여 묶어서 작업하려고 합니다. app .route('경로') .get(핸들러함수) .delete(핸들러함수) 이 코드에서 핸들러 함수를 작성한다고 봐주시면 좋을 것 같습니다. 회원 개별 조회 .route('/user/:num') .get((req, res)=>{ let { num } = req.params; num = parseInt(num); const user = db.get(num); if (!db.has(num)) { res.status(404).json({ message: "찾는 유저가 없습니다." }); return; } res.status(200).json({ userId: user.id, name: user.name }); }) 조..
API 설계를 따른 틀을 작성을 하고 나면 이제 조금씩 살을 덧대는 작업을 진행하게 되는데요. 아직 데이터베이스를 건들지 않아서 Map객체를 이용하고 있습니다. 회원가입 app.post("/join", (req, res) => { const data = req.body; db.set(idx++, data); // 아직 아이디 중복 가능 console.log(data); if (!data || !data.id || !data.password || !data.name) { res.status(400).json({ message: "입력 값을 다시 확인해주세요" }); return; } res.status(201).json({ //등록성공 상태코드 : 201 message: `${db.get(idx - 1)...