본문 바로가기

반응형

스프링웹개발프로젝트

(16)
FirstSpringBoard#5-1] web.xml 설정과 presentation 레이어 용 설정 파일 생성. 웹 애플리케이션의 영역을 크게 두가지로 나눌 수 있습니다. 비즈니스 레이어(business layer)와 프레젠테이션 레이어(presentation layer)입니다. 비즈니스 레이어는 비즈니스 로직과 DB와 연동하는 부분입니다. 프레젠테이션 레이어는 사용자에게 보이는 부분과 사용자의 요청을 처리해주는 부분으로 나뉩니다. 우리는 이제까지 비즈니스 레이어를 구현한 거에요. 다음 시간부터는 프레젠테이션 레이어를 구현할게요. 출처: http://anomie7.tistory.com/24 [아노미7] 저번 시간에는 기본적인 비즈니스 로직을 모두 구현했어요. 웹 애플리케이션의 영역은 크게 두가지로 나뉘어요. 비즈니스 레이어(business layer)와 프레젠테이션 레이어(presentation layer)입니다...
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#0]프로젝트 소개 안녕하세요. 아노미7입니다.저는 웹개발자로 취업을 준비하고 있는 학생입니다. 스프링에 입문한지는 이제 한달정도 되었습니다.jsp만으로 혹은 model2방식으로 웹 애플리케이션을 구축하다가 spring을 공부해서 웹 어플리케이션을 구현하니 Spring이 제공하는 개발편의성에 큰 희열을 느꼈었어요. 이 글을 읽는 구독자들도 스프링 MVC로 웹애플리케이션을 구축하면서 웹프로그래밍의 재미를 느꼈으면 좋겠습니다.이 연재는 이론적인 부분을 크게 다루지 않습니다. 개발의 과정과 각종 설정파일, 소스코드를 공개합니다. 이 프로젝트는 저 혼자서 계획하고 구축하는 프로젝트입니다. 물론 그렇기 때문에 프로젝트의 구조는 굉장히 단순합니다.게시글을 게시, 수정, 삭제, 조회하고 전체 글 목록을 볼 수 있는 프로젝트입니다. 아래..

반응형