롯데 시네마 클론코딩 - JSP를 이용한 영화 예매 기능 프론트엔드&백엔드 클론코딩
팀원 | 권나연 | 안채영 | 이성은 | 이충현 | 장혜원 | 정은우 |
---|---|---|---|---|---|---|
맡은 작업 | 영화 목록페이지 기능 구현, RDS 연동 | 영화 상세페이지 기능 구현, 예약완료 페이지 기능 구현, ERD 제작 | 메인페이지, 공통 화면 소스(header, footer, etc), 로고 | 로그인, 회원가입 기능 구현, Slack과 Github 연동, DB관리 | 예약기능 및 페이지 구현및 DB 데이터 관리 | 마이페이지(예약목록, 예약확인, 예약취소)기능 구현 |
깃 주소 | hellonayeon | hellochaeyoung | lse99 | chungchung234 | IMHYEWON | juneu1509 |
Git을 사용해 프로젝트의 형상을 관리를 하고 Github을 통해 팀원들과 각자의 버전을 공유했습니다.
- Github 주소
- Default 브랜치인 dev 브랜치로부터 각자 브랜치를 생성해 맡은 기능 구현을 진행했습니다.
- Github의 Issue와 Milestone, Project 기능을 사용해 작업 현황을 공유했습니다.
Slack과 Github을 연동해 원격 브랜치에 업데이트가 발생하면 Slack에서 확인 가능하도록 설정했습니다.
Notion을 이용해 협업에 필요한 문서들을 공유했습니다.
- Java : 18
- MySQL : 8.0.29
- Servlet
- Html, CSS, JQuery : 3.6.0.min
- gson : 2.2.2 / json-simple : 1.1.1
- Github, Notion
-
로그인 전 메뉴
회원가입
로그인
메뉴 활성화
-
로그인 후 메뉴
마이페이지
로그아웃
메뉴 활성화
-
회원가입 화면 각 항목별로 유효성 검사 진행
아이디 중복체크
전체 항목 미기입시 회원가입 불가
-
로그인 화면 쿠키에 아이디 저장
- 영화 포스터 하단
페이지 번호
로 영화 목록 확인
예매
클릭시 영화 예매 페이지로 이동
지역
,영화관
,영화
,상영시간
선택시 인원 선택 화면으로 이동- 비동기 통신으로 지역&영화관, 영화 선택에 따른 상영 타임 테이블 정보 조회
-
마이 페이지 메뉴
-
마이페이지
-
예매 상세 내역 페이지
2022.07.06 | 2022.07.07 | 2022.07.08 | 2022.07.09 | 2022.07.11 | 2022.07.12 | |
---|---|---|---|---|---|---|
요구사항 정의 | 🙌 | |||||
기획 및 설계 | 🙌 | 🙌 | ||||
개발 환경 구성 | 🙌 | |||||
기능 구현 | 🙌 | 🙌 | 🙌 | |||
테스트 | 🙌 | 🙌 | 🙌 | 🙌 | ||
문서 정리 | 🙌 |
- 요구사항 정의 및 설계 진행
- 회의록 : https://www.notion.so/jungew1509/20220706-f48a260a5a6b4f4e8541c4d3640ff121
- 협업 및 형상 관리를 위한 github organization 및 repository 생성
- CUTEAM 만의 Github 사용 약속 정하기
- Pull Request, Commit 컨벤션
- 기능 별 branch 생성
- Issue 및 MileStone 생성
- 다양한 개발 환경(Mac, Windows, Intellij, Eclipse, JAVA 등)에 의한 .gitignore 설정
- CUTEAM 만의 Github 사용 약속 정하기
- ERD 구현
- Member, Movie, Screen, Reservation
- 총 4개의 테이블로 ERD를 최종 구성
- 담당 기능 배정
- 회의록 : https://www.notion.so/jungew1509/20220707-2af94f5e1ed24291a655fd8380d1245e
- 09:00, 19:00 진행 상황 공유를 위한 회의 진행
- 회의록 : https://www.notion.so/jungew1509/20220708-3d0b6761f43749498f6048226dbea0bf
- 09:00, 14:00 : 진행 상황 공유를 위한 회의 진행
- 팀원 각자 담당 기능 자유롭게 구현 작업 진행
- 회의록 : https://www.notion.so/jungew1509/20220709-b8db7d19989f47b9be6cad00d578af97
- 09:00, 19:00 : 진행 상황 공유를 위한 회의 진행
- 담당 기능 구현 마무리 작업 진행
- 프로젝트 완성을 위한 공동 작업 계획 수립 진행
- 회의록 : https://www.notion.so/jungew1509/20220711-1f1b9c5222bc43cabcc112a3d850dbdd
- 09:00, 17:00 : 진행 상황 공유를 위한 회의 진행
- 담당 기능 구현 마무리 작업 진행
- 회의록 : https://www.notion.so/jungew1509/20220712-50cc3f57225f409bb73c6815ddac6af4
- Github를 이용하여 Organization을 제작하여 소스를 공유 및 버전관리
- 팀 회의를 통해 Github 사용방법을 정의
Github Organization의 Repository를 활용한 모습
협의를 통해 git convention 정의
파일 제작 시 수정사항을 위하여 파일명, 주석, 코드스타일을 정의하고 사용했다.
프런트엔드 파트의 경우 WebContent를 이용하여 페이지 별로 디렉토리를 구분했다.
메인화면 혹은 공통 부분 화면의 경우 루트에 위치한다.
백엔드 파트의 경우 기능별로 디렉토리를 구분했다.
- 🦁 은우
- Linked
- 프로젝트 본격적으로 개발하기 전부터 각자 맡은일을 체계적으로 잘한 것 같다. 깃 사용법을 각자 분업하여 조사해서 알려주고 계획한대로 깃을 잘 사용한 점이 너무 좋았다.
- learned
- default branch를 적용의 중요성을 알게되었다. 푸쉬를 하기전 풀먼저 하고 푸쉬를 했어야 했다는 것을 배웠다.
- Lacked
- 프런트엔드 동적페이지로 구현하는 것과 sql 작성하는 법을 더 알아야겠다고 생각했다. 동적 페이지 구현이 어려워 많이 적용하지 않았고, 프로젝트기간 마지막에 예매페이지를 구현할때 도와줄 수 없다는 점이 아쉬웠다. SQL을 작성하는데 SQL로 더 쉽게 처리할 수 있는 방법이 많았을 것 같은데 아쉬웠다.
- longed for
- 각자 페이지를 분업하여 가져간 후에 더 자세하게 알 수 없었던게 아쉬웠다.
- Linked
- 🐷 혜원
- Linked 원래 프로젝트 주제인 ‘영화 예매 시스템’을 구현하는 것 외에 문서 정리, 깃으로 협업하는 법을 배울 수 있다는 점이 좋았습니다. 깃은 커밋 푸쉬정도 밖에 몰랐는데 다양한 기능을 사용하면서 효율적으로 협업할 수 있도록 도와주셔서 감사합니다 ~😍
- learned
- 백단 데이터 흐름에 대해 작업하면서 배운 것도 있지만, 프론트와 데이터 주고받는 부분에 대해 많이 배우게 되었습니다. 그리고 비동기로 데이터를 받아서 뷰를 만드는 과정에서 document,돔의 실행 순서(?)가 중요하다는 것을 알게 되었습니다.
- lacked
- 분업할 때, 서비스별로 하다보니 각자 맡은 부분만 설계하고 관여한 점,
- longed for
- 좀 굵직한 로직, 흐름은 함께 이야기 해보면 조금 더 빠르게 방향을 정할 수 있었을 거란 생각이 들어 아쉬웠습니다. 시간이 더 있었다면 제가 맡은 페이지 UX를 더 개선하고 싶습니다
- 🥕 성은
- Linked
- 맡은 일만 하지 않고 다들 도와주셔서 넘 감사했습니당
- learned
- 문서 정리 — 체계적으로 하는 것도 배우고/ 깃 제대로 관리해볼 수 있어서 많이 배운 것 같습니당
- Lacked
- 시간이.. 시간이 너무 부족했따
- longed for
- 각자 맡을 부분을 좀 더 세분화 했으면 좋았을듯!!
- Linked
- ⭐ 나연
- Linked | 팀원들이랑 해서 좋았던 것
- 분업이 잘 됐고, 기능이 다르더라도 서로의 문제를 자기 문제처럼 고민하는 모습이 좋았다.
- 프로젝트 형상관리 (Git, Github)
- 기능 구현 범위를 3일 기간에 맞게 팀원들이 잘 조정해준 점
- Learned | 내가 이 프로젝트를 하며 배운점
- 문서화 작업 !
- 주기적인 소통
- 주저하지 않고 시작하면 얻는게 있당 !
- 처음 버전은 큰 기능들이 합쳐져 돌아갈 수 있게끔 간단하게 만들기
- Lacked | 아쉬운 점
- 초기 개발환경 세팅을 확실하게 하지 않은점 (Eclipse, IntelliJ)
- 빌드 도구 !! (Maven, Gradle)
- Longed For | 개선했었으면 좋았을 점
- 내 스케쥴 뿐만 아니라 다른 팀원들의 스케쥴도 계속 확인했으면 좋았을 듯
- Linked | 팀원들이랑 해서 좋았던 것
- 🌊 충현
- Linked
- 세분화된 역활분담과 형상관리를 통해 협업을 이끌어낸 점을 통해 많이 배웠다
- Learned
- 브런치의 다양한 활용에 대해 배웠다.
- Lacked
- 소셜 로그인 기능을 꼭 넣고 싶었는데 도전도 못하고 끝낸것이 아쉬웠다
- Longed for
- 소셜 로그인 기능을 넣고 회원 정보에 관한 보안 처리해서 실제 운영중인 로그인 페이지와 비교해도 손색 없는 페이지를 만들어 보고 싶다.
- Linked
- 🍦 채영
- Linked
- 깃에 대해서 잘 알고 있는 팀원들 덕분에 깃을 제대로 써볼 수 있어서 너무 좋았다.
- 기록을 잘하는 팀원이 있어서 놓치기 쉽지만 중요할 자료들을 다 모을 수 있어서 좋았다.
- 모두가 팀 프로젝트 경험이 있어서 한 명도 미숙함 없이 프로젝트가 진행됐던 것 같고 부족한 부분은 서로 도와주고 채워주는 모습이 좋았다.
- Learned
- 깃을 제대로 사용해 본 첫 번째 기회였던 것 같다. 많은 것을 배웠다.
- PR, Issues, convention, commit message 등등
- JSP를 이제 마스터 한 것 같다…
- 깃을 제대로 사용해 본 첫 번째 기회였던 것 같다. 많은 것을 배웠다.
- Lacked
- 리팩토링을 하지 못한 것
- 테이블 설계가 좀 미숙해서 로직이 좀 꼬였던 것 같다.
- 깃에 미숙해서 실수 했던 것이 좀 맘에 걸린다.
- 프론트엔드를 정말 못해서
- 기능을 공평하게 양을 나눴다고 생각했는데 그게 아니었어서 설계 떄 더 자세하게 기능을 세분화하여 분담해야겠다.
- 걱정이 너무 많아서 계속 생각하느라 컨디션 조절 실패한 것.
- Longed for
- IDE 통일
- 라이브러리 관리를 위한 빌드 툴 사용..
- Linked