장바구니 담기 close

장바구니에 상품을 담았습니다.

Spring Security 3/e

Spring Security 3/e

  • 믹넛슨
  • |
  • 에이콘출판
  • |
  • 2019-01-29 출간
  • |
  • 624페이지
  • |
  • 188 X 235 X 30 mm
  • |
  • ISBN 9791161752488
판매가

40,000원

즉시할인가

36,000

카드할인

0원(즉시할인 0%)

적립금

2,000원 적립(5%적립)

배송비

무료배송

(제주/도서산간 배송 추가비용:3,000원)

추가혜택

네이버페이 무조건 1%적립+ 추가 1%적립

수량
+ -
총주문금액
36,000

※ 스프링제본 상품은 반품/교환/환불이 불가능하므로 신중하게 선택하여 주시기 바랍니다.

출판사서평




★ 이 책에서 다루는 내용 ★
■ 일반적인 보안 취약점 및 해결 방법
■ 모의해킹을 통한 보안 취약점 발견 방법
■ 인증 및 권한 부여 구현
■ LDAP, Active Directory, CAS, OpenID 및 OAuth와 같은 기존의 기업 인프라 구성 요소 사용 방법
■ Spring, Spring-boot 및 Spring-data와 같은 보편적인 프레임워크 연동
■ RESTful 웹 서비스 및 마이크로서비스 아키텍처의 보안 문제
■ LDAP, Apache Directory server 및 SAML과 같은 다른 보안 인프라 구성 요소와 스프링 연동

★ 이 책의 대상 독자 ★
자바 웹 및 RESTful 웹 서비스의 개발자이고, 자바 8, 자바 웹 및 RESTful 웹 서비스 애플리케이션, XML 및 스프링 프레임워크의 생성에 대한 지식이 있는 사람이면 누구에게나 도움이 될 것이며, 스프링 시큐리티에 대한 어떠한 경험도 필요하지 않다.

