Giter Site home page Giter Site logo

djkeh / fastcampus-project-board Goto Github PK

View Code? Open in Web Editor NEW
114.0 3.0 60.0 516 KB

패스트캠퍼스 게시판 만들기 프로젝트. 자바 + 스프링부트와 관련 기술들을 공부한다.

Home Page: https://fastcampus.co.kr/dev_online_befinal

Java 89.86% CSS 0.84% HTML 9.23% Procfile 0.06%
fastcampus fastcampus-uno

fastcampus-project-board's People

Contributors

djkeh avatar jadekim042386 avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar

fastcampus-project-board's Issues

깃헙 프로젝트와 이슈 정리하기

깃헙 프로젝트를 세팅하고, 카드를 만들어 정리하자.

  • 프로젝트 베타 만들기
  • 카드 목록 만들기 - 강의 커리큘럼 참고
  • 이슈로 적절히 바꾸기

데이터베이스 접근 로직 테스트 정의

도메인 설계 내용(#8)을 바탕으로 DB 와 연동하기 위한 방법을 구상하고, 세팅을 하고, 테스트를 먼저 작성해본다.

  • DB 기술 선택하기
  • DB 에 접근할 수 있는 상태로 환경 세팅하기
  • 테스트

게시판 서비스 뷰에 기능 구현하기

게시판 서비스 뷰가 실제로 동작하게 만들기 위해 해야 할 일을 정리하고, 실행한다.

  • 뷰 기능 정의
    • 게시판 페이지 기능 테스트 정의
    • 게시글 페이지 기능 테스트 정의
    • 로그인 페이지 기능 테스트 정의
  • 뷰 기능 구현
    • 게시판 페이지 기능 구현
    • 게시글 페이지 기능 구현
    • 로그인 페이지 기능 구현
  • 테스트

잘못된 도메인 정보 바로잡기

#31 기능을 하다가 도메인 코드 설계가 일부 잘못 되어있는 것을 발견.
UserAccount 회원 계정의 userId 는 회원 id 이므로 유니크해야 하는데,
해당 속성이 빠져있었다.
erd 문서에는 email 의 유니크 키가 표현되지 않음
바로잡기로 한다.

  • user_id에 유니크 키 추가
  • email erd 업데이트

[고도화] 엔티티 코드 리팩토링 - `equals()`, `hashcode()`에서 필드 접근을 getter로 바꾸기

스프링 데이터 JPA로 엔티티를 다룰 때, 엔티티 데이터는 하이버네이트 구현체가 만든 프록시 객체를 이용하여 지연 로딩될 수 있다.
따라서 엔티티를 조회할 때 필드에 직접 접근하면 id == null 인 상황이 있을 수 있고, 이러면 올바른 비교를 하지 못 하게 된다.
getter를 사용하면 이러한 문제를 예방할 수 있다.
수정해보자.

  • Article
  • ArticleComment
  • UserAccount

게시판 페이징 구현

게시판 서비스에 필요한 페이징 기능을 구현한다.

  • 게시판 페이지 (이전, 숫자, 이후)
  • 게시글 페이지 (이전, 이후)

도메인 설계

게시판 서비스를 만들기 위한 기본 도메인을 설계해보자.

  • 도메인 ERD 다이어그램 그려보기
  • 자바 클래스로 도메인 표현해보기

헤로쿠에 배포하기

드디어 완성한 게시판 서비스 프로젝트!
클라우드에 배포하여 사용해보자.

[고도화] 댓글 기능 고도화 - 댓글 기능의 결정과 롤백

n차 대댓글 기능은 댓글 단계가 깊어질 수록 디자인이 복잡해져서
유저의 편의를 위해 설계했으나, 오히려 유저의 경험을 해칠 우려가 있다고 판단했다.
또한 런칭 후 관찰해보니, 실제로도 유저 반응이 좋지 않아서 서비스에 내보내기 않기로 논의를 했다.

이에 기능을 롤백한다.

인증 기능 구현

인증 기능을 구현한다.

  • 인증 설정하기
    • 인증이 필요 없는 영역
      • 루트 페이지 보기
      • 게시판 보기
    • 인증이 필요한 영역
      • 게시글 (+ 댓글) 보기
      • 자기 게시글 쓰기, 수정, 삭제
      • 자기 댓글 쓰기, 수정, 삭제
  • 인증 기능에 필요한 부분 구현
  • 회원 가입 페이지
  • 테스트

게시판 검색 구현

게시판에서 게시글을 검색하는 기능을 구현하고, 검색 기능을 보다 특별하게 이용자에게 제공할 수 있는 방법을 고민해 본다.

  • 구현
    • 검색 대상 필드로 기본 검색 기능 구현
    • 기본 게시판 페이지의 검색바 기능 구현
    • 제목, 본문, 이름 검색 페이지
    • 해시태그 검색 페이지
  • 테스트

[고도화] 추가 도메인 설계

새로운 기능을 구현하기 위해 필요한 데이터를 모델링하고, 기존 도메인(엔티티 클래스)에서 변경할 부분이 있는지 살핀다.

  • 기존 도메인 코드 분석
  • 대댓글 도메인 표현
  • 해시태그 도메인 표현

깃헙 릴리즈하기

게시판 서비스의 첫번째 버전이 완성되었다.
깃헙에 릴리즈하자.

ch01 04 -> 05, ch02 09 -> 10 강의 관련 문의사항

안녕하세요 강의 잘 보고 있습니다. ch02까지 보면서 개인적으로 불편했던 점 두가지가 있어 문의드립니다. 혹시 이곳에 문의드리는 게 아니라면 이슈 삭제해 주셔도 됩니다.

  1. ch01 04 -> 05 넘어갈 때 생겨난 프로젝트들에 대한 설명 부재
    ch01 04에서 예시로 프로젝트에 카드를 3개 정도 만들었는데, 05에서 "제가 미리 만들어 왔습니다" 하시면서 17개의 카드를 보여주십니다. 하지만 이 부분에 대해 어떤 목록이 추가되었는지에 대해 별도의 설명이나 강의자료가 없어 강의를 앞뒤로 돌려가며 무엇이 추가된 것인가 찾아봐야 하는 불편함이 있습니다.

  2. ch02 09 -> 10 넘어갈 때 추가된 userAccount 관련 설명 부재
    이 부분은 뭔가 강의가 통으로 빠진 느낌인데, erd에도, 도메인도, 테스트도 추가되었는데 이에 대한 강의가 보이지 않는 것 같습니다. 제가 놓친 걸수도 있는데 최소한 ch02에는 관련된 내용이 없는 것 같습니다.

읽어주셔서 감사합니다.

게시판 정렬 구현

게시판 정렬 기능을 구현한다.
정렬 기능은 게시판 페이지에서 각 컬럼(제목, 해시태그, 작성자, 작성일)의 제목을 누르면
해당 값으로 오른차순, 내림차순 정렬이 되게끔 동작하게 만드는데 쓴다.

  • 정렬 기능 구현
  • 뷰에 적용
  • 테스트

[고도화] 해시태그 검색 기능 고도화

해시태그 기능을 고도화한다.

  • 하나의 글이 여러 개의 해시태그를 저장할 수 있도록 만들기
  • 별도 입력 공간을 주지 않고, 본문에서 해시태그를 파싱해서 기록하기
  • DB에는 #을 뺀 문자열을 저장할 수 있게 하기
  • 해시태그에 링크를 삽입하기

게시글 뷰 기능 구현

수업 시간에 보여주지 않았던 게시판 뷰, 게시글 뷰의 게시글 등록, 수정, 삭제 기능을 구현한다.
#21 의 연장선

  • 게시판 뷰 - 글쓰기
  • 게시글 뷰 - 수정, 삭제

[고도화] 추가 요소 - 깃헙 CI 기능 활성화하기

현재 본 프로젝트는 헤로쿠와 연동되어 있어, pr이 머지되면 자동으로 클라우드 배포가 일어난다.
다만 이 사이에 테스트 실행이 자동으로 일어나지 않고 있기 때문에,
깃헙 CI 를 활성화해서 pr 머지 -> 테스트 -> 배포의 자동화 플로우를 완성해보면 더 좋을 것 같다.

도메인 수정 - 회원 계정과 게시글, 댓글 관계 연결

게시글과 댓글은 모두 회원이 작성하는데, 그 연관관계가 ERD 와 같이 자바 코드에 표현되지 않은 것 같다.
createdBy를 작성자로 생각하고 다룰 수도 있지만, 해당 필드는 작성자와 직접적인 연관이 맺어져있지 않기 때문에
보다 이상적인 방향으로 도메인 설계를 할 필요가 있다.
문제를 확인하고 수정하기.

원인을 알 수 없는 소스코드 유실 확인하기

강의 도중에 원인을 알 수 없는 코드 유실이 일어났다.
다행히 기능은 모두 정상 작동하는 것으로 보이지만
테스트가 실패한다.
직전 강의까지 모든 테스트가 통과했는데 굉장히 이상함...

원인을 파악해보고, 알 수 없다면 소스코드라도 되살려보자.

헤더에 해시태그 메뉴 추가하기

#38 에서 해시태그 기능을 구현했는데, 쉽게 접근할 수 있도록 배려를 하지 않았다.
이를 헤더에 추가하여 쉽게 해시태그 검색 페이지 존재를 알고, 들어갈 수 있게 한다.

게시글 댓글 구현

게시글에 댓글을 다는 기능을 구현한다.

  • 게시글 페이지에서 댓글을 등록하기
  • 게시글 페이지에서 댓글을 골라 삭제하기
  • 게시글 페이지에서 댓글을 골라 편집하기
  • 테스트

게시글 네비게이션의 로직 버그 수정: 중간 글을 삭제할 경우 이전 글, 다음 글을 선택할 수 없는 문제

게시글 페이지에서는 이전 글, 다음 글 버튼을 통해 게시글 이동이 가능하다.
이 기능은 단순히 게시글 id를 +-1씩 증감하는 알고리즘으로 구현되어 있는데,
이 방법은 중간 게시글을 삭제할 경우 게시글 리소스를 탐색하지 못하는 문제점을 가지고 있다.
이를 개선할 방법이 있으나 다른 수강생분들의 생각할 기회를 빼앗지 않도록,
개선 방법은 pr로 작성하도록 한다.

위 내용은 강의 수강생분들 중 한 분께서 발견하여 제보해 주셨다.

이는 기초 페이지네이션 알고리즘을 코드로 소개하는 동시에 개선의 여지를 버그로 남겨두어서
프로젝트를 공부하는 수강생과 버그 이슈를 통해 소통하고, pr을 통해 수정도 함께 하고 코드 리뷰까지 해드리고자 하는 의도였으나
그보다는 버그 오동작으로 인한 수강생 분의 혼란이나 강의 수강 중 겪을 불편함이 좀 더 우려되므로
직접 수정하고, 과정을 공유하는 방법으로 진행하도록 한다.

그래도 수정 작업 시작 전에 다른 분의 참여가 있다면 코드 리뷰로 소통할 예정.

Reference

[고도화] 프로젝트 시작 전 리팩토링

게시판 서비스 고도화 프로젝트를 진행하기 전,
프로젝트에서 아쉬웠던 부분을 리팩토링하고
프로젝트를 본격적으로 시작할 준비를 한다.

  • 테스트에서 잘못된 Void.class 사용을 개선하기
  • JUnit5 테스트에서 불필요한 public 접근자 제거하기
  • 테스트 메소드 네이밍 개선하기
  • 테스트에서 이상한 들여쓰기나 중복된 표현 수정하기
  • 불필요한 import, 띄어쓰기 수정하기
  • 유즈케이스를 현재 상황에 맞게 업데이트 하기

계정 도메인 추가 작업

지난 #8 에서 강의 흐름 상 작업하지 않았던 회원 계정 도메인을 추가로 작업한다.
이는 인증 기능 구현을 위해 필요함

  • erd 업데이트
  • 도메인 추가
  • jpa 인터페이스 추가

[고도화] 인증 기능 고도화 - 카카오톡으로 로그인

인증 기능에 카카오 계정으로 로그인하는 방법을 추가한다.

  • Kakao Developers에서 카카오 API 사용 준비하기
    • 애플리케이션 등록하기
    • Rest API 키 확인하기
    • 사이트 도메인 등록하기
    • Redirect URI 등록하기
    • 동의항목 설정하기
    • Client Secret 키 확인하기
  • 회원 도메인이 인증 없는 상태에서 회원 정보를 저장할 수 있게 수정하기
  • 카카오 인증 응답 정보 확인, 정의하기
  • OAuth 2.0 보안 설정 (+람다식 접근)
  • OAuth2UserService 구현
    • 기본 OAuth 2.0 인증 처리 구현체 사용
    • 카카오 인증 정보를 회원으로 등록하기
  • 기본 인증 서비스 로직 구현
  • 뷰 구현
    • 카카오 로그인 버튼 이미지 준비
    • 카카오 로그인 버튼 구현
    • 로그인 후 노출하는 유저 정보 변경: ID -> 닉네임

Reference

게시판 서비스 뷰 만들기

게시판 서비스 뷰를 만들기 위해 해야 할 일을 정리하고, 실행한다.

  • 뷰 엔드포인트 테스트 정의
  • 뷰 구현
    • 게시판 페이지 만들기
    • 게시글 페이지 만들기
    • 로그인 페이지 만들기
    • 뷰에 디자인 붙이기
  • 테스트

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.