책 소개
(https://github.com/AcornPublishing/toby-spring3-1)
XML 대신 자바코드를 이용해서 스프링을 개발할 수 있는 최신 빈 설정 기법부터 편리한 RESTful 스타일의 웹 컨트롤러 작성 기법까지 스프링 3.0과 스프링 3.1의 최신 기술을 상세하게 소개하고 그 중에서 자신에게 맞는 최적의 기술을 선택하고 조합할 수 있는 기준과 활용전략을 다룬다.
『토비의 스프링 3.1』은 스프링을 처음 접하거나 스프링을 경험했지만 스프링이 어렵게 느껴지는 개발자부터 스프링을 활용한 아키텍처를 설계하고 프레임워크를 개발하려고 하는 아키텍트에 이르기까지 모두 참고할 수 있는 스프링 완벽 바이블이다.
대한민국 전자정부 표준 프레임워크 스프링을 설명하는 No. 1 베스트셀러!
[ 이 책에서 다루는 내용 ]
★ DIJ/JavaConfig, OXM, @MVC, SpEL, Task, REST 등의 스프링 3.0의 최신 기술 소개
Java EE 6의 JSR-303과 자바코드를 이용한 최첨단 DI기술, XML 매핑을 위한 OXM, 기존 MVC를 완벽하게 대체한 강력한 웹 프레임워크인 @MVC, 스프링 공식 EL인 SpEL, JSR-303(BeanValidation)과 새로운 컨버터와 포매터 활용방법, 각종 비동기 작업을 위한 Task 기능, REST 템플릿 사용법 등 스프링 3.0의 새로운 기능을 기존 스프링 기술과 함께 상세히 소개한다.
★ 런타임 추상화, 프로파일, 프로퍼티 소스, 캐시 추상화, 발전된 @MVC, 플래시 맵 등 스프링 3.1의 최신 기술 소개
프로파일을 이용한 다이내믹한 빈 설정 기술, 통합된 프로퍼티 소스, 더욱 강력해진 @MVC 핸들러 작성, 플래시 맵 활용 방법과 AOP를 이용한 캐시 추상화 등 스프링 3.1의 최신 기술과 달라진 점을 자세히 소개한다.
★ 스프링 기술 선택을 위한 상세한 기술 비교, 선택 기준 제시
같은 기술에도 수많은 옵션을 제공하는 스프링의 특성 때문에 기술 선택에 고민하는 개발자를 위해서 스프링이 제공하는 다양한 기술 옵션을 비교하고, 환경에 따른 적절한 선택을 위한 기준을 제공해준다.
★ @Enable 빈 설정 모듈화 기법 소개
스프링 3.1의 최신 자바코드 빈 설정 기법을 이용해서 재사용 가능한 빈 설정 모듈을 만드는 방법을 스프링 3.1에 적용된 실전 예를 기준으로 상세하게 설명한다.
★ 스프링 애플리케이션 아키텍처 설계와 스프링 기반 프레임워크 제작을 위한 완벽 가이드
스프링을 이용한 엔터프라이즈 애플리케이션 아키텍처 작성을 위한 다양한 아키텍처 소개와 전략 분석, 스프링을 기반으로 한 사내 프레임워크 제작에 꼭 필요한 스프링 확장 기법을 소개한다.
[ 이 책의 구성 ]
스프링이 공개된 지 이미 9년째이고 많은 개발자가 스프링을 사용해 애플리케이션을 개발해오고 있다. 그럼에도 적지 않은 수의 개발자들은 스프링의 핵심 가치와 혜택을 충분히 누리지 못하는 듯하다. 스프링의 가치를 제대로 누리며 사용하려면 스프링을 제대로 공부해야 한다. 스프링을 효과적으로 익히려면 다음의 세 가지 단계를 통해 스프링을 학습해야 한다.
▶ 스프링의 핵심 가치와 원리에 대한 이해
▶ 스프링의 기술에 대한 지식과 선택 기준 정립
▶ 스프링의 적용과 확장
이 책은 이 세 가지 단계를 따라서 스프링을 공부하려는 사람을 대상으로 쓰여진 책으로, Vol. 1에서는 첫 단계인 ‘핵심 가치와 원리에 대한 이해’를 중심으로 하고, Vol. 2에서는 두 번째 단계인 ‘스프링 기술에 대한 지식과 선택’을 집중해서 다룬다. 세 번째 단계인 확장에 대해서는 책의 여러 곳에서 다양한 전략과 예제, 힌트를 제공한다. 하지만 본격적으로 응용과 확장에 대한 지식을 쌓는 일은 독자들의 몫이다. 각자의 상황에 맞게 처음 두 단계에서 배운 지식을 응용해 스프링을 확장해보는 훈련을 해야 한다.
《Vol. 2 스프링의 기술과 선택》의 구성과 예제
Vol. 2에서는 스프링 프레임워크를 이용해 애플리케이션을 작성하는 다양한 방법을 살펴보고, 각 방법의 특징과 장단점을 설명한다. Vol. 2는 각 장마다 개별 기술을 독립적으로 설명하므로 원하는 장부터 살펴봐도 상관없다. 다만 1장은 스프링을 이용해 애플리케이션을 만들 때 반드시 알아야 할 애플리케이션 구조와 설정 방법을 설명하므로 다른 장으로 넘어가기 전에 먼저 살펴보기를 권장한다.
Vol. 2는 스프링이 제공하는 기술의 종류와 특징, 사용법에 대한 설명에 집중하고, 이를 이용해서 만들어지는 애플리케이션 코드의 패턴과 구조에 관한 내용은 Vol. 1에서 자세히 다루므로 Vol. 2에서 다루지 않는다. Vol. 2의 내용은 Vol. 1에서 설명한 내용을 이해하고 있다는 전제하에 작성됐다. 스프링의 개발 기술 내용을 빠르게 살펴보고 싶다면 Vol. 1을 보지 않고 Vol. 2를 먼저 봐도 되지만, 가능한 한 Vol. 1을 먼저 공부하고 Vol. 2의 내용을 보기를 권장한다.
Vol. 2의 내용은 대부분 스프링 3.0과 스프링 3.1 버전에 동일하게 적용할 수 있다. 스프링 3.1에만 적용되는 내용은 각 장의 마지막 절에서 따로 설명한다.
Vol. 2의 예제 코드는 두 가지로 구성된다.
첫째는 각 장에서 설명하는 스프링 기술의 사용 방법을 담은 학습 테스트다. 책에는 설명에 꼭 필요한 일정 분량의 코드만 소개되어 있다. 각 기술의 사용 방법을 담은 좀 더 다양한 코드는 소스코드 파일에 담긴 learningtest 프로젝트의 학습 테스트 코드를 참고하면 된다. 테스트 코드이지만 기술 학습용으로 작성됐으므로 이를 Vol. 2의 내용과 함께 살펴보면 스프링 기술의 사용 방법에 대한 아이디어를 얻을 수 있을 것이다. learningtest 프로젝트는 스프링 3.0으로 작성된 것과 스프링 3.1로 작성된 것, 두 가지가 제공된다.
둘째는 스프링 웹 기술인 스프링 MVC를 이용해 만든 웹 애플리케이션 예제인 springusergroup 프로젝트다. 이 프로젝트는 서버에서 동작하도록 만들어진 완전한 애플리케이션이다. 그렇다고 이 예제 프로젝트를 그대로 가져다 실전에서 활용하면 될 것이라고 기대해선 안 된다. 프로젝트를 구성할 때 참고하거나 프로젝트의 각 기술 영역에 대한 접근 방법이 자신의 상황과 일치한다면 일부를 활용할 수는 있겠지만, Vol. 2에서 줄곧 설명하는 대로 아키텍처와 계층구조, 사용할 기술, 설정 방법, 각 기술의 접근 방법은 각자의 상황과 환경에 맞게 선택해야 한다. springusergroup 예제의 목적은 스프링 MVC를 사용한 웹 프레젠테이션 계층의 개발과 이를 다른 계층과 어떻게 접목하는지에 관한 것임을 기억하자.
예제 프로젝트를 설치하고 사용하는 방법은 각 프로젝트 폴더의 readme.txt 파일을 참고하면 된다. 모든 예제 프로젝트는 JavaSE 1.6과 이클립스 기반의 STS(SpringSource Tool Suite)에서 작성됐다. STS는 http://www.springsource.com/products/sts에서 다운로드 받을 수 있다.
책의 예제에 사용한 DB는 MySQL 5.1 버전이다. 하지만 적절한 JDBC 드라이버를 추가하고 DB 연결정보를 수정해주면 그 밖의 DB를 사용해서 예제를 실행할 수 있다. DB를 변경하는 방법도 프로젝트 루트의 readme.txt 파일에 나와 있다.
별도 소스코드 제공
- 이 책에 들어 있는 모든 예제의 소스코드
- 스프링 3.0과 스프링 3.1의 기술 활용법을 보여주는 학습 테스트 코드
- 스프링 @MVC를 이용한 웹 애플리케이션 프로젝트
[ 이 책의 대상 독자 ]
이 책은 스프링을 이용해서 엔터프라이즈 자바 애플리케이션을 개발하려는 모든 개발자를 대상으로 한다. 이 책을 공부하기 위해서는 자바 언어와 JDBC를 이용한 DB 프로그래밍, 그리고 기초적인 웹 개발 지식이 필요하다. Vol. 2에는 스프링 외의 서드파티 프레임워크나 JavaEE 표준 기술을 스프링에 통합해서 사용하는 내용이 일부 포함되어 있다. 이런 내용을 살펴볼 때는 관련 기술에 대한 지식이 추가로 필요할 수 있다.
[ 스프링 3.1의 새로운 기능 ]
스프링 3.1에 추가된 주요한 기능과 특징은 다음과 같다.
강화된 자바 코드를 이용한 빈 설정
스프링 3.1은 스프링 3.0부터 지원하기 시작한 자바 코드를 이용한 빈 설정 방식을 대폭 확장해서 스프링 빈 설정의 거의 모든 영역으로 확대했다. 기존에 XML로 작성했던 스프링 설정 정보를 3.1에서는 자바 코드로 대체할 수 있다. XML을 전혀 사용하지 않고 스프링 애플리케이션을 작성할 수도 있다. 자바 코드를 이용한 빈 설정을 위해 다양한 애노테이션이 추가됐다. XML의 전용 커스텀 태그를 대체할 수 있는, @Enable로 시작하는 전용 애노테이션도 제공된다.
런타임 환경 추상화
스프링 애플리케이션이 실행되는 런타임 환경 정보를 추상화한 환경 오브젝트가 컨테이너를 통해 제공된다. 실행환경에 따라 달라지는 빈 설정을 효과적으로 관리할 수 있는 프로파일과 각종 프로퍼티 정보를 컨테이너를 통해 일관된 방식으로 제공할 수 있게 해주는 프로퍼티 소스가 환경 오브젝트가 제공하는 주요 기능이다.
JPA 지원 확장과 하이버네이트 4 지원
하이버네이트 4 지원 기능이 새롭게 추가됐다. JPA를 이용할 때보다 편리하게 설정정보를 작성할 수 있는 편리한 기능도 추가됐다.
새로운 DispatcherServlet 전략과 플래시 맵
스프링 3.0에서 사용되던 DispatcherServlet 전략의 일부가 새롭게 설계된 전략으로 대체됐다. 이를 통해 MVC 기능을 확장하기가 편리해졌다. Post/Redirect/Get 패턴에 사용할 수 있는 플래시 맵 기능도 추가됐다.
캐시 추상화
AOP를 이용한 메소드 레벨의 캐시 추상화 기능이 추가됐다. 이를 이용해 캐시 구현 기술에 독립적인 방식으로 애플리케이션 빈에 캐시 기능을 적용할 수 있게 됐다. 맵을 이용한 간단한 캐시 구현부터 ehcache를 이용한 고급 캐시 기술까지 지원한다.
[ 『토비의 스프링 3.1』 추천의 글 ]
스프링의 아버지 로드 존슨은 '객체지향 설계는 특정 구현기술보다, 심지어 자바보다도 더 중요하다.'고 말했다. 『토비의 스프링 3』 책은 그 가치를 잘 담아냈다. 테스트하기 쉬운 코드, 구성요소의 역할과 책임을 섬세하게 나누는 설계 등 이 책에서 강조하는 기법은 프로그래밍을 하는 사람이면 누구나 새겨볼 만한 내용이다. 거기에 비해 어쩌면 최신 기술의 소개라는 측면은 부차적일지도 모른다. 그럼에도 최신 스프링 3.1에 맞춰 개정판이 나온다는 소식은 반갑기 그지 없다. 이제 이 책이 단순히 흘러가는 트렌드를 잡는 책이 아니라 『수학의 정석』처럼 꾸준히 개정되며 늘 우리에게 지식과 통찰을 주는 스테디셀러로 자리 잡기를 기원한다.
- 정상혁 / NHN Technology Service 신규서비스 개발팀 차장
스프링 활용법뿐 아니라 그 원리까지 쉽게 이해할 수 있도록 풀어서 설명하는 이 책은 대규모 프로젝트에서 정형화된 업무 로직의 반복된 구현에 지친 SI 개발자 분들에게 학습의 즐거움과 더 나은 코드를 만들어가는 과정에서 실력이 늘어가는 개발의 재미를 다시금 느끼게 해줄 것입니다. 최근 들어서는 3.0에서 3.1, 3.2로 발전해 나가는 스프링의 발전 방향을 눈여겨 보는 분들도 많을 것입니다. 이처럼 매우 적절한 시기에 스프링 3.1을 다루는 개정판까지 나온다니, 클라우드, 빅데이터 등 점점 복잡해지는 IT 환경의 변화를 수용하기 위해 스프링이 어떻게 변해가는지도 이 책을 통해 엿볼 수 있을 것입니다.
- 김승권 / 금융분야 독립컨설턴트
[ 『토비의 스프링 3』 추천의 글 ]
저자인 이일민 씨를 아는 사람에게는 긴 설명이 필요 없겠지만, 잘 모르는 분을 위해 이 책의 고유한 가치를 몇 가지 떠올려봤다.
첫째, 뛰어난 강사이기도 한 저자의 효과적인 강의 스타일을 담아낸 책의 이야기 전개다. 저자는 대뜸 스프링이 가진 기술을 나열하기보단 친숙한 자바 코드(초난감 DAO)를 내밀었다. 책을 읽어가면 점차 독자는 흔히 쓰이던 코드의 문제점에 공감하고, 여러 가지 방식으로 개선해가는 여정을 함께한다. 책과 함께 고민한 독자라면 여정의 끝에서 스프링을 쓰는 이유와 어떤 게 올바른 사용법인지 배울 수 있다. 사실 이런 전개는 정말 뛰어난 외국 서적에서는 종종 볼 수 있는 방식이지만, 한글 기술서로 한정하면 가히 독보적이라 할 수 있다.
둘째, 사상과 활용법을 모두 담은 넓은 효용성이다. 시중에 두꺼운 기술서는 드물지 않지만, 이 책은 API 설명이나 화면 캡처로 지면을 할애하지 않았다. 책 전반부는 객체지향 프로그래밍 관점에서 어떤 코드가 좋은 코드인지를 다루면서 왜 스프링을 써야 하는지를 설명하고, 후반부는 스프링을 구성하는 요소 기술을 올바르게 사용하는 방법을 빠짐없이 설명하고 있음을 상기하면 책의 두께는 놀랍도록 얇다(?). 학습과제에만 초점을 맞출 수 있도록 구성한 장의 구성과 단계별 예제는 SoC(Separation of Concerns)를 통해 방대한 내용을 모두 담아내기 위해 저자가 각고해 노력한 결과물이다.
셋째, 책의 내용과 예제 코드의 정확함이다. 프로그래밍 서적으로 공부할 때 예제가 작동하지 않아 시간을 허비한 경험이 있는 개발자는 드물지 않다. 1부는 테스트 주도로 진행하고, 2부도 예제 전부가 테스트 코드 형태로 만들어져 결함을 막았다. 한편 개념 설명을 위해 다이어그램을 활용하고 코드에도 충분한 부연 설명을 붙인 결과, 섬세하고 정확한 내용이 만들어졌다.
변변한 책이 없던 시절 스프링을 이해하기 위해 어쩔 수 없이 스프링 소스코드를 봤다. 스프링 소스코드는 객체를 조직화하는 설계에 대한 모범답안과도 같았다. 하지만 방대한 코드만 보고 의도를 모두 익힐 수는 없었다. 그 후에 로드 존슨의 책을 반복해 읽으면서 스프링을 이해할수록 감탄하고 또 감탄했다. 다행스럽게도 지금 스프링을 공부하는 여러분에게는 더 나은 방법을 제시할 수 있다. 로드 존슨이 했던 이야기를 로드 존슨은 할 수 없는 우리말로 읽을 수 있다. 그리고 진정한 고수 개발자로 꾸준히 노력해온 이일민 씨의 노하우를 함께 배울 수 있다.
- 안영회 (http://younghoe.info)
한국스프링사용자모임공동설립자, (주)아이티와이즈컨설팅 컨설턴트
이 책은 스프링의 핵심 가치를 전달하는 데 집중하고 있다. 로드 존슨이 쓴 『J2EE Development without EJB』 이후로 지금까지 출간된 스프링 서적 중에서 이 책만큼 스프링의 핵심 가치를 제대로 전달한 책은 보지 못했다. 이 책은 스프링을 사용하지 않더라도 자바를 기반으로 애플리케이션을 개발하는 모든 개발자가 읽어야 하는 책이다. 그만큼 자바가 추구하고자 하는 핵심 가치에 집중하고 있는 책이다. 특히 이 책의 모든 소스코드에는 테스트 코드가 함께 들어 있다. 이는 테스트하기 쉬운 코드를 만들도록 유도하는 스프링의 강점을 보여주면서 테스트의 중요성을 자연스럽게 이야기하려는 저자의 의도이리라.
자바 기반의 엔터프라이즈 개발은 지금까지 많은 우여곡절을 겪으면서 먼 길을 돌아왔다. 이 책으로 인해 자바가 추구하고자 했던 초심으로 돌아갈 수 있는 계기가 됐으면 하는 바람이다.
- 박재성 / XLGames 웹 서비스 개발자
지난 10회 한국 스프링 사용자 모임 세미나 도입부 때 개회사를 겸한 간단한 발표를 하면서 저는 두 가지를 말했습니다. 스프링이 단순한 프레임워크가 아닌 플랫폼으로 발전했다는 사실과, 그럼에도 초기 스프링의 철학은 여전히 유효하고 더욱 강조돼야 하며 스프링 자체보다 중요하다는 점입니다.
스프링 사이트의 스프링 소개(About Spring)에서 확인할 수 있는 이 철학을 지금까지 로드 존스의 책을 제외한 어떤 스프링 관련 책에서도 충분히 다루지 않았습니다. 그래서 많은 사람이 스프링이 주는 이점과 즐거움을 누리지 못하면서 스프링을 쓰고 있습니다. 고맙게도 이일민 씨는 스프링이 무엇인지 명시적으로 설명하기를 8장으로 미루고 그보다 먼저, 친절하고 쉽게 그리고 감동적으로 스프링의 배경(좋은 객체지향 기법과 우수 실천법)을 설명합니다.
이일민 씨는 뛰어난 개발자이고 완벽주의자인 동시에 타고난 이야기꾼입니다. 전 이 책을 눈으로 읽으면서도 어떻게 이렇게 다양하고 방대한 내용이 한 책으로 엮일 수 있는지 이해할 수가 없습니다. 스프링을 닮은 책입니다.
- 박성철 / 한국 스프링 사용자 모임 큰일꾼
스프링을 처음 본 게 2003년이었는데 그때만 해도 아무도 지금처럼 스프링이 전 세계 애플리케이션 개발 시장에서 가장 영향력 있는 프레임워크로 성장하리라고 예측하지는 못했던 것 같다. 스프링이 성공할 수 있었던 가장 큰 요인 중 하나는 객체지향 원칙을 충실히 지켜내면서도 더 나아가 개발자의 자율성과 창의성을 극대화할 수 있는 유연한 구조를 지니고 있기 때문이다. 이 책은 스프링이 추구했던 이러한 내면의 원칙을 현실과 잘 맞추어 풀어낸 한 편의 흥미진진한 소설과도 같다. 이 시대의 아키텍트나 개발자라면 반드시 한 번은 꼭 읽어봐야 할 책이다.
- 김창제 / 삼성 SDS 수석, Anyframe Java 기획•개발 총괄
스프링은 이제 자바 개발의 필수 프레임워크로 자리 잡았다. 스프링은 자바의 객체지향적 사고와 애자일한 가치를 구현한 프레임워크이지만, 대부분 개발자는 필요한 템플릿을 수정하기만 할 뿐 스프링 프레임워크가 지향하는 가치와 동작원리를 충분히 이해하지 못한 채로 사용하고 있다. 이 책은 스프링을 배우는 데 필요한 DAO, AOP 같은 중요 개념의 이해를 시작으로 실전 프로젝트에 적용하는 방법까지 체계적으로 다루고 있다. 그리고 스프링의 학습법까지 친절히 다루는 등 곳곳에 저자 이일민 씨의 숨은 노력과 배려가 깃든 책으로 자바 개발자라면 꼭 읽어보길 권한다.
- 옥상훈 / 제4대 한국자바개발자 협의회 회장, 현 한국SW아키텍트 연합 공동회장
먼저, 저는 스프링을 전혀 모릅니다. J2EE 1.4, JavaEE 5, 그리고 JavaEE 6까지, 기술 표준과 구현에 참여하고 관심을 둬왔던 저로서는, JavaEE(특히 EJB)의 안티테제로 시작한 스프링에 어느 정도 반감이 있었고, 그래서 의도적으로 알려 하기를 꺼렸습니다.
하지만 티맥스를 떠나 오픈마루에서 웹 서비스 개발을 하게 되자 스프링은 당면한 과제가 돼버렸습니다. 루비온레일스로 비켜가 보기도 했지만, 결국 자바 플랫폼으로 가게 됐습니다. 제가 아무리 JavaEE만으로 개발하자고 주장해도, 결국 스프링을 채택하기에 이르렀습니다.
토비님의 블로그 또한 자바와 비자바를 떠나 많은 개발자에게 감명을 줬습니다. 그리고 그 이면에 담긴 JavaEE의 한계와 문제점은 실은 저를 부끄럽게 만들기 충분했지요. 무엇보다도 그 깊이, 토비님이 보여주신 그 깊이가 저는 한없이 부러웠고 존경스러웠습니다. 저는 이 책의 1장을 읽었습니다. 이제서야 스프링이 뭔지를 겨우 알아가게 되다니, 마치 요새 “맥주 맛도 모르면서”의 광고 카피처럼 말입니다.
이 책이 독자에게 영감과 격려를 주리라 믿습니다.
- 이창신 / ias(iNDIE aPPLICATION sOFTWARE) 대표
먼저, 기다려온 스프링 3 서적의 출간을 축하합니다. 스프링 2.5 버전을 경험했던 사람으로 달라진 기능은 무엇인지, 하위 버전과의 호환성 보장을 위해 어떻게 확장되고 발전됐는지, 새로운 버전이 나올 때마다 갖게 되는 궁금증에 대해 명쾌한 해답을 얻을 수 있는 좋은 기회가 됐습니다. 또한 스프링의 각 개념이 예제 중심으로 잘 설명되어 있어 스프링을 처음 접하는 분들도 쉽게 다가갈 수 있으리라 생각되며, 이전 버전 경험자 분들에게는 스프링이 확장 포인트를 어떻게 응용하면서 업그레이드됐는지 배울 수 있는 좋은 기회가 되리라 생각합니다. 다시 한번 『토비의 스프링 3』 출간을 축하하며, 스프링을 도입하거나 스프링 3.0으로 버전 업그레이드를 고려하고 있는 많은 개발자의 고민을 조금이나마 덜어줄 수 있기를 기대합니다.
- 이봉옥 책임 / 전자정부 표준프레임워크 커미터 삼성SDS
이 책을 통해 개발자들은 리팩토링과 디자인 패턴, 객체지향 핵심 원칙도 자연스럽게 접하면서, 책에 담긴 내용을 자신의 것으로 받아들일 것이라고 생각한다. 원칙과 코드를 잘 어울리게 설명한 대목에서는 누구나 내공을 느끼게 할 만큼 쉽고 깊이 있게 풀어낸 책이기에, 초보 개발자는 물론 연차가 오래됐지만 기초가 부족하다고 느끼는 개발자에게 적극적으로 권해주고 싶다.
독자들이 이 책을 마칠 즈음엔 스프링을 배우러 왔다가 객체지향이라는 월척을 낚았다고 웃으며 책장을 덮게 될 것이라고 확신한다. 아울러 지금까지 써왔던 방식과 달리 스프링에서 주고자 했던 핵심 가치를 느끼며 코딩하고 있는 자신을 발견하리라고 조심스럽게 상상해본다.
- 양수열 / 인피언컨설팅 연구소장, JCO 3대회장•현 고문
저는 스프링은 잘 모르지만 토비 형님과 에이콘 출판사를 잘 알기에 이 책을 자신 있게 권해드릴 수 있습니다. 토비 형님은 어려운 내용을 쉽게 설명하는 마력을 가진 사람입니다. 사실 쉬운 내용도 어렵게 설명하는 분들이 워낙 많기에 그의 글이 더욱 빛납니다.
두 개의 부로 구성된 이 책의 1부는 그의 그런 장점을 잘 녹여내어 처음 시작하는 자바 개발자도 쉽게 내용을 이해할 수 있습니다. 2부는 실제 프로젝트에 적용하는 데 필요한 내용을 담고 있습니다. 또한 고심에 고심을 거듭하여 만든 예제들은 프로젝트를 진행하는 데 적잖은 도움을 드릴 것입니다.
이 책을 구입한 모든 분들이 한 단계 더 발전하는 좋은 계기가 되길 바라겠습니다.
대한민국 개발자 파이팅!
- 정희용 / 월간 마이크로소프트웨어 발행인
책을 펴기도 전에, 1400페이지가 넘는 이 책의 두께와 무게에 지레 겁을 먹은 독자분도 있을 것이다. 하지만 걱정하지 말자. 이 책이 이토록 두껍고 무거워진 건 모두 다 우리를 위한 배려 때문이고, 그 방대한 양만큼이나 매우 친절한 책이다. 스프링을 학습하는 데 있어 중요한 내용을 이렇게까지 차근차근 그리고 점진적으로 쉽게 설명해주는 책은 여태 없었다. 진작에 이런 책으로 스프링 공부를 시작했다면 내가 스프링에 쏟아온 학습 시간이 한층 줄어들었을 게 분명하다.
이 책의 가치는 여러 번 반복해 읽었을 때 더욱 빛을 발한다. 저자의 의도는 단순히 스프링을 설명하는 데 그치지 않는다. 이 책에서는 객체지향적인 코드, 프레임워크의 개념 정립, 테스트가 주는 장점 등을 고스란히 엿볼 수 있다. 물론 우리가 스프링만 가지고서는 아무것도 할 수 없다. 결국은 다른 코드와 버무려 맛있는 코드를 만들어야 한다. 이를 간파한 저자는 바로 그때 어떻게 하면 개발자들이 좀 더 가치 있고 유익한 코드를 작성할 수 있는지 이 책에서 잘 설명한다. 팁을 하나 더 드리자면, 별도로 제공되는 소스코드는 꼭 확인하기 바란다. 나중에 기회가 되면 봄싹 모임에서 스터디로 진행하고 싶을 정도로 멋지고 유용한 코드가 독자를 기다린다. 마치 잠자는 책 속의 코드처럼…
- 백기선 / 봄싹 커뮤니티(springsprout.org) 대표, 스프링프레임워크 강사
목차
목차
- 1장 IoC 컨테이너와 DI
- 1.1 IoC 컨테이너: 빈 팩토리와 애플리케이션 컨텍스트
- 1.1.1 IoC 컨테이너를 이용해 애플리케이션 만들기
- POJO 클래스
- 설정 메타정보
- 1.1.2 IoC 컨테이너의 종류와 사용 방법
- StaticApplicationContext
- GenericApplicationContext
- GenericXmlApplicationContext
- WebApplicationContext
- 1.1.3 IoC 컨테이너 계층구조
- 부모 컨텍스트를 이용한 계층구조 효과
- 컨텍스트 계층구조 테스트
- 1.1.4 웹 애플리케이션의 IoC 컨테이너 구성
- 웹 애플리케이션의 컨텍스트 계층구조
- 웹 애플리케이션의 컨텍스트 구성 방법
- 루트 애플리케이션 컨텍스트 등록
- 서블릿 애플리케이션 컨텍스트 등록
- 1.1.1 IoC 컨테이너를 이용해 애플리케이션 만들기
- 1.2 IoC/DI를 위한 빈 설정 메타정보 작성
- 1.2.1 빈 설정 메타정보
- 빈 설정 메타정보 항목
- 1.2.2 빈 등록 방법
- XML: 《bean》 태그
- XML: 네임스페이스와 전용 태그
- 자동인식을 이용한 빈 등록: 스테레오타입 애노테이션과 빈 스캐너
- 자바 코드에 의한 빈 등록: @Configuration 클래스의 @Bean 메소드
- 자바 코드에 의한 빈 등록: 일반 빈 클래스의 @Bean 메소드
- 빈 등록 메타정보 구성 전략
- 1.2.3 빈 의존관계 설정 방법
- XML: 《property》, 《constructor-arg》
- XML: 자동와이어링
- XML: 네임스페이스와 전용 태그
- 애노테이션: @Resource
- 애노테이션: @Autowired/@Inject
- @Autowired와 getBean(), 스프링 테스트
- 자바 코드에 의한 의존관계 설정
- 빈 의존관계 설정 전략
- 1.2.4 프로퍼티 값 설정 방법
- 메타정보 종류에 따른 값 설정 방법
- PropertyEditor와 ConversionService
- 컬렉션
- Null과 빈 문자열
- 프로퍼티 파일을 이용한 값 설정
- 1.2.5 컨테이너가 자동등록하는 빈
- ApplicationContext, BeanFactory
- ResourceLoader, ApplicationEventPublisher
- systemProperties, systemEnvironment
- 1.2.1 빈 설정 메타정보
- 1.3 프로토타입과 스코프
- 1.3.1 프로토타입 스코프
- 프로토타입 빈의 생명주기와 종속성
- 프로토타입 빈의 용도
- DI와 DL
- 프로토타입 빈의 DL 전략
- 1.3.2 스코프
- 스코프의 종류
- 스코프 빈의 사용 방법
- 커스텀 스코프와 상태를 저장하는 빈 사용하기
- 1.3.1 프로토타입 스코프
- 1.4 기타 빈 설정 메타정보
- 1.4.1 빈 이름
- XML 설정에서의 빈 식별자와 별칭
- 애노테이션에서의 빈 이름
- 1.4.2 빈 생명주기 메소드
- 초기화 메소드
- 제거 메소드
- 1.4.3 팩토리 빈과 팩토리 메소드
- 1.4.1 빈 이름
- 1.5 스프링 3.1의 Ioc 컨테이너와 DI
- 1.5.1 빈의 역할과 구분
- 빈의 종류
- 컨테이너 인프라 빈과 전용 태그
- 빈의 역할
- 1.5.2 컨테이너 인프라 빈을 위한 자바 코드 메타정보
- IoC/DI 설정 방법의 발전
- 자바 코드를 이용한 컨테이너 인프라 빈 등록
- 1.5.3 웹 애플리케이션의 새로운 IoC 컨테이너 구성
- 1.5.4 런타임 환경 추상화와 프로파일
- 환경에 따른 빈 설정정보 변경 전략과 한계
- 런타임 환경과 프로파일
- 활성 프로파일 지정 방법
- 프로파일 활용 전략
- 1.5.5 프로퍼티 소스
- 프로퍼티
- 스프링에서 사용되는 프로퍼티의 종류
- 프로파일의 통합과 추상화
- 프로퍼티 소스의 사용
- @PropertySource와 프로퍼티 파일
- 웹 환경에서 사용되는 프로퍼티 소스와 프로퍼티 소스 초기화 오브젝트
- 1.5.1 빈의 역할과 구분
- 1.6 정리
- 1.1 IoC 컨테이너: 빈 팩토리와 애플리케이션 컨텍스트
- 2장 데이터 액세스 기술
- 2.1 공통 개념
- 2.1.1 DAO 패턴
- DAO 인터페이스와 DI
- 예외처리
- 2.1.2 템플릿과 API
- 2.1.3 DataSource
- 학습 테스트와 통합 테스트를 위한 DataSource
- 오픈소스 또는 상용 DB 커넥션 풀
- JDNI/WAS DB 풀
- 2.1.1 DAO 패턴
- 2.2 JDBC
- 2.2.1 스프링 JDBC 기술과 동작원리
- 스프링의 JDBC 접근 방법
- 스프링 JDBC가 해주는 작업
- 2.2.2 SimpleJdbcTemplate
- SimpleJdbcTemplate 생성
- SQL 파라미터
- SQL 실행 메소드
- SQL 조회 메소드
- SQL 배치 메소드
- 2.2.3 SimpleJdbcInsert
- SimpleJdbcInsert 생성
- SimpleJdbcInsert 실행
- 2.2.4 SimpleJdbcCall
- SimpleJdbcCall 생성
- SimpleJdbcCall 실행
- 2.2.5 스프링 JDBC DAO
- 2.2.1 스프링 JDBC 기술과 동작원리
- 2.3 iBatis SqlMaps
- 2.3.1 SqlMapClient 생성
- iBatis 설정파일과 매핑파일
- SqlMapClient를 위한 SqlMapClientFactoryBean 등록
- 2.3.2 SqlMapClientTemplate
- 등록, 수정, 삭제
- 조회
- SqlMapClientCallback
- 2.3.1 SqlMapClient 생성
- 2.4 JPA
- 2.4.1 EntityManagerFactory 등록
- LocalEntityManagerFactoryBean
- JavaEE 5 서버가 제공하는 EntityManagerFactory
- LocalContainerEntityManagerFactoryBean
- 트랜잭션 매니저
- 2.4.2 EntityManager와 JpaTemplate
- JpaTemplate
- 애플리케이션 관리 EntityManager와 @PersistenceUnit
- 컨테이너 관리 EntityManager와 @PersistenceContext
- @PersistenceContext와 확장된 퍼시스턴스 컨텍스트
- JPA 예외 변환
- JPA 예외 변환 AOP
- 2.4.1 EntityManagerFactory 등록
- 2.5 하이버네이트
- 2.5.1 SessionFactory 등록
- LocalSessionFactoryBean
- AnnotationSessionFactoryBean
- 트랜잭션 매니저
- 2.5.2 Session과 HibernateTemplate
- HibernateTemplate
- SessionFactory.getCurrentSession()
- 2.5.1 SessionFactory 등록
- 2.6 트랜잭션
- 2.6.1 트랜잭션 추상화와 동기화
- PlatformTransactionManager
- 트랜잭션 매니저의 종류
- 2.6.2 트랜잭션 경계설정 전략
- 코드에 의한 트랜잭션 경계설정
- 선언적 트랜잭션 경계설정
- 프록시 모드: 인터페이스와 클래스
- AOP 방식: 프록시와 AspectJ
- 2.6.3 트랜잭션 속성
- 트랜잭션 전파: propagation
- 트랜잭션 격리수준: isolation
- 트랜잭션 제한시간: timeout
- 읽기전용 트랜잭션: read-only, readOnly
- 트랜잭션 롤백 예외: rollback-for, rollbackFor, rollbackForClassName
- 트랜잭션 커밋 예외: no-rollback-for, noRollbackFor, noRollbackForClassName
- 2.6.4 데이터 액세스 기술 트랜잭션의 통합
- 트랜잭션 매니저별 조합 가능 기술
- ORM과 비 ORM DAO를 함께 사용할 때의 주의사항
- 2.6.5 JTA를 이용한 글로벌/분산 트랜잭션
- 독립형 JTA 트랜잭션 매니저
- WAS 트랜잭션 매니저의 고급 기능 사용하기
- 2.6.1 트랜잭션 추상화와 동기화
- 2.7 스프링 3.1의 데이터 액세스 기술
- 2.7.1 persistence.xml 없이 JPA 사용하기
- 2.7.2 하이버네이트 4 지원
- LocalSessionFactoryBean
- LocalSessionFactoryBuilder
- 2.7.3 @EnableTransactionManager 295
- 2.8 정리
- 2.1 공통 개념
- 3장 스프링 웹 기술과 스프링 MVC
- 3.1 스프링의 웹 프레젠테이션 계층 기술
- 3.1.1 스프링에서 사용되는 웹 프레임워크의 종류
- 스프링 웹 프레임워크
- 스프링 포트폴리오 웹 프레임워크
- 스프링을 기반으로 두지 않는 웹 프레임워크
- 3.1.2 스프링 MVC와 DispatcherServlet 전략
- DispatcherServlet과 MVC 아키텍처
- DispatcherServlet의 DI 가능한 전략
- 3.1.1 스프링에서 사용되는 웹 프레임워크의 종류
- 3.2 스프링 웹 애플리케이션 환경 구성
- 3.2.1 간단한 스프링 웹 프로젝트 생성
- 루트 웹 애플리케이션 컨텍스트
- 서블릿 웹 애플리케이션 컨텍스트 등록
- 스프링 웹 프로젝트 검증
- 3.2.2 스프링 웹 학습 테스트
- 서블릿 테스트용 목 오브젝트
- 테스트를 위한 DispatcherServlet 확장
- ConfigurableDispatcherServlet을 이용한 스프링 MVC 테스트
- 편리한 DispatcherServlet 테스트를 위한 AbstractDispatcherServletTest
- 3.2.1 간단한 스프링 웹 프로젝트 생성
- 3.3 컨트롤러
- 3.3.1 컨트롤러의 종류와 핸들러 어댑터
- Servlet과 SimpleServletHandlerAdapter
- HttpRequestHandler와 HttpRequestHandlerAdapter
- Controller와 SimpleControllerHandlerAdapter
- AnnotationMethodHandlerAdapter
- 3.3.2 핸들러 매핑
- BeanNameUrlHandlerMapping
- ControllerBeanNameHandlerMapping
- ControllerClassNameHandlerMapping
- SimpleUrlHandlerMapping
- DefaultAnnotationHandlerMapping
- 기타 공통 설정정보
- 3.3.3 핸들러 인터셉터
- HandlerInterceptor
- 핸들러 인터셉터 적용
- 3.3.4 컨트롤러 확장
- 커스텀 컨트롤러 인터페이스와 핸들러 어댑터 개발
- 3.3.1 컨트롤러의 종류와 핸들러 어댑터
- 3.4 뷰
- 3.4.1 뷰
- InternalResourceView와 JstlView
- RedirectView
- VelocityView, FreeMarkerView
- MarshallingView
- AbstractExcelView, AbstractJExcelView, AbstractPdfView
- AbstractAtomFeedView, AbstractRssFeedView
- XsltView, TilesView, AbstractJasperReportsView
- MappingJacksonJsonView
- 3.4.2 뷰 리졸버
- InternalResourceViewResolver
- VelocityViewResolver, FreeMarkerViewResolver
- ResourceBundleViewResolver, XmlViewResolver, BeanNameViewResolver
- ContentNegotiatingViewResolver
- 3.4.1 뷰
- 3.5 기타 전략
- 3.5.1 핸들러 예외 리졸버
- AnnotationMethodHandlerExceptionResolver
- ResponseStatusExceptionResolver
- DefaultHandlerExceptionResolver
- SimpleMappingExceptionResolver
- 3.5.2 지역정보 리졸버
- 3.5.3 멀티파트 리졸버
- RequestToViewNameTranslator
- 3.5.1 핸들러 예외 리졸버
- 3.6 스프링 3.1의 MVC
- 3.6.1 플래시 맵 매니저 전략
- 플래시 맵
- 플래시 맵 매니저
- 플래시 맵 매니저 전략
- 3.6.2 WebApplicationInitializer를 이용한 컨텍스트 등록
- 루트 웹 컨텍스트 등록
- 서블릿 컨텍스트 등록
- 3.6.1 플래시 맵 매니저 전략
- 3.7 정리
- 3.1 스프링의 웹 프레젠테이션 계층 기술
- 4장 스프링 @MVC
- 4.1 @RequestMapping 핸들러 매핑
- 4.1.1 클래스/메소드 결합 매핑정보
- @RequestMapping 애노테이션
- 타입 레벨 매핑과 메소드 레벨 매핑의 결합
- 메소드 레벨 단독 매핑
- 타입 레벨 단독 매핑
- 4.1.2 타입 상속과 매핑
- 매핑정보 상속의 종류
- 제네릭스와 매핑정보 상속을 이용한 컨트롤러 작성
- 4.1.1 클래스/메소드 결합 매핑정보
- 4.2 @Controller
- 4.2.1 메소드 파라미터의 종류
- HttpServletRequest, HttpServletResponse
- HttpSession
- WebRequest, NativeWebRequest
- Locale
- InputStream, Reader
- OutputStream, Writer
- @PathVariable
- @RequestParam
- @CookieValue
- @RequestHeader
- Map, Model, ModelMap
- @ModelAttribute
- Errors, BindingResult
- SessionStatus
- @RequestBody
- @Value
- @Valid
- 4.2.2 리턴 타입의 종류
- 자동 추가 모델 오브젝트와 자동생성 뷰 이름
- ModelAndView
- String
- void
- 모델 오브젝트
- Map/Model/ModelMap
- View
- @ResponseBody
- 4.2.3 @SessionAttributes와 SessionStatus
- 도메인 중심 프로그래밍 모델과 상태 유지를 위한 세션 도입의 필요성
- @SessionAttributes
- SessionStatus
- 등록 폼을 위한 @SessionAttributes 사용
- 스프링 목 오브젝트와 AbstractDispatcherServletTest를 이용해 세션 테스트 만들기
- 4.2.1 메소드 파라미터의 종류
- 4.3 모델 바인딩과 검증
- 4.3.1 PropertyEditor
- 디폴트 프로퍼티 에디터
- 커스텀 프로퍼티 에디터
- @InitBinder
- WebBindingInitializer
- 프로토타입 빈 프로퍼티 에디터
- 4.3.2 Converter와 Formatter
- Converter
- ConversionService
- Formatter와 FormattingConversionService
- 바인딩 기술의 적용 우선순위와 활용 전략
- 4.3.3 WebDataBinder 설정 항목
- allowedFields, disallowedFields
- requiredFields
- fieldMarkerPrefix
- fieldDefaultPrefix
- 4.3.4 Validator와 BindingResult, Errors
- Validator
- JSR-303 빈 검증 기능
- BindingResult와 MessageCodeResolver
- MessageSource
- 4.3.5 모델의 일생
- HTTP 요청으로부터 컨트롤러 메소드까지
- 컨트롤러 메소드로부터 뷰까지
- 4.3.1 PropertyEditor
- 4.4 JSP 뷰와 form 태그
- 4.4.1 EL과 spring 태그 라이브러리를 이용한 모델 출력
- JSP EL
- 스프링 SpEL
- 지역화 메시지 출력
- 4.4.2 spring 태그 라이브러리를 이용한 폼 작성
- 단일 폼 모델
- 《spring:bind》와 BindingStatus
- 4.4.3 form 태그 라이브러리
- 《form:form》
- 《form:input》
- 《form:label》
- 《form:errors》
- 《form:hidden》
- 《form:password》, 《form:textarea》
- 《form:checkbox》, 《form:checkboxes》
- 《form:radiobutton》, 《form:radiobuttons》
- 《form:select》, 《form:option》, 《form:options》
- 커스텀 UI 태그 만들기
- 4.4.1 EL과 spring 태그 라이브러리를 이용한 모델 출력
- 4.5 메시지 컨버터와 AJAX
- 4.5.1 메시지 컨버터의 종류
- JSON을 이용한 AJAX 컨트롤러: GET + JSON
- JSON을 이용한 AJAX 컨트롤러: POST(JSON) + JSON
- 4.5.1 메시지 컨버터의 종류
- 4.6 mvc 네임스페이스
- 《mvc:annotation-driven》
- 《mvc:interceptors》
- 《mvc:view-controller》
- 4.7 @MVC 확장 포인트
- 4.7.1 AnnotationMethodHandlerAdapter
- SessionAttributeStore
- WebArgumentResolver
- ModelAndViewResolver
- 4.7.1 AnnotationMethodHandlerAdapter
- 4.8 URL과 리소스 관리
- 4.8.1 《mvc:default-servlet-handler/》를 이용한 URL 관리
- 디폴트 서블릿과 URL 매핑 문제
- 《mvc:default-servlet-handler/》
- 4.8.2 《url:resource/》를 이용한 리소스 관리
- 4.8.1 《mvc:default-servlet-handler/》를 이용한 URL 관리
- 4.9 스프링 3.1의 @MVC
- 4.9.1 새로운 RequestMapping 전략
- @RequestMapping 메소드와 핸들러 매핑 전략의 불일치
- HandlerMethod
- @RequestMapping 전략 선택
- 4.9.2 @RequestMapping 핸들러 매핑: RequestMappingHandlerMapping
- 요청 조건
- 요청 조건의 결합 방식
- 4.9.3 @RequestMapping 핸들러 어댑터
- 파라미터 타입
- 확장 포인트
- 4.9.4 @EnableWebMvc와 WebMvcConfigurationSupport를 이용한 @MVC 설정
- @EnableWebMvc와 WebMvcConfigurer
- @MVC 설정자 빈 등록 방법
- @MVC 전략용 설정 빈 등록
- 4.9.1 새로운 RequestMapping 전략
- 4.10 정리
- 4.1 @RequestMapping 핸들러 매핑
- 5장 AOP와 LTW
- 5.1 애스펙트 AOP
- 5.1.1 프록시 기반 AOP
- 프록시 기반 AOP 개발 스타일의 종류와 특징
- 자동 프록시 생성기와 프록시 빈
- 프록시의 종류
- 5.1.2 @AspectJ AOP
- @AspectJ를 이용하기 위한 준비사항
- @Aspect 클래스와 구성요소
- 포인트컷 메소드와 애노테이션
- 어드바이스 메소드와 애노테이션
- 파라미터 선언과 바인딩
- @AspectJ를 이용한 AOP의 학습 방법과 적용 전략
- 5.1.1 프록시 기반 AOP
- 5.2 AspectJ와 @Configurable
- 5.2.1 AspectJ AOP
- 5.2.2 빈이 아닌 오브젝트에 DI 적용하기
- DI 애스펙트
- @Configurable
- 로드타임 위버와 자바 에이전트
- 5.3 로드타임 위버(LT)
- 5.4 스프링 3.1의 AOP와 LTW
- 5.4.1 AOP와 LTW를 위한 애노테이션
- @EnableAspectJAutoProxy
- @EnableLoadTimeWeaving
- 5.4.1 AOP와 LTW를 위한 애노테이션
- 5.5 정리
- 5.1 애스펙트 AOP
- 6장 테스트 컨텍스트 프레임워크
- 6.1 테스트 컨텍스트 프레임워크
- 6.1.1 테스트 프레임워크와 컨텍스트 테스트
- 테스트용 애플리케이션 컨텍스트 캐싱과 설정파일
- 컨텍스트 설정의 상속과 컨텍스트 로더
- 6.1.2 테스트 코드의 테스트 컨텍스트 활용
- 테스트 컨텍스트로부터 DI 받기
- 공유 컨텍스트 사용 시 주의할 점
- 6.1.1 테스트 프레임워크와 컨텍스트 테스트
- 6.2 트랜잭션 지원 테스트
- 6.2.1 테스트의 트랜잭션 지원 필요성
- DAO 단독 테스트
- 롤백 테스트
- 6.2.2 트랜잭션 지원 테스트 작성 방법
- 트랜잭션 매니저
- @Transactional 테스트
- ORM 롤백 트랜잭션 테스트의 주의사항
- 트랜잭션 지원 테스트에 DBUnit 이용하기
- 6.2.1 테스트의 트랜잭션 지원 필요성
- 6.3 스프링 3.1의 컨텍스트 테스트 프레임워크
- 6.3.1 자바 코드 설정정보와 프로파일 활용
- @Configuration 클래스 테스트
- @ActiveProfile
- 6.3.1 자바 코드 설정정보와 프로파일 활용
- 6.4 정리
- 6.1 테스트 컨텍스트 프레임워크
- 7장 스프링의 기타 기술과 효과적인 학습 방법
- 7.1 스프링 기술과 API를 효과적으로 학습하는 방법
- 7.1.1 빈으로 등록되는 스프링 클래스와 DI
- 구현 인터페이스 분석
- 프로퍼티 분석
- DI/확장 포인트 분석
- 7.1.1 빈으로 등록되는 스프링 클래스와 DI
- 7.2 IoC 컨테이너 DI
- 7.2.1 BeanPostProcessor와 BeanFactoryPostProcessor
- BeanPostProcessor
- BeanFactoryPostProcessor
- 7.2.1 BeanPostProcessor와 BeanFactoryPostProcessor
- 7.3 SpEL
- 7.3.1 SpEL 사용 방법
- 7.4 OXM
- 7.4.1 Marshaller/Unmarshaller 인터페이스
- 7.4.2 OXM 기술 어댑터 클래스
- 7.5 리모팅과 웹 서비스, EJB
- 7.5.1 익스포터와 프록시
- 익스포터
- 프록시
- 7.5.2 RESTful 서비스 템플릿
- 7.5.3 EJB 서비스 이용
- 7.5.1 익스포터와 프록시
- 7.6 태스크 실행과 스케줄링
- 7.6.1 TaskExecutor 서비스 추상화
- 7.6.2 TaskScheduler
- 7.6.3 task 네임스페이스
- 《task:executor》
- 《task:scheduler》
- 《task:scheduled-tasks》와 《task:scheduled》
- 7.6.4 애노테이션을 이용한 스케줄링과 비동기 태스크 실행
- @Scheduled
- @Async
- 7.7 캐시 추상화(스프링 3.1)
- 7.7.1 애노테이션을 이용한 캐시 속성 부여
- @Cacheable
- @CacheEvict와 @CachePut
- 애노테이션을 이용한 캐시 기능 설정
- 7.7.2 캐시 매니저
- 7.7.1 애노테이션을 이용한 캐시 속성 부여
- 7.8 @Enable 애노테이션을 이용한 빈 설정정보 모듈화
- 7.8.1 @Import와 @Configuration 상속
- @Import를 이용한 단순 재사용
- @Configuration 클래스 상속과 오버라이딩을 이용한 확장 방법
- 7.8.2 @Enable 전용 애노테이션과 ImportAware
- @Enable 애노테이션 적용
- ImportAware 인터페이스를 이용한 옵션 지정
- 7.8.3 빈 설정자
- 7.8.4 ImportSelector와 ImportBeanDefinitionRegistrar
- 7.8.1 @Import와 @Configuration 상속
- 7.9 정리
- 7.1 스프링 기술과 API를 효과적으로 학습하는 방법
- 부록 A 스프링 모듈
- A.1 스프링 모듈의 종류와 특징
- A.1.1 스프링 모듈 이름
- A.1.2 스프링 모듈 추가
- 수동 추가
- Maven/Ivy 자동 추가
- A.1.3 스프링 모듈 목록
- A.2 스프링 모듈의 의존관계
- A.2.1 모듈별 의존관계
- ASM 모듈
- Core 모듈
- Beans 모듈
- AOP 모듈
- Expression 모듈
- Context 모듈
- Context.Support 모듈
- Transaction 모듈
- JDBC 모듈
- ORM 모듈
- Web 모듈
- Web.Servlet 모듈
- Web.Portlet 모듈
- Web.Struts 모듈
- JMS 모듈
- Aspects 모듈
- Instrument 모듈
- Instrument.Tomcat 모듈
- Test 모듈
- A.2.1 모듈별 의존관계
- A.1 스프링 모듈의 종류와 특징
- 부록 B 스프링 의존 라이브러리
- B.1 의존 라이브러리의 종류와 특징
- B.1.1 의존 라이브러리 이름
- B.1.2 의존 라이브러리 추가
- 수동 추가
- 자동 추가
- B.2 모듈별 의존 라이브러리 의존관계
- B.2.1 필수 라이브러리
- B.2.2 모듈별 선택 라이브러리
- ASM 모듈
- Core 모듈
- Beans 모듈
- AOP 모듈
- Expression 모듈
- Context 모듈
- Context.Support 모듈
- Transaction 모듈
- JDBC 모듈
- ORM 모듈
- Web 모듈
- Web.Servlet 모듈
- Web.Portlet 모듈
- Web.Struts 모듈
- JMS 모듈
- Aspects 모듈
- Instrument 모듈
- Instrument.Tomcat 모듈
- B.1 의존 라이브러리의 종류와 특징
도서 오류 신고
정오표
정오표
1쇄 오류/오탈자
[ p108 아래에서 3-4행 ]
스프링 3.0에는 아직 그런 기능이 제공되지 않는다. 필요하다면 각 전용 태그를 처리하는 소스를 참고해서 만들어볼 수 있을 것이다.
→ 그런데 전용 태그에 대응되는 @Configuration 자바 클래스 설정 방식은 스프링 3.1부터 제공된다. 스프링 3.0에서는 필요하다면 태그를 처리하는 소스를 참고해서 직접 만들어볼 수 있을 것이다.
[ p138 첫 번째 소스코드 ]
"Spring"이라는 값을 주입니다. → "Everyone"이라는 값을 주입한다.
[ p141 리스트 1-62 2행 ]
public Hello hello(@Value("${database.username}" String name) {
→ public Hello hello(@Value("${database.username}") String name) {
[ p184 마지막 행, p185 세 번째 소스코드 4행, 다섯 번째 소스코드 2행 ]
public void UserDao userDao() { → public UserDao userDao() {
[ p246 아래서 9행 ]
SimpleSqlInsert
→
SimpleJdbcInsert
[ p505 리스트 4-35 6행 ]
String name = request.getParameter("hello"); → String name = request.getParameter("name");
2쇄 오류/오탈자
[ p116 'XML:네임스페이스와 전용 태그' 절 2행 ]
태그나 → 태그가
[ p489 5행 ]
@ReqpestParam → @RequestParam