★ 이 책의 구성 ★
1장, ‘취약한 애플리케이션의 구조’에서는 달력 애플리케이션에 대한 가상 보안 감사를 다루며, 스프링 시큐리티를 적용해 해결할 수 있는 일반적인 보안 문제에 대해 설명한다. 또한 몇 가지 기본 보안 용어에 대해 설명하고, 샘플 애플리케이션을 실행하기 위한 전제 조건에 대해 알아본다.
2장, ‘스프링 시큐리티 시작하기’에서는 “Hello World”를 이용해 스프링 시큐리티를 설치하는 방법에 대해 설명한다. 또한 스프링 시큐리티에서 사용하는 가장 일반적인 사용자 정의 설정에 대해서도 알아본다.
3장, ‘사용자 정의 인증’에서는 실무에서의 문제를 해결하기 위한 인증 인프라의 핵심 부분을 사용자 정의를 통해 구현함으로써 스프링 시큐리티의 인증 구조를 설명한다. 이를 통해, 스프링 시큐리티의 인증 방식을 이해하고 기존 인증 메커니즘과 새로운 인증 메커니즘을 연동하는 방법을 배운다.
4장, ‘JDBC 기반 인증’에서는 스프링 시큐리티에 빌트인된 JDBC를 활용해 데이터베이스 기반의 인증을 다룬다. 또한 스프링 시큐리티의 새로운 패스워드화 모듈을 사용해 패스워드를 보호하는 방법에 대해 설명한다.
5장, ‘스프링 데이터를 이용한 인증’에서는 스프링 시큐리티의 스프링 데이터 JPA 및 스프링데이터, MongoDB를 연동해 데이터베이스에 대한 인증을 다룬다.
6장, ‘LDAP 디렉터리 서비스’에서는 LDAP 디렉터리 서버와 애플리케이션을 연동하는 방법에 대해 설명한다.
7장, ‘Remember-Me 서비스’에서는 스프링 시큐리티에서 사용하는 Remember-Me 기능과 이를 구성하는 방법을 설명하며, 사용 시 염두에 둬야 할 추가 고려 사항에 대해서도 알아본다.
8장, ‘TLS를 사용한 클라이언트 인증서 인증’에서는 인증서 관리가 추가 보안을 제공할 수 있는 샘플 애플리케이션과 같은 특정 비즈니스 시나리오에 대한 대안으로서 X.509 인증서 기반 인증을 설명한다.
9장, ‘OAuth 2 적용하기’에서는 OAuth 2 기반의 사용자 로그인 및 사용자 속성에 대해 다루며, 스프링 OAuth 2와 스프링 소셜(Spring Social) 연동 방법을 포함해 OAuth 2 프로토콜의 논리적 흐름에 대한 전반적인 내용을 설명한다.
10장, ‘CAS를 활용한 SSO’에서는 샘플 애플리케이션에 CAS(Central Authentication Service)를 이용해 싱글 사인 온(Single-Sign-On), SSO 및 싱글 로그아웃(Single Logout) 기능을 구현하는 방법에 대해 알아본다. 또한 상태를 저장하지 않는 서비스(stateless services)에서 CAS 프록시 티켓을 사용하는 방법에 대해서도 배운다.
11장, ‘미세 접근 제어’에서는 스프링 시큐리티의 메서드 보안 기능을 사용한 페이지 내 권한 검사(일부 페이지 렌더링) 및 비즈니스 계층 보안에 대해 다룬다.
12장, ‘접근 제어 목록’에서는 까다로운 비즈니스 관련 보안 문제에 유연하게 적용할 수 있는 스프링 시큐리티의 ACL 모듈을 사용해 비즈니스 객체 수준 보안의 개념과 기본 구현 방법을 다룬다.
13장, ‘사용자 정의 권한 부여’에서는 스프링 시큐리티 권한 부여 인프라의 주요 부분에 대한 사용자 정의 구현체를 작성해 스프링 시큐리티의 권한 부여가 이뤄지는 방식을 설명한다.
14장, ‘세션 관리’에서는 스프링 시큐리티가 사용자 세션을 관리하고 보호하는 방법에 대해 설명한다. 일단, 세션 변조 공격(Session Fixation Attack)에 대해 설명하며, 스프링 시큐리티를 이용해 방어하는 방법에 대해 배운다. 또한 로그인한 사용자를 관리하는 방법과 단일 사용자가 보유한 동일 세션 수를 제한하는 방법에 대해 설명한다. 마지막으로, 스프링 시큐리티에서 http 세션과 사용자를 연결하는 방법과 사용자를 지정하는 방법에 대해 다룬다.
15장, ‘스프링 시큐리티의 추가 기능’에서는 스프링 시큐리티의 추가 기능과 크로스 사이트 스크립팅(XSS), 크로스 사이트 요청 위조(CSRF), 동기화 토큰 및 클릭 재킹(Clickjacking)과 같은 일반적인 보안 취약점과 이를 방지하는 방법에 대해 설명한다.
16장, ‘스프링 시큐리티 4.2 마이그레이션’에서는 설정 변경 사항, 클래스 및 패키지 마이그레이션(migration), 새로운 주요 기능 등을 포함한 스프링 시큐리티 3에서의 마이그레이션 방향을 제공한다. 또한 스프링 시큐리티 4.2에서 볼 수 있는 새로운 기능을 강조하고 책에서 설명하는 기능에 대해 도움 자료를 제공한다.
17장, ‘OAuth 2 및 JSON 웹 토큰을 이용한 마이크로서비스 보안’에서는 마이크로서비스 기반 구조를 배우고, OAuth 2와 JWT가 스프링 기반의 애플리케이션에서 역할을 수행하는 방
법을 다룬다.
부록의 ‘참고 자료’에서는 스프링 시큐리티와 직접적인 관련은 없지만, 이 책에서 다루는 주제와 관련이 있는 참고 자료를 포함하고 있다. 부록에서 가장 중요한 부분은 이 책의 샘플 코드를 실행하는 데 도움이 되는 내용을 다루는 부분이다.


