본문 바로가기

반응형

스프링프로젝트

(9)
FirstSpringBoard#00] git와 github를 이용해서 실습 코드 조회하기 안녕하세요.실습을 따라하면서 막히는 부분이 많을 거라고 생각합니다.아무래도 블로그의 코드를 보면서 하면 내가 맞게하고 있는지도 의심스러울거고 오타가 날 수도 있는거니깐요.저는 실습을 하면서 git를 이용해서 버전관리를 합니다.주요 기능들이 추가되면 커밋해서 변경이력을 남겨요.제 github에 올린 소스를 이용하는 것도 학습에 큰 도움이 될겁니다.git을 이용해서 프로젝트의 변경 이력을 조회하는 방법을 알아봅시다. git는 DVN으로 분산 버전 관리 시스템의 약자입니다.git에서 파일을 저장하는 repository는 두개입니다. 내 컴퓨터에 저장하는 local repository와 원격저장소에 저장하는 remote repository에요.github는 원격저장소라고 할 수 있습니다.우선 제 github로 ..
FirstSpringBoard#4-2] 마이바티스(mybatis)의 매퍼 인터페이스(mapper Interface)를 스프링 컨테이너에 등록하기 저번 시간에는 sqlSessionTemplate를 root-context.xml이라는 설정 파일에 등록하고 @Autowired를 통해서 의존성을 주입받는 방법을 테스트해보았어요. 그러나 sqlSessionTemplate뿐만 아니라 우리가 설정했던 Mapper Interface도 스프링 컨테이너에 등록해서 애노테이션으로 주입 받을 수 있어요. 그 방법을 알아보고 설정 파일에 알맞게 DAO와 Service 클래스도 수정할 겁니다. root-context.xml에 아래 엘리먼트를 추가해주세요. 아래 그림을 보고 테스트 코드를 수정해서 실행하세요. DAO를 수정해주세요. 코드가 엄청나게 많이 줄어든 것을 확인할 수 있어요. public class BoardDAO { @Autowired BoardMapper bo..
FirstSpringBoard#4-1] 마이바티스(Mybatis)와 스프링 프레임워크(Spring FrameWork) 연동 안녕하세요. 이제 드디어 스프링 설정을 하게되었습니다. 포스팅 제목이 FirstSpringBoard인데 여태 진행 사항을 보면서 "스프링도 자바 코딩과 다를게 없잖아?"라고 의구심이 드셨을 수도 있어요. 이제 부터 본격적으로 스프링을 이용해서 프로젝트를 구현해나갈 겁니다. 우선 우리가 사용할 기능은 DI(Dependenxy Injection)입니다. 우리말로는 의존성 주입이라고 해요. BoardDAO에서 SqlSession이나 ServiceBoardImpl에서 BoardDAO의 객체를 생성해서 사용해 주잖아요. BoardDAO boardDAO = new BoardDAO() 이런 식으로요. 스프링 의존성 주입을 사용하면 new 키워드를 사용한 객체 생성없이 스프링에서 객체를 생성해서 변수에 주입을 해줍니다..
FirstSpringBoard#3-3] 수정, 삭제, 특정 게시물 조회 기능 구현 & Service 인터페이스 구현 안녕하세요. 오늘은 나머지 기능을 구현할게요.그리고 현재 테스트코드에서 DAO를 호출해서 비즈니스 로직을 처리하고 있습니다. 그러나 DAO를 바로 호출해서 비즈니스 로직을 처리하는 것은 기능의 확장이나 변화에 대해서 유연하게 대처하지 못하고 나중에 스프링의 AOP 기능을 적용하는데 문제가 있습니다. 그렇기 때문에 DAO를 추상화한 Service Interface를 만들고 Interface를 구현한 ServiceImpl 클래스를 만들어서 이 클래스에서 DAO를 호출하도록 할 것입니다. 과정은 이전과 동일해요. 1. Mapper.xml에 mapper 추가 2. mapper interface에 대응하는 메소드 추가3. DAO에서 DB연동 코드 추가4. 테스트 코드 작성 위와 같은 순서대로 진행됩니다. 나머지 ..
FirstSpringBoard#3-2] 프로젝트 과정 설명 & 비즈니스로직 구현하기(게시물 등록 하기) 아래 그림은 여태까지 진행한 프로젝트의 순서를 간단히 정리한 것입니다. 1. 프로젝트 계획-ERD는 데이터베이스 테이블에 관한 명세입니다. 테이블에 관한 정보과 테이블들간의 관계에 관한 정보가 담겨있어요. 프로젝트에 앞서서 필요한 데이터베이스 테이블를 설계한다고 생각하면 됩니다.-Mockup은 내가 구현할 애플리케이션의 UI를 설계하는 것입니다. 설계하면서 웹페이지 컴포넌트들의 동작들에 대해서 생각할 수 있고실제 비즈니스 로직 구성에 대해서 생각해 볼 수 있어요.-UML은 폭넓은 개념인데 대표적으로 시퀸스 다이어그램이나 클래스 다이어그램을 예로 들 수 있어요. 프로젝트 구성에서 객체들의 관계나 비즈니스 로직에서 객체들의 동작이 어떻게 되는지 정해진 형식으로 보여줍니다. 2. 프로젝트 생성입니다.-디렉토리..
FirstSpringBoard#3-1] 비즈니스로직 구현하기(전체 글 조회) 이번 포스팅에서는 이전시간에 설정한 것들을 바탕으로 비즈니스 로직을 구현해보겠습니다. Domain 객체를 만들고, Mapper.xml 파일을 설정하고 테스트 코드를 작성하면서 DAO 클래스를 만들어볼게요. 우선 비즈니스 로직 구현을 위해서 웹어플리케이션의 기능을 알아봐야합니다. 아래 화면을 보면 우리가 필요한 기능들을 알 수 있어요. -전체 글 조회 -특정 글 조회 -수정 -삭제 -글쓰기 각각 기능 수행에 필요한 쿼리문들도 떠오를 것입니다. -전체 글 조회(slect *from tablename) -특정 글 조회(select *from tablename where id = #{id}) -수정 (update tablename set column1 = #{...}, column2 = #{....}) -삭제 ..
FirstSpringBoard#2]마이바티스와 연동하기 안녕하세요. 오늘은 마이바티스와 연동해서 SqlSession 객체를 생성하는 시간입니다. 아마 여러분들은 JDBC나 JDBCTemplate를 주로 이용하셨을 겁니다. 마이바티스는 SQL Mapper입니다. 쉽게 말해서 객체의 필드, 원시 타입을 SQL과 연결해주는 거에요.Jdbc를 사용할때 prepareStatement.set(1, name)나 rs.getString("name")과 같이 SQL에 넣어줄 파라미터나 DB에서 반환받는 값을 개발자가 직접 설정했었는데.SQL Mapper는 이 작업을 자동으로 해줍니다. 그리고 마이바티스는 sql문과 DB연동 정보를 자바코드와 분리시켜주는 역할을 합니다.여태까지 SQL문을 String type으로 소스코드 안에서 선언해줬었는데. 이제는 그럴 필요가 없습니다. ..
FirstSpringBoard#1-2] 메이븐 의존성 추가 안녕하세요. 저번 포스팅에서는 STS의 인코딩 방식 설정과 프로젝트 생성까지 했습니다.이번에는 메이븐으로 프로젝트 구성에 필요한 라이브러리를 추가할게요.우리 프로젝트에서는 Mybatis라는 DB연동 프레임워크(persistence framework)를 사용할것입니다.spring에서 Mybatis를 연동하기 위한 라이브러리를 추가할 것이고 테스트 코드 작성을 위한 설정도 할거에요. 1. 우리가 생성한 프로젝트를 보면 pom.xml이라는 파일이 있습니다.이 파일에서 메이븐 의존성을 추가합니다. 2. pom.xml 파일을 클릭하면 아래와 같은 화면이 보이는데요.밑의 탭들이 보입니다. Dependencise는 메이븐에서 추가한 라이브러리들을 쉽게 관리할 수 있는 창입니다.그 옆의 Dependency Hierar..

반응형