Code Convention
1. Naming Rule
1) 메소드
- 동사 + 명사의 형태이며 메소드 명의 첫 캐릭터는 소문자로 기술한다.
- 동사 + 명사1 + 명사2 의 형태처럼 동사 뒤의 단어들이 반복되는 경우 각 단어의 첫 캐릭터는 대문자.
getData();
getCustomerData();
2) 상수
- final, define, const로 선언되는 상수는 "_"(under bar)로 구분된 대문자로 정의.
private static final String SERVER_ADDRESS = "192.0.0.1";
3) 변수
- DB table 필드, Request parameter 와 1:1 매핑 되는 변수는 해당 명명규칙을 따르되 첫 글자는 소문자이고 ‘_’로 구분되는 경우는 대문자로 구분한다.
DB 필드명 : user_id -> 변수명 : userId
-첫문자가 소문자 두번째가 대문자의 경우(mSeq) GET / SET 메소드가 아래와 같이 생성된다.
private String mSeq;
public String getmSeq() {
return mSeq;
}
public void setmSeq(String mSeq) {
this.mSeq = mSeq;
}
///
private String msSeq;
public String getMsSeq() {
return msSeq;
}
public void setMsSeq(String msSeq) {
this.msSeq = msSeq;
}
- 도메인 클래스
- DB 필드 Integer 나 int 경우 도메인 클래스내 변수를 int 로 선언
4) 클래스 패키지 경로
- 프로젝트명이 gm 인 경우
자바 패키지명
com.groundx42.gm.aop -> AOP 관련 패키지
com.groundx42.gm.common -> common 관련 패키지
com.groundx42.gm.excetion -> exception 관련 패키지
com.groundx42.gm.framework -> framework 관련 패키지
com.groundx42.gm.interceptor -> 인터셉터 관련 패키지
com.groundx42.gm.process -> 업무 프로세스 관련 패키지
- com.groundx42.gm.process.서비스명.업무분류.패키지.클래스명
예) 회원서비스라면
com.groundx42.gm.process.member.web.MemberController -> Member Web Controller 클래스
com.groundx42.gm.process.member.mobile.MobileMemberController -> Member Mobile Controller 클래스 (prefix)
com.groundx42.gm.process.member.service.MemberService -> Member 비즈니스 로직 인터페이스
com.groundx42.gm.process.member.service.MemberServiceImpl -> Member 비즈니스 로직 클래스
com.groundx42.gm.process.member.domain.Member -> Member 도메인 클래스
com.groundx42.gm.process.member.dao.MemberDAO -> Member DAO 인터페이스
com.groundx42.gm.process.member.dao.MemberDAOImpl -> Member DAO 클래스
5) Controller 클래스 명 및 mapping 경로
- 모든 Controller 클래스 명에는 끝에 Controller 을 붙인다.
LoginController -> Login 관련 Controller
MemberController -> Member 관련 Controller
- Controller 클래스의 mapping 경로는 recruit 의 경우 패키지경로에서 여섯번째 경로까지를 생략하고 나머지를 경로로 기술한다.
- 클래스 mapping 명은 소문자로 시작한다.
- mapping 경로의 경우 클래스 명 끝의 Controller 는 생략한다.
com.groundx42.gm.process.recruit.member.controller.LoginController 인 경우 : /member/login -> http://recruit.groundx42.com/member/login.do
com.groundx42.gm.process.recruit.member.controller.MemberController 인 경우 : /member/member -> http://recruit.groundx42.com/member/member.do
6) Service / DAO / 도메인 클래스
- Service 와 DAO 클래스는 업무분류 를 접두사로 사용하고, 도메인 클래스는 DB 테이블명을 클래스 명으로 사용한다.
- 인터페이스 명 끝에 Service / DAO 를 붙인다.
- 클래스 명 끝에 ServiceImpl / DAOImpl 를 붙인다.
MemberService -> Member 비즈니스 로직 인터페이스
MemberServiceImpl -> Member 비즈니스 로직 클래스
MemberDAO -> Member DAO 인터페이스
MemberDAOImpl -> Member DAO 클래스
Member -> Member Domain 클래스 (DB 테이블명 동일하게 맞춘다)
7) mybatis sqlmap 폴더
- 메이븐 생성 폴더 java 폴더와 동일 레벨에 sqlmap 폴더를 생성한다.
src/main/java -> 메이븐 자바 폴더
src/main/sqlmap/member/memberDAO.xml -> Member 관련 sql xml 문
8) 메이븐 resources 설정
src/main/resources-dev -> 개발 환경 리소스 폴더
src/main/resources-local -> 로컬 개발 환경 리소스 폴더
src/main/resources-prod -> 실 서비스 환경 리소스 폴더
9) Layout
- 파일 경로는 /_freemarker/_layout 경로를 베이스로 한다.
- 기본 layout 파일명은 _서비스명_서비스역할_layout.ftl
- 파일명은 소문자를 사용하고 단어간의 사이에는 ‘_’ 문자로 구분한다.
/_layout/default_layout.ftl
/_layout/header_layout.ftl
/_layout/footer_layout.ftl
10) View (JSP or FTL)
- 파일 경로는 /_freemarker/_template 경로를 베이스로 하며, 해당 클래스의 패키지 경로의 네번째 명부터의 경로와 일치시킨다.
- 파일명은 소문자를 사용하고 단어간의 사이에는 ‘_’ 문자로 구분한다.
- freemarker 파일 확장자는 *.ftl로 설정한다.
com.groundx42.gm.process.recruit.member.controller.MemberController 클래스에 대한 view 경로 -> /_freemarker/_template/member/member_list.ftl
11) Spring 설정 파일 구조
- spring-서비스명-역할-config.xml 로 명명한다.
src/main/resources-prod/conf/mybatis/sqlMapConfig.xml -> mybatis mapper 설정 파일
src/main/resources-prod/conf/prop/xx.properties -> properties 설정 파일
src/main/resources-prod/conf/spring/applicationContext-jdbc.xml -> JNDI 설정 + sqlMapConfig.xml 설정 파일
src/main/resources-prod/conf/spring/default-servlet.xml -> spring 설정 파일
12) 기타 Java Code Convention
- 기타 Java Code Convention 과 관련한 내용은 아래의 경로를 참조한다.
http://java.sun.com/docs/codeconv/html/CodeConvTOC.doc.html
13) 주석 다는 방법 / Copyright
주석은 명사로 시작해서 동사로 끝낸다.
예) 회원 정보를 저장한다.