목차


1장. 취약한 애플리케이션의 구조
__보안 감사
____샘플 애플리케이션 소개
____JBCP 달력 애플리케이션의 구조
__애플리케이션 테크놀로지
____보안 감사 결과 리뷰
__인증
__권한 부여
____데이터베이스 내 인증 정보 보안
__요약


2장. 스프링 시큐리티 시작하기
__스프링 시큐리티 기본 설정
____샘플 애플리케이션 가져오기
____의존성 업데이트
____스프링 시큐리티 XML 설정 파일 구현
____web.xml 파일 업데이트
____안전한 애플리케이션 실행
____자주 발생하는 문제점
__약간의 기능 추가
____사용자 정의 로그인 페이지
__요약


3장. 사용자 정의 인증
__JBCP 달력의 구조
____CalendarUser 객체
____Event 객체
____CalendarService 인터페이스
____UserContext 인터페이스
____SpringSecurityUserContext 인터페이스
__SecurityContextHolder를 사용한 새로운 사용자 로그인
____스프링 시큐리티에서의 사용자 관리
____새로운 사용자로 로그인
____SignupController 업데이트
__사용자 정의 UserDetailsService 객체 생성
____CalendarUserDetailsService 클래스
____UserDetailsService 설정
____UserDetailsManager에 대한 참조 제거
____CalendarUserDetails 객체
____SpringSecurityUserContext 단순화
__사용자 정의 AuthenticationProvider 객체 생성
____CalendarUserAuthenticationProvider
____CalendarUserAuthenticationProvider 객체
____다른 매개변수를 이용한 인증
__인증 메서드 선택
__요약


4장. JDBC 기반 인증
__필수 의존성
__H2 데이터베이스 사용
____제공된 JDBC 스크립트
____H2 임베디드 데이터베이스 설정
____JDBC UserDetailsManager 구현체 설정
__스프링 시큐리티의 기본 사용자 스키마
____사용자 정의
____사용자 권한 정의
__UserDetailsManager 인터페이스
____그룹 기반 접근 제어 그룹 기반 접근 제어 설정
__사용자 정의 스키마 지원
____올바른 JDBC SQL 쿼리 판단
____로드된 SQL 스크립트 업데이트
____CalendarUser 권한 SQL
____사용자 정의 권한 삽입
____사용자 정의 SQL 쿼리 사용을 위한 JdbcUserDetailsManager 설정
__보안 패스워드 설정
__PasswordEncoder 메서드
____패스워드 인코딩 설정
____PasswordEncoder 메서드 설정
____스프링 시큐리티에 PasswordEncoder 메서드 적용
__스프링 시큐리티에 솔트 적용
____스프링 시큐리티 설정 업데이트
____기존 패스워드 마이그레이션
____DefaultCalendarUserService 업데이트
__솔트를 적용한 패스워드 사용
__요약


5장. 스프링 데이터를 이용한 인증
__스프링 데이터 JPA
____의존성 업데이트
____스프링 데이터 JPA 사용을 위한 JBCP 달력 업데이트
____데이터베이스 설정 재구성
____데이터베이스 초기화
__SQL에서 ORM으로 리팩토링
____JPA를 사용한 도메인 객체 매핑
____스프링 데이터 저장소
____데이터 액세스 객체
__애플리케이션 서비스
__UserDetailsService 객체
____RDBMS를 문서 데이터베이스로 리팩토링
__MongoDB를 사용한 문서 데이터베이스 구축
____의존성 업데이트
____MongoDB의 데이터베이스 설정 재구성
____MongoDB 데이터베이스 초기화
____MongoDB와 도메인 객체 매핑
____MongoDB의 데이터 액세스 객체
__요약


