지금은 블로그 게시판을 만들고 있다.
router.post("/boardsreply", authMiddleware, async (req, res) =>{
const { userId } = res.locals.user;
const writeId = await Users
.findOne({_id: userId})
.exec();
const { comment, boardsId } = req.body;
const createdReply = await Reply.create({ comment: comment, user: writeId.user, boardsId: boardsId });
res.json({ replys: createdReply });
});
jwt 토큰(로그인정보)을 localStorage에 한다. Reply 테이블(댓글테이블)에는 댓글내용, 작성자, 게시글ID가 들어간다. 게시글ID와 댓글내용은 req.body로 받아오고, 작성자는 토큰에서 받아와서 Reply 테이블에 저장한다.
router.get("/boards/goUpdate/:boardsId",authMiddleware, async (req, res) => {
const { boardsId } = req.params;
const { userId } = res.locals.user;
const [detail] = await Boards.find({_id: boardsId});
const [detail2] = await Users.find({_id: userId});
console.log(detail.user)
console.log(detail2.user)
const isUser = (detail.user === detail2.user);
res.send({
isUser, boardsId
})
})
게시글을 수정/삭제 각각의 기능의 API는 따로있고, 이건 수정/삭제를 할수있는 페이지로 이동하는 API이다. 기존에 게시글은 게시글의 비밀번호가 따로 있었고, 로그인/회원가입 기능이 없어서 게시글 비밀번호로 수정/삭제를 하였는데 로그인/회원가입 기능을 추가하면서 게시글의 비밀번호는 없앴고, 현재 로그인되어있는 ID가 게시글의 작성자와 동일하면 수정/삭제 페이지로 이동이 가능하게끔 만들었다. 변수명을 좋지않게 만들었는데.. 아직 변수명을 올바르게 잘 만드는 요령이 부족한것 같다. 일단 detail.user 는 게시글의 작성자고, detail2.user는 현재 로그인되어있는 유저이다.
isUser에 true or false 값을 담아서 보내주고, 클라이언트에서 isUser값이 true면 수정/삭제페이지로 이동, false면 작성자만 수정/삭제 할수있다는 메세지를 보냈다.
REST(RESTful) 이란?
RESTful API를 통해 요청이 수행될 때 RESTful API는 리소스 상태에 대한 표현을 요청자에게 전송합니다. 이 정보 또는 표현은 HTTP: JSON(Javascript Object Notation), HTML, XLT 또는 일반 텍스트를 통해 몇 가지 형식으로 전송됩니다. JSON은 그 이름에도 불구하고 사용 언어와 상관이 없을 뿐 아니라 인간과 머신이 모두 읽을 수 있기 때문에 가장 널리 사용됩니다.
API가 RESTful로 간주되려면 다음 기준을 따라야 합니다.