6장. LDAP 디렉터리 서비스
__LDAP 이해
____LDAP
____임베디드 LDAP 문제 해결
__스프링 LDAP 인증 방식 이해
____사용자 자격 증명 인증
____아파치 DS를 통한 인증 과정
__아파치 DS를 통한 역할 결정
____UserDetails의 추가 애트리뷰트 매핑
____고급 LDAP 설정
____LDAP 패스워드 인코딩과 저장
____패스워드 비교 인증의 단점
__UserDetailsContextMapper 객체 설정
____UserDetailsContextMapper의 암시적 설정
____사용자 추가 상세 정보 보기
LdapUserDetailsService 설정
__LdapUserDetailsService를 사용하기 위한 AccountController 업데이트
____외부 LDAP 서버와 스프링 시큐리티 연동
__명시적 LDAP 빈 설정
____외부 LDAP 서버 참조 설정
____LdapAuthenticationProvider 인터페이스 설정
____UserDetailsService에 대한 역할 검색 위임
__LDAP를 통한 마이크로소프트 AD 연동
____스프링 시큐리티 4.2의 AD 지원
__요약


7장. Remember-Me 서비스
__Remember-Me
____의존성
____토큰 기반 Remember-Me 기능
__MD5
____Remember-Me 시그니처
__Remember-Me의 안전성
____Remember-Me를 위한 권한 부여 규칙
__영구 토큰 기반 Remember-Me 설정
____영구 토큰 기반 Remember-Me 기능의 동작 원리
__JPA 기반 PersistentTokenRepository
____사용자 정의 Remember-Me 서비스
____만료된 Remember-Me 세션 정리
__Remember-Me 아키텍처
____Remember-Me와 사용자 라이프 사이클
____IP 주소를 통한 Remember-Me 기능 제한
__사용자 정의 쿠키 및 HTTP 매개변수명
__요약


8장. TLS를 사용한 클라이언트 인증서 인증
__클라이언트 인증서 인증의 동작 원리
____클라이언트 인증서 인증 인프라 설정
____웹 브라우저로 인증서 키 쌍 불러오기
____클라이언트 인증서 인증 문제 해결
____스프링 시큐리티에서 클라이언트 인증서 인증 설정
____security 네임스페이스를 사용한 클라이언트 인증서 인증 설정
__스프링 빈을 사용한 클라이언트 인증서 설정
____빈 기반 설정의 추가 기능
____클라이언트 인증서 인증 구현 시 고려 사항
__요약


9장. OAuth 2 적용하기
__OAuth 2의 가능성
____OAuth 2 애플리케이션 가입
____스프링 시큐리티에서 OAuth 인증 활성화
____추가 필수 의존성
__스프링 시큐리티에서의 OAuth 2 구성
____로컬 UserConnectionRepository
____프로바이더 정보에 대한 로컬 데이터베이스 엔트리 생성
____사용자 정의 UserConnectionRepository 인터페이스
____ConnectionSignup의 흐름
__OAuth 2 프로바이더 연결
____OAuth 2 사용자 추가
____OAuth 2 컨트롤러 로그인 절차
__추가 OAuth 2 프로바이더
____OAuth 2 사용자 등록 문제
____비표준 OAuth 2 프로바이더 등록
__OAuth 2의 안전성
__요약


10장. CAS를 활용한 SSO
__CAS 소개
__고수준 CAS 인증 흐름
__스프링 시큐리티와 CAS
____의존성
____CAS 설치와 설정
__CAS 기본 연동 설정
____CAS ServiceProperties 객체 생성
____CasAuthenticationEntryPoint 객체 추가
____CAS 티켓 검증 사용CasAuthenticationProvider 객체를 이용한 진위성 증명
__단일 로그아웃
____단일 로그아웃 설정
__클러스터 환경
____Stateless 서비스에 대한 프록시 티켓 인증
____프록시 티켓 인증 설정
__프록시 티켓 사용
____프록시 티켓 인증
__CAS 서버 사용자 정의
____CAS WAR 오버레이
____CAS 내부 인증 작동 방식
____임베디드 LDAP 서버와 CAS 연결 설정
__CAS 단언으로부터 UserDetails 객체 생성
____CAS 응답에 LDAP 애트리뷰트 반환
____LDAP 애트리뷰트와 CAS 애트리뷰트 매핑
____사용자 정의 애트리뷰트에 접근하기 위한 CAS 서비스 권한 부여
____CAS로부터 UserDetails 획득
____GrantedAuthorityFromAssertionAttributesUser 객체
____SAML 1.1을 사용한 또 다른 티켓 인증
____애트리뷰트 조회의 유용성
__추가 CAS 기능
__요약


11장. 미세 접근 제어
__그레이들 의존성
____스프링 표현 언어 통합
__Thymeleaf 스프링 시큐리티 태그 라이브러리를 활용한 조건부 렌더링
____URL 접근 규칙을 기반으로 한 조건부 렌더링
____SpEL을 활용한 조건부 렌더링
____컨트롤러 로직을 사용한 조건부 컨텐츠 렌더링
____WebInvocationPrivilegeEvaluator 클래스
____페이지 내 권한 부여를 설정하는 최적의 방법
____메서드 레벨 보안
____다중 보안의 필요성
__인터페이스 기반 프록시
__JSR-250 호환 표준 규칙
____스프링의 @Secured 어노테이션을 사용한 메서드 보안
____메서드 매개변수를 포함하는 메서드 보안 규칙
____반환된 값을 통합하는 메서드 보안 규칙
____역할 기반 필터링을 통한 메서드 데이터 보호
____@PreFilter를 사용한 컬렉션 사전 필터링
____메서드 권한 부여 타입 비교
____어노테이션 기반 보안을 위한 고려 사항
__요약


12장. 접근 제어 목록
__ACL 개념 모듈
__스프링 시큐리티에서의 ACL
__스프링 시큐리티 ACL 지원을 위한 기본 설정
____그레이들 의존성
____예제 시나리오 설정
____H2 데이터베이스에 ACL 테이블 추가
____SecurityExpressionHandler 설정
____AclPermissionCacheOptimizer 객체
____간단한 ACL 엔트리 생성
____고급 ACL 주제
____사용자 정의 ACL 퍼미션 선언
____ACL 퍼미션 평가 활성화
____수정 가능 ACL과 권한 부여
____일반적인 ACL 적용 시 고려 사항
____스프링 시큐리티 ACL의 필요성
__요약


13장. 사용자 정의 권한 부여
__요청에 대한 권한 부여
____접근 결정의 취합 방식 설정
____UnanimousBased 접근 결정 관리자 설정
____요청에 대한 표현식 기반 권한 부여
__URL에 대한 접근 제어의 동적 정의
____RequestConfigMappingService 설정
____사용자 정의 SecurityMetadataSource 구현
____사용자 정의 SecurityMetadataSource 등록
____antMatchers() 메서드 제거
__사용자 정의 표현식 생성
____사용자 정의 SecurityExpressionRoot 설정
____사용자 정의 SecurityExpressionHandler 설정
____CustomWebSecurityExpressionHandler 설정과 사용
____CustomWebSecurityExpressionHandler에 대한 대안
__요약


14장. 세션 관리
__세션 고정 보호 설정.
____세션 고정 공격에 대한 이해
____스프링 시큐리티를 사용한 세션 고정 공격 방어
____세션 고정 공격 시뮬레이션
____세션 고정 보호 옵션 비교
__사용자 당 동시 세션 수 제한
____동시 세션 제어 설정
__ㅍ동시 세션 제어 테스트
__만료 세션 리다이렉트 설정.
__동시성 제어의 일반적인 문제점
____강제 로그아웃 대신 인증 방지 설정
__동시 세션 제어의 장점
__사용자의 활성화된 세션 표시
____스프링 시큐리티가 HttpSession 메서드를 사용하는 방법
____HttpSessionSecurityContextRepository 인터페이스
____스프링 시큐리티에 HttpSession를 사용하도록 설정
____스프링 시큐리티의 DebugFilter를 이용한 디버깅
__요약


15장. 스프링 시큐리티의 추가 기능
__보안 취약점
__크로스 사이트 스크립팅
__사이트 간 요청 변조
____동기화 토큰
____CSRF 보호 사용 시점
____기본 CSRF 지원
____CSRF 보호 구현 시 주의사항
__보안 HTTP 응답 헤더
____기본 보안 헤더
____사용자 정의 헤더
__요약


16장. 스프링 시큐리티 4.2 마이그레이션
__소개
__샘플 마이그레이션
____스프링 시큐리티 4.2의 향상된 기능
____스프링 시큐리티 4.x의 기타 변경 사항
____스프링 시큐리티 4의 설정 변경
__삭제된 기능
____spring-security-core 삭제
____spring-security-web 삭제
____기본 필터 URL 마이그레이션
____JAAS
__요약


17장. OAuth 2 및 JSON 웹 토큰을 이용한 마이크로서비스 보안
__마이크로서비스의 개념
____단일체.
____마이크로서비스
__서비스 기반 아키텍처
__마이크로서비스 보안
____서비스 통신
____결합성
____기술적 복잡성
__OAuth 2 사양
____액세스 토큰
____권한 부여 방식
__JSON 웹 토큰(JWT)
____토큰 구조
__스프링 시큐리티에서의 OAuth 2 지원
____자원 소유자
____자원 서버
____권한 부여 서버
____RSA JWT 액세스 토큰 변환기 keypair
____OAuth 2 resource 속성 설정
____OAuth 2 Client 속성 설정
____JWT 액세스 토큰 변환기
____UserDetailsService 객체
____OAuth 2 서버 애플리케이션 실행
__마이크로서비스 클라이언트
____OAuth 2 클라이언트 설정
__요약
__JBCP 달력 샘플 코드 시작


부록. 참고 자료
__그레이들 빌드툴
__그레이들 IDE 플러그인
__새로운 작업 공간 생성
__샘플 코드의 구조
__샘플 코드 가져오기
__샘플 코드 실행
__톰캣 HTTPS 설정
__보충 자료

교환 및 환불안내

도서교환 및 환불
  • ㆍ배송기간은 평일 기준 1~3일 정도 소요됩니다.(스프링 분철은 1일 정도 시간이 더 소요됩니다.)
  • ㆍ상품불량 및 오배송등의 이유로 반품하실 경우, 반품배송비는 무료입니다.
  • ㆍ고객님의 변심에 의한 반품,환불,교환시 택배비는 본인 부담입니다.
  • ㆍ상담원과의 상담없이 교환 및 반품으로 반송된 물품은 책임지지 않습니다.
  • ㆍ이미 발송된 상품의 취소 및 반품, 교환요청시 배송비가 발생할 수 있습니다.
  • ㆍ반품신청시 반송된 상품의 수령후 환불처리됩니다.(카드사 사정에 따라 카드취소는 시일이 3~5일이 소요될 수 있습니다.)
  • ㆍ주문하신 상품의 반품,교환은 상품수령일로 부터 7일이내에 신청하실 수 있습니다.
  • ㆍ상품이 훼손된 경우 반품 및 교환,환불이 불가능합니다.
  • ㆍ반품/교환시 고객님 귀책사유로 인해 수거가 지연될 경우에는 반품이 제한될 수 있습니다.
  • ㆍ스프링제본 상품은 교환 및 환불이 불가능 합니다.
  • ㆍ군부대(사서함) 및 해외배송은 불가능합니다.
  • ㆍ오후 3시 이후 상담원과 통화되지 않은 취소건에 대해서는 고객 반품비용이 발생할 수 있습니다.
반품안내
  • 마이페이지 > 나의상담 > 1 : 1 문의하기 게시판 또는 고객센터 1800-7327
교환/반품주소
  • 경기도 파주시 문발로 211 1층 / (주)북채널 / 전화 : 1800-7327
  • 택배안내 : CJ대한통운(1588-1255)
  • 고객님 변심으로 인한 교환 또는 반품시 왕복 배송비 5,000원을 부담하셔야 하며, 제품 불량 또는 오 배송시에는 전액을 당사에서부담 합니다.