봄-퀵 가이드
Spring은 엔터프라이즈 Java를위한 가장 인기있는 애플리케이션 개발 프레임 워크입니다. 전 세계 수백만 명의 개발자가 Spring Framework를 사용하여 쉽게 테스트 할 수 있고 재사용 가능한 고성능 코드를 만듭니다.
Spring 프레임 워크는 오픈 소스 Java 플랫폼입니다. 처음에는 Rod Johnson이 작성했으며 2003 년 6 월 Apache 2.0 라이선스로 처음 출시되었습니다.
봄은 크기와 투명성면에서 가볍습니다. Spring 프레임 워크의 기본 버전은 약 2MB입니다.
Spring Framework의 핵심 기능은 모든 Java 애플리케이션 개발에 사용할 수 있지만 Java EE 플랫폼 위에 웹 애플리케이션을 구축하기위한 확장 기능이 있습니다. Spring 프레임 워크는 J2EE 개발을보다 쉽게 사용하도록하고 POJO 기반 프로그래밍 모델을 활성화하여 좋은 프로그래밍 사례를 촉진합니다.
Spring Framework 사용의 이점
다음은 Spring Framework 사용의 몇 가지 큰 이점 목록입니다.
Spring은 개발자가 POJO를 사용하여 엔터프라이즈 급 애플리케이션을 개발할 수 있도록합니다. POJO 만 사용하는 이점은 애플리케이션 서버와 같은 EJB 컨테이너 제품이 필요하지 않지만 Tomcat 또는 일부 상용 제품과 같은 강력한 서블릿 컨테이너 만 사용할 수 있다는 것입니다.
Spring은 모듈 방식으로 구성됩니다. 패키지와 클래스의 수가 많더라도 필요한 것만 걱정하고 나머지는 무시하면됩니다.
Spring은 휠을 재발 명하지 않고 대신 여러 ORM 프레임 워크, 로깅 프레임 워크, JEE, Quartz 및 JDK 타이머, 기타 뷰 기술과 같은 기존 기술 중 일부를 진정으로 사용합니다.
Spring으로 작성된 애플리케이션을 테스트하는 것은 환경 의존적 인 코드가이 프레임 워크로 이동하기 때문에 간단합니다. 또한 JavaBeanstyle POJO를 사용하면 테스트 데이터를 주입하기 위해 종속성 주입을 사용하는 것이 더 쉬워집니다.
Spring의 웹 프레임 워크는 잘 설계된 웹 MVC 프레임 워크로, Struts 또는 기타 과도하게 엔지니어링되거나 덜 인기있는 웹 프레임 워크와 같은 웹 프레임 워크에 대한 훌륭한 대안을 제공합니다.
Spring은 기술 별 예외 (예 : JDBC, Hibernate 또는 JDO에 의해 발생)를 일관되고 확인되지 않은 예외로 변환하는 편리한 API를 제공합니다.
경량 IoC 컨테이너는 특히 EJB 컨테이너와 비교할 때 경량 인 경향이 있습니다. 이는 메모리와 CPU 리소스가 제한된 컴퓨터에서 응용 프로그램을 개발하고 배포하는 데 유용합니다.
Spring은 로컬 트랜잭션 (예 : 단일 데이터베이스 사용)으로 축소하고 전역 트랜잭션 (예 : JTA 사용)으로 확장 할 수있는 일관된 트랜잭션 관리 인터페이스를 제공합니다.
DI (종속성 주입)
Spring이 가장 많이 식별하는 기술은 Dependency Injection (DI)Inversion of Control의 맛. 그만큼Inversion of Control (IoC)일반적인 개념이며 다양한 방식으로 표현할 수 있습니다. 의존성 주입은 Inversion of Control의 구체적인 예일뿐입니다.
복잡한 Java 애플리케이션을 작성할 때 애플리케이션 클래스는 다른 Java 클래스와 가능한 한 독립적이어야 이러한 클래스를 재사용하고 단위 테스트 중에 다른 클래스와 독립적으로 테스트 할 수 있습니다. 의존성 주입은 이러한 클래스를 함께 붙이고 동시에 독립적으로 유지하는 데 도움이됩니다.
의존성 주입이란 정확히 무엇입니까? 이 두 단어를 따로 살펴 보겠습니다. 여기서 종속성 부분은 두 클래스 간의 연관으로 변환됩니다. 예를 들어, 클래스 A는 클래스 B에 종속됩니다. 이제 두 번째 부분 인 주입을 살펴 보겠습니다. 이 모든 의미는 클래스 B가 IoC에 의해 클래스 A에 주입된다는 것입니다.
종속성 주입은 매개 변수를 생성자에 전달하는 방식으로 또는 setter 메서드를 사용하여 생성 후 발생할 수 있습니다. Dependency Injection은 Spring Framework의 핵심이므로 관련 예제와 함께 별도의 장에서이 개념을 설명합니다.
AOP (Aspect Oriented Programming)
Spring의 핵심 구성 요소 중 하나는 Aspect Oriented Programming (AOP)뼈대. 응용 프로그램의 여러 지점에 걸쳐있는 함수가 호출됩니다.cross-cutting concerns이러한 교차 문제는 개념적으로 애플리케이션의 비즈니스 로직과 분리되어 있습니다. 로깅, 선언적 트랜잭션, 보안, 캐싱 등 다양한 측면의 일반적인 좋은 예가 있습니다.
OOP에서 모듈화의 핵심 단위는 클래스이고 AOP에서는 모듈화 단위가 aspect입니다. DI는 애플리케이션 객체를 서로 분리하는 데 도움이되며, AOP는 영향을 미치는 객체에서 교차 절단 문제를 분리하는 데 도움이됩니다.
Spring Framework의 AOP 모듈은 분리되어야하는 기능을 구현하는 코드를 명확하게 분리하기 위해 메소드 인터셉터와 포인트 컷을 정의 할 수 있도록 aspect 지향 프로그래밍 구현을 제공합니다. 별도의 장에서 Spring AOP 개념에 대해 자세히 설명합니다.
Spring은 잠재적으로 모든 엔터프라이즈 애플리케이션을위한 원 스톱 상점이 될 수 있습니다. 그러나 Spring은 모듈 식이므로 나머지 모듈을 가져 오지 않고도 자신에게 적용 할 수있는 모듈을 선택할 수 있습니다. 다음 섹션에서는 Spring Framework에서 사용할 수있는 모든 모듈에 대한 세부 정보를 제공합니다.
Spring Framework는 애플리케이션 요구 사항에 따라 사용할 수있는 약 20 개의 모듈을 제공합니다.
핵심 컨테이너
Core Container는 Core, Beans, Context 및 Expression Language 모듈로 구성되며 세부 사항은 다음과 같습니다.
그만큼 Core 모듈은 IoC 및 종속성 주입 기능을 포함하여 프레임 워크의 기본 부분을 제공합니다.
그만큼 Bean 모듈은 팩토리 패턴의 정교한 구현 인 BeanFactory를 제공합니다.
그만큼 Context모듈은 Core 및 Beans 모듈에서 제공하는 견고한 기반을 기반으로하며 정의되고 구성된 모든 개체에 액세스하는 매체입니다. ApplicationContext 인터페이스는 Context 모듈의 초점입니다.
그만큼 SpEL 모듈은 런타임에 개체 그래프를 쿼리하고 조작하기위한 강력한 표현 언어를 제공합니다.
데이터 액세스 / 통합
데이터 액세스 / 통합 계층은 JDBC, ORM, OXM, JMS 및 트랜잭션 모듈로 구성되며 세부 정보는 다음과 같습니다.
그만큼 JDBC 모듈은 지루한 JDBC 관련 코딩의 필요성을 제거하는 JDBC 추상화 계층을 제공합니다.
그만큼 ORM 모듈은 JPA, JDO, Hibernate 및 iBatis를 포함한 인기있는 객체 관계형 매핑 API를위한 통합 계층을 제공합니다.
그만큼 OXM 모듈은 JAXB, Castor, XMLBeans, JiBX 및 XStream에 대한 객체 / XML 매핑 구현을 지원하는 추상화 계층을 제공합니다.
자바 메시징 서비스 JMS 모듈에는 메시지 생성 및 소비 기능이 포함되어 있습니다.
그만큼 Transaction 모듈은 특수 인터페이스를 구현하는 클래스와 모든 POJO에 대해 프로그래밍 및 선언적 트랜잭션 관리를 지원합니다.
편물
웹 계층은 Web, Web-MVC, Web-Socket 및 Web-Portlet 모듈로 구성되며 세부 사항은 다음과 같습니다.
그만큼 Web 모듈은 멀티 파트 파일 업로드 기능, 서블릿 리스너 및 웹 지향 애플리케이션 컨텍스트를 사용하는 IoC 컨테이너 초기화와 같은 기본적인 웹 지향 통합 기능을 제공합니다.
그만큼 Web-MVC 모듈에는 웹 애플리케이션을위한 Spring의 MVC (Model-View-Controller) 구현이 포함되어 있습니다.
그만큼 Web-Socket 모듈은 웹 애플리케이션에서 클라이언트와 서버 간의 WebSocket 기반 양방향 통신을 지원합니다.
그만큼 Web-Portlet 모듈은 포틀릿 환경에서 사용할 MVC 구현을 제공하며 웹 서블릿 모듈의 기능을 미러링합니다.
여러 가지 잡다한
AOP, Aspects, Instrumentation, Web 및 Test 모듈과 같은 다른 중요한 모듈은 다음과 같습니다.
그만큼 AOP 모듈은 분리되어야하는 기능을 구현하는 코드를 명확하게 분리하기 위해 메소드 인터셉터와 포인트 컷을 정의 할 수있는 aspect 지향 프로그래밍 구현을 제공합니다.
그만큼 Aspects 모듈은 강력하고 성숙한 AOP 프레임 워크 인 AspectJ와의 통합을 제공합니다.
그만큼 Instrumentation 모듈은 특정 애플리케이션 서버에서 사용할 클래스 계측 지원 및 클래스 로더 구현을 제공합니다.
그만큼 Messaging모듈은 애플리케이션에서 사용할 WebSocket 하위 프로토콜로 STOMP를 지원합니다. 또한 WebSocket 클라이언트에서 STOMP 메시지를 라우팅하고 처리하기위한 주석 프로그래밍 모델을 지원합니다.
그만큼 Test 모듈은 JUnit 또는 TestNG 프레임 워크로 Spring 컴포넌트의 테스트를 지원합니다.
이 장에서는 Spring Framework로 작업을 시작하기 위해 개발 환경을 준비하는 방법을 안내합니다. 또한 Spring Framework를 설정하기 전에 컴퓨터에서 JDK, Tomcat 및 Eclipse를 설정하는 방법을 알려줍니다.
1 단계-JDK (Java Development Kit) 설정
Oracle의 Java 사이트 인 Java SE Downloads 에서 최신 버전의 SDK를 다운로드 할 수 있습니다 . 다운로드 한 파일에서 JDK 설치 지침을 찾을 수 있으며, 주어진 지침에 따라 설치 및 구성을 수행합니다. 마지막으로 java 및 javac (일반적으로 각각 java_install_dir / bin 및 java_install_dir)가 포함 된 디렉토리를 참조하도록 PATH 및 JAVA_HOME 환경 변수를 설정합니다.
Windows를 실행 중이고 C : \ jdk1.6.0_15에 JDK를 설치 한 경우 C : \ autoexec.bat 파일에 다음 행을 입력해야합니다.
set PATH=C:\jdk1.6.0_15\bin;%PATH%
set JAVA_HOME=C:\jdk1.6.0_15
또는 Windows NT / 2000 / XP에서는 내 컴퓨터를 마우스 오른쪽 버튼으로 클릭하고 속성 → 고급 → 환경 변수를 선택해야합니다. 그런 다음 PATH 값을 업데이트하고 확인 버튼을 클릭해야합니다.
Unix (Solaris, Linux 등)에서 SDK가 /usr/local/jdk1.6.0_15에 설치되어 있고 C 셸을 사용하는 경우 .cshrc 파일에 다음을 넣어야합니다.
setenv PATH /usr/local/jdk1.6.0_15/bin:$PATH
setenv JAVA_HOME /usr/local/jdk1.6.0_15
또는 Borland JBuilder, Eclipse, IntelliJ IDEA 또는 Sun ONE Studio와 같은 IDE (통합 개발 환경)를 사용하는 경우 간단한 프로그램을 컴파일하고 실행하여 IDE가 Java를 설치 한 위치를 알고 있는지 확인해야합니다. 그렇지 않으면 IDE 문서에 제공된대로 적절한 설정을 수행해야합니다.
2 단계-Apache Common Logging API 설치
최신 버전의 Apache Commons Logging API를 다운로드 할 수 있습니다. https://commons.apache.org/logging/. 설치를 다운로드 한 후 편리한 위치에 바이너리 배포의 압축을 풉니 다. 예를 들어, Windows의 C : \ commons-logging-1.1.1 또는 Linux / Unix의 /usr/local/commons-logging-1.1.1입니다. 이 디렉토리에는 다음과 같은 jar 파일 및 기타 지원 문서 등이 있습니다.
이 디렉토리에서 CLASSPATH 변수를 올바르게 설정했는지 확인하십시오. 그렇지 않으면 응용 프로그램을 실행하는 동안 문제가 발생합니다.
3 단계-Eclipse IDE 설정
이 튜토리얼의 모든 예제는 Eclipse IDE를 사용하여 작성되었습니다. 따라서 컴퓨터에 최신 버전의 Eclipse를 설치하는 것이 좋습니다.
Eclipse IDE를 설치하려면 다음에서 최신 Eclipse 바이너리를 다운로드하십시오. https://www.eclipse.org/downloads/. 설치를 다운로드 한 후 편리한 위치에 바이너리 배포의 압축을 풉니 다. 예를 들어 Windows의 C : \ eclipse 또는 Linux / Unix의 / usr / local / eclipse에서 마지막으로 PATH 변수를 적절하게 설정합니다.
Eclipse는 Windows 시스템에서 다음 명령을 실행하여 시작하거나 eclipse.exe를 두 번 클릭 할 수 있습니다.
%C:\eclipse\eclipse.exe
Eclipse는 Unix (Solaris, Linux 등) 시스템에서 다음 명령을 실행하여 시작할 수 있습니다.
$/usr/local/eclipse/eclipse
성공적으로 시작한 후 모든 것이 정상이면 다음 결과가 표시됩니다.
4 단계-Spring Framework 라이브러리 설정
이제 모든 것이 정상이면 Spring 프레임 워크 설정을 진행할 수 있습니다. 다음은 시스템에 프레임 워크를 다운로드하고 설치하는 간단한 단계입니다.
Windows 또는 Unix에 Spring을 설치할지 여부를 선택하고 다음 단계로 진행하여 Windows 용 .zip 파일과 Unix 용 .tz 파일을 다운로드합니다.
최신 버전의 Spring 프레임 워크 바이너리를 https://repo.spring.io/release/org/springframework/spring.
이 튜토리얼을 개발할 때 spring-framework-4.1.6.RELEASE-dist.zipWindows 시스템에 다운로드되었습니다. 다운로드 한 파일의 압축이 풀리면 E : \ spring 안에 다음과 같은 디렉토리 구조를 제공합니다.
디렉토리에서 모든 Spring 라이브러리를 찾을 수 있습니다. E:\spring\libs. 이 디렉토리에서 CLASSPATH 변수를 올바르게 설정했는지 확인하십시오. 그렇지 않으면 응용 프로그램을 실행하는 동안 문제가 발생합니다. Eclipse를 사용하는 경우 모든 설정이 Eclipse를 통해 수행되므로 CLASSPATH를 설정할 필요가 없습니다.
이 마지막 단계를 마치면 다음 장의 첫 번째 Spring 예제로 넘어갈 준비가 된 것입니다.
Spring Framework로 실제 프로그래밍을 시작하겠습니다. Spring 프레임 워크를 사용하여 첫 번째 예제를 작성하기 전에 Spring-Environment Setup Chapter에 설명 된대로 Spring 환경을 올바르게 설정했는지 확인해야합니다 . 또한 Eclipse IDE에 대한 약간의 작업 지식이 있다고 가정합니다.
이제 "Hello World!"를 출력하는 간단한 Spring 애플리케이션을 작성해 보겠습니다. 또는 Spring Beans 구성 파일에서 수행 된 구성을 기반으로하는 다른 메시지.
1 단계-Java 프로젝트 생성
첫 번째 단계는 Eclipse IDE를 사용하여 간단한 Java 프로젝트를 만드는 것입니다. 옵션을 따르십시오File → New → Project 마지막으로 선택 Java Project마법사 목록에서 마법사. 이제 프로젝트 이름을HelloSpring 다음과 같이 마법사 창을 사용하여-
프로젝트가 성공적으로 생성되면 다음 콘텐츠가 Project Explorer −
2 단계-필요한 라이브러리 추가
두 번째 단계로 프로젝트에 Spring Framework 및 공통 로깅 API 라이브러리를 추가하겠습니다. 이렇게하려면 프로젝트 이름을 마우스 오른쪽 버튼으로 클릭하십시오.HelloSpring 그런 다음 컨텍스트 메뉴에서 사용 가능한 다음 옵션을 따르십시오- Build Path → Configure Build Path 다음과 같이 Java 빌드 경로 창을 표시하려면-
이제 사용 Add External JARs 아래에서 사용할 수있는 버튼 Libraries 탭에서 Spring Framework 및 Common Logging 설치 디렉토리에서 다음 핵심 JAR을 추가합니다.
commons-logging-1.1.1
spring-aop-4.1.6.RELEASE
spring-aspects-4.1.6.RELEASE
spring-beans-4.1.6.RELEASE
spring-context-4.1.6.RELEASE
spring-context-support-4.1.6.RELEASE
spring-core-4.1.6.RELEASE
spring-expression-4.1.6.RELEASE
spring-instrument-4.1.6.RELEASE
spring-instrument-tomcat-4.1.6.RELEASE
spring-jdbc-4.1.6.RELEASE
spring-jms-4.1.6.RELEASE
spring-messaging-4.1.6.RELEASE
spring-orm-4.1.6.RELEASE
spring-oxm-4.1.6.RELEASE
spring-test-4.1.6.RELEASE
spring-tx-4.1.6.RELEASE
spring-web-4.1.6.RELEASE
spring-webmvc-4.1.6.RELEASE
spring-webmvc-portlet-4.1.6.RELEASE
spring-websocket-4.1.6.RELEASE
3 단계-소스 파일 생성
이제 실제 소스 파일을 HelloSpring계획. 먼저 다음과 같은 패키지를 생성해야합니다.com.tutorialspoint. 이렇게하려면 마우스 오른쪽 버튼을 클릭하십시오.src 패키지 탐색기 섹션에서 옵션을 따르십시오- New → Package.
다음으로 우리는 HelloWorld.java 과 MainApp.java com.tutorialspoint 패키지 아래의 파일.
내용은 다음과 같습니다. HelloWorld.java 파일-
package com.tutorialspoint;
public class HelloWorld {
private String message;
public void setMessage(String message){
this.message = message;
}
public void getMessage(){
System.out.println("Your Message : " + message);
}
}
다음은 두 번째 파일의 내용입니다. MainApp.java −
package com.tutorialspoint;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class MainApp {
public static void main(String[] args) {
ApplicationContext context = new ClassPathXmlApplicationContext("Beans.xml");
HelloWorld obj = (HelloWorld) context.getBean("helloWorld");
obj.getMessage();
}
}
주요 프로그램에 대해 다음 두 가지 중요한 사항에 유의해야합니다.
첫 번째 단계는 프레임 워크 API를 사용한 애플리케이션 컨텍스트를 만드는 것입니다. ClassPathXmlApplicationContext(). 이 API는 빈 구성 파일을로드하고 결국 제공된 API를 기반으로 모든 개체, 즉 구성 파일에 언급 된 빈을 생성하고 초기화합니다.
두 번째 단계는 다음을 사용하여 필요한 빈을 얻는 데 사용됩니다. getBean()생성 된 컨텍스트의 메서드입니다. 이 메소드는 빈 ID를 사용하여 일반 객체를 반환하며 최종적으로 실제 객체로 캐스팅 할 수 있습니다. 객체가 있으면이 객체를 사용하여 모든 클래스 메서드를 호출 할 수 있습니다.
4 단계-Bean 구성 파일 생성
XML 파일이고 빈, 즉 클래스를 하나로 묶는 시멘트 역할을하는 Bean 구성 파일을 만들어야합니다. 이 파일은src 다음 스크린 샷에 표시된 디렉토리-
일반적으로 개발자는이 파일의 이름을 Beans.xml,하지만 원하는 이름을 선택하는 것은 독립적입니다. 이 파일이 CLASSPATH에서 사용 가능한지 확인하고 MainApp.java 파일에 표시된대로 애플리케이션 컨텍스트를 작성하는 동안 기본 애플리케이션에서 동일한 이름을 사용해야합니다.
Beans.xml은 고유 ID를 다른 Bean에 할당하고 Spring 소스 파일에 영향을주지 않고 다른 값을 가진 객체 생성을 제어하는 데 사용됩니다. 예를 들어, 다음 파일을 사용하여 "message"변수에 대한 모든 값을 전달할 수 있으며 HelloWorld.java 및 MainApp.java 파일에 영향을주지 않고 다른 메시지 값을 인쇄 할 수 있습니다. 어떻게 작동하는지 봅시다.
<?xml version = "1.0" encoding = "UTF-8"?>
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">
<bean id = "helloWorld" class = "com.tutorialspoint.HelloWorld">
<property name = "message" value = "Hello World!"/>
</bean>
</beans>
Spring 애플리케이션이 메모리에로드되면 Framework는 위의 구성 파일을 사용하여 정의 된 모든 Bean을 생성하고 다음에 정의 된 고유 ID를 할당합니다. <bean>꼬리표. 당신이 사용할 수있는<property> 태그를 사용하여 객체 생성시 사용 된 다양한 변수의 값을 전달합니다.
5 단계-프로그램 실행
소스 및 Bean 구성 파일 작성이 완료되면 프로그램을 컴파일하고 실행하는이 단계를 수행 할 준비가 된 것입니다. 이렇게하려면 MainApp.Java 파일 탭을 활성 상태로 유지하고 다음 중 하나를 사용하십시오.Run Eclipse IDE에서 사용 가능한 옵션 또는 Ctrl + F11 컴파일하고 실행하려면 MainApp신청. 응용 프로그램에 문제가 없으면 Eclipse IDE의 콘솔에 다음 메시지가 인쇄됩니다.
Your Message : Hello World!
축하합니다. 첫 번째 Spring 애플리케이션을 성공적으로 만들었습니다. "message"속성의 값을 변경하고 두 소스 파일을 변경하지 않은 상태로 유지함으로써 위 Spring 애플리케이션의 유연성을 확인할 수 있습니다.
Spring 컨테이너는 Spring Framework의 핵심입니다. 컨테이너는 개체를 만들고, 연결하고, 구성하고, 생성부터 파괴까지 전체 수명주기를 관리합니다. Spring 컨테이너는 DI를 사용하여 애플리케이션을 구성하는 구성 요소를 관리합니다. 이러한 객체를 Spring Beans라고하며 다음 장에서 논의 할 것입니다.
컨테이너는 제공된 구성 메타 데이터를 읽어 인스턴스화, 구성 및 어셈블 할 개체에 대한 지침을 얻습니다. 구성 메타 데이터는 XML, Java 주석 또는 Java 코드로 나타낼 수 있습니다. 다음 다이어그램은 Spring의 작동 방식에 대한 높은 수준의보기를 나타냅니다. Spring IoC 컨테이너는 Java POJO 클래스와 구성 메타 데이터를 사용하여 완전히 구성되고 실행 가능한 시스템 또는 애플리케이션을 생성합니다.
Spring은 다음 두 가지 유형의 컨테이너를 제공합니다.
Sr. 아니. | 컨테이너 및 설명 |
---|---|
1 | Spring BeanFactory 컨테이너 이것은 DI에 대한 기본 지원을 제공하는 가장 간단한 컨테이너이며 org.springframework.beans.factory.BeanFactory 인터페이스에 의해 정의됩니다 . BeanFactoryAware, InitializingBean, DisposableBean과 같은 BeanFactory 및 관련 인터페이스는 Spring과 통합되는 많은 타사 프레임 워크와의 역 호환성을 위해 여전히 Spring에 존재합니다. |
2 | Spring ApplicationContext 컨테이너 이 컨테이너는 속성 파일에서 텍스트 메시지를 확인하는 기능 및 관심있는 이벤트 리스너에 애플리케이션 이벤트를 게시하는 기능과 같은 엔터프라이즈 별 기능을 추가합니다. 이 컨테이너는 org.springframework.context.ApplicationContext 인터페이스에 의해 정의됩니다 . |
의 ApplicationContext의 컨테이너는 모든 기능이 포함 되는 BeanFactory 가 일반적으로 이상 권장, 그래서 용기를 BeanFactory에 . BeanFactory는 데이터 볼륨과 속도가 중요한 모바일 장치 또는 애플릿 기반 응용 프로그램과 같은 경량 응용 프로그램에 계속 사용할 수 있습니다.
애플리케이션의 백본을 형성하고 Spring IoC 컨테이너에 의해 관리되는 객체를 호출합니다. beans. 빈은 인스턴스화되고 조립되며 스프링 IoC 컨테이너에 의해 관리되는 객체입니다. 이러한 Bean은 컨테이너에 제공하는 구성 메타 데이터로 작성됩니다. 예를 들어, 이전 장에서 이미 보았던 XML <bean /> 정의 형식입니다.
Bean 정의에는 다음과 같은 정보가 포함됩니다. configuration metadata, 컨테이너가 다음을 알기 위해 필요합니다-
- 콩을 만드는 방법
- Bean의 라이프 사이클 세부 사항
- 빈의 의존성
위의 모든 구성 메타 데이터는 각 Bean 정의를 구성하는 다음 특성 세트로 변환됩니다.
Sr. 아니. | 속성 및 설명 |
---|---|
1 | class 이 속성은 필수이며 Bean을 작성하는 데 사용할 Bean 클래스를 지정합니다. |
2 | name 이 속성은 Bean 식별자를 고유하게 지정합니다. XML 기반 구성 메타 데이터에서 ID 및 / 또는 이름 속성을 사용하여 Bean 식별자를 지정합니다. |
삼 | scope 이 속성은 특정 빈 정의에서 생성 된 객체의 범위를 지정하며 빈 범위 장에서 설명합니다. |
4 | constructor-arg 이것은 의존성을 주입하는데 사용되며 다음 장에서 논의 될 것입니다. |
5 | properties 이것은 의존성을 주입하는데 사용되며 다음 장에서 논의 될 것입니다. |
6 | autowiring mode 이것은 의존성을 주입하는데 사용되며 다음 장에서 논의 될 것입니다. |
7 | lazy-initialization mode lazy-initialized bean은 시작 시가 아니라 처음 요청 될 때 IoC 컨테이너에 bean 인스턴스를 만들도록 지시합니다. |
8 | initialization method 빈에 필요한 모든 속성이 컨테이너에 의해 설정된 직후에 호출되는 콜백. 빈 라이프 사이클 장에서 논의 될 것입니다. |
9 | destruction method 빈을 포함하는 컨테이너가 파괴 될 때 사용할 콜백. 빈 라이프 사이클 장에서 논의 될 것입니다. |
Spring 구성 메타 데이터
Spring IoC 컨테이너는이 구성 메타 데이터가 실제로 작성되는 형식에서 완전히 분리됩니다. 다음은 Spring Container에 구성 메타 데이터를 제공하는 세 가지 중요한 방법입니다.
- XML 기반 구성 파일.
- 주석 기반 구성
- Java 기반 구성
XML 기반 구성 메타 데이터가 컨테이너에 제공되는 방법을 이미 보았지만 지연 초기화, 초기화 방법 및 파괴 방법을 포함하여 다른 빈 정의가있는 XML 기반 구성 파일의 또 다른 샘플을 살펴 보겠습니다.
<?xml version = "1.0" encoding = "UTF-8"?>
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">
<!-- A simple bean definition -->
<bean id = "..." class = "...">
<!-- collaborators and configuration for this bean go here -->
</bean>
<!-- A bean definition with lazy init set on -->
<bean id = "..." class = "..." lazy-init = "true">
<!-- collaborators and configuration for this bean go here -->
</bean>
<!-- A bean definition with initialization method -->
<bean id = "..." class = "..." init-method = "...">
<!-- collaborators and configuration for this bean go here -->
</bean>
<!-- A bean definition with destruction method -->
<bean id = "..." class = "..." destroy-method = "...">
<!-- collaborators and configuration for this bean go here -->
</bean>
<!-- more bean definitions go here -->
</beans>
Spring Hello World Example 을 확인 하여 Spring Beans를 정의, 구성 및 생성하는 방법을 이해할 수 있습니다 .
주석 기반 구성에 대해서는 별도의 장에서 설명합니다. 주석을 사용하여 Spring Dependency Injection으로 프로그래밍을 시작하기 전에 몇 가지 다른 중요한 Spring 개념을 파악하기를 원하므로 별도의 장에서 의도적으로 논의됩니다.
<bean>을 정의 할 때 해당 bean의 범위를 선언하는 옵션이 있습니다. 예를 들어 Spring이 필요할 때마다 새로운 빈 인스턴스를 생성하도록 강제하려면 빈의 범위 속성을 다음과 같이 선언해야합니다.prototype. 마찬가지로 Spring이 필요할 때마다 동일한 빈 인스턴스를 반환하도록하려면 빈의 범위 속성을 다음과 같이 선언해야합니다.singleton.
Spring Framework는 다음 5 개의 범위를 지원하며, 그중 3 개는 웹 인식 ApplicationContext를 사용하는 경우에만 사용할 수 있습니다.
Sr. 아니. | 범위 및 설명 |
---|---|
1 | singleton 이것은 빈 정의의 범위를 Spring IoC 컨테이너 당 단일 인스턴스 (기본값)로 지정합니다. |
2 | prototype 이것은 임의의 수의 오브젝트 인스턴스를 갖도록 단일 Bean 정의의 범위를 지정합니다. |
삼 | request 이것은 빈 정의의 범위를 HTTP 요청으로 지정합니다. 웹 인식 Spring ApplicationContext의 컨텍스트에서만 유효합니다. |
4 | session 이것은 빈 정의의 범위를 HTTP 세션으로 지정합니다. 웹 인식 Spring ApplicationContext의 컨텍스트에서만 유효합니다. |
5 | global-session 이는 빈 정의의 범위를 전역 HTTP 세션으로 지정합니다. 웹 인식 Spring ApplicationContext의 컨텍스트에서만 유효합니다. |
이 장에서는 처음 두 스코프에 대해 논의하고 나머지 세 스코프는 웹 인식 Spring ApplicationContext에 대해 논의 할 때 논의 될 것입니다.
싱글 톤 범위
범위가 싱글 톤으로 설정되면 Spring IoC 컨테이너는 해당 Bean 정의에 의해 정의 된 객체의 정확히 하나의 인스턴스를 생성합니다. 이 단일 인스턴스는 이러한 싱글 톤 Bean의 캐시에 저장되며 해당 명명 된 Bean에 대한 모든 후속 요청과 참조는 캐시 된 객체를 반환합니다.
기본 범위는 항상 싱글 톤입니다. 그러나 Bean의 인스턴스가 하나만 필요한 경우scope 재산 singleton 다음 코드 스 니펫에 표시된대로 Bean 구성 파일에서-
<!-- A bean definition with singleton scope -->
<bean id = "..." class = "..." scope = "singleton">
<!-- collaborators and configuration for this bean go here -->
</bean>
예
작동하는 Eclipse IDE를 준비하고 다음 단계를 수행하여 Spring 애플리케이션을 작성해 보겠습니다.
단계 | 기술 |
---|---|
1 | 이름이 SpringExample 인 프로젝트를 만들고 아래에 com.tutorialspoint 패키지를 만듭니다 .src 생성 된 프로젝트의 폴더. |
2 | Spring Hello World 예제 장에 설명 된대로 Add External JARs 옵션을 사용하여 필요한 Spring 라이브러리를 추가 합니다. |
삼 | com.tutorialspoint 패키지 아래에 Java 클래스 HelloWorld 및 MainApp을 만듭니다 . |
4 | 아래에 Beans 구성 파일 Beans.xml을 만듭니다 .src 폴더. |
5 | 마지막 단계는 모든 Java 파일과 Bean Configuration 파일의 내용을 만들고 아래 설명 된대로 응용 프로그램을 실행하는 것입니다. |
내용은 다음과 같습니다. HelloWorld.java 파일-
package com.tutorialspoint;
public class HelloWorld {
private String message;
public void setMessage(String message){
this.message = message;
}
public void getMessage(){
System.out.println("Your Message : " + message);
}
}
다음은의 내용입니다 MainApp.java 파일-
package com.tutorialspoint;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class MainApp {
public static void main(String[] args) {
ApplicationContext context = new ClassPathXmlApplicationContext("Beans.xml");
HelloWorld objA = (HelloWorld) context.getBean("helloWorld");
objA.setMessage("I'm object A");
objA.getMessage();
HelloWorld objB = (HelloWorld) context.getBean("helloWorld");
objB.getMessage();
}
}
다음은 구성 파일입니다. Beans.xml 싱글 톤 범위에 필요-
<?xml version = "1.0" encoding = "UTF-8"?>
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">
<bean id = "helloWorld" class = "com.tutorialspoint.HelloWorld" scope = "singleton">
</bean>
</beans>
소스 및 빈 구성 파일 생성이 완료되면 애플리케이션을 실행 해 보겠습니다. 응용 프로그램에 문제가 없으면 다음 메시지가 인쇄됩니다.
Your Message : I'm object A
Your Message : I'm object A
프로토 타입 범위
범위가 프로토 타입으로 설정되면 Spring IoC 컨테이너는 특정 빈에 대한 요청이있을 때마다 객체의 새 빈 인스턴스를 생성합니다. 일반적으로 모든 state-full bean에는 프로토 타입 범위를 사용하고 stateless bean에는 싱글 톤 범위를 사용하십시오.
프로토 타입 범위를 정의하려면 scope 재산 prototype 다음 코드 스 니펫에 표시된대로 Bean 구성 파일에서-
<!-- A bean definition with prototype scope -->
<bean id = "..." class = "..." scope = "prototype">
<!-- collaborators and configuration for this bean go here -->
</bean>
예
Eclipse IDE를 제자리에두고 다음 단계에 따라 Spring 애플리케이션을 만듭니다.
단계 | 기술 |
---|---|
1 | 이름이 SpringExample 인 프로젝트를 만들고 아래에 com.tutorialspoint 패키지를 만듭니다 .src 생성 된 프로젝트의 폴더. |
2 | Spring Hello World 예제 장에 설명 된대로 Add External JARs 옵션을 사용하여 필요한 Spring 라이브러리를 추가 합니다. |
삼 | com.tutorialspoint 패키지 아래에 Java 클래스 HelloWorld 및 MainApp을 만듭니다 . |
4 | 아래에 Beans 구성 파일 Beans.xml을 만듭니다 .src 폴더. |
5 | 마지막 단계는 모든 Java 파일과 Bean Configuration 파일의 내용을 만들고 아래 설명 된대로 응용 프로그램을 실행하는 것입니다. |
내용은 다음과 같습니다. HelloWorld.java 파일
package com.tutorialspoint;
public class HelloWorld {
private String message;
public void setMessage(String message){
this.message = message;
}
public void getMessage(){
System.out.println("Your Message : " + message);
}
}
다음은의 내용입니다 MainApp.java 파일-
package com.tutorialspoint;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class MainApp {
public static void main(String[] args) {
ApplicationContext context = new ClassPathXmlApplicationContext("Beans.xml");
HelloWorld objA = (HelloWorld) context.getBean("helloWorld");
objA.setMessage("I'm object A");
objA.getMessage();
HelloWorld objB = (HelloWorld) context.getBean("helloWorld");
objB.getMessage();
}
}
다음은 구성 파일입니다. Beans.xml 프로토 타입 범위에 필요-
<?xml version = "1.0" encoding = "UTF-8"?>
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">
<bean id = "helloWorld" class = "com.tutorialspoint.HelloWorld" scope = "prototype">
</bean>
</beans>
소스 및 빈 구성 파일 생성이 완료되면 애플리케이션을 실행 해 보겠습니다. 응용 프로그램에 문제가 없으면 다음 메시지가 인쇄됩니다.
Your Message : I'm object A
Your Message : null
Spring Bean의 수명주기는 이해하기 쉽습니다. Bean이 인스턴스화 될 때 사용 가능한 상태로 만들기 위해 일부 초기화를 수행해야 할 수 있습니다. 마찬가지로 빈이 더 이상 필요하지 않고 컨테이너에서 제거되면 일부 정리가 필요할 수 있습니다.
빈 인스턴스화와 소멸 사이에이면에서 발생하는 활동 목록이 있지만이 장에서는 빈 초기화 및 소멸시 필요한 두 가지 중요한 빈 라이프 사이클 콜백 메서드에 대해서만 설명합니다.
Bean에 대한 설정 및 분해를 정의하려면 다음을 사용하여 <bean>을 선언하기 만하면됩니다. initmethod 및 / 또는 destroy-method매개 변수. init-method 속성은 인스턴스화 즉시 Bean에서 호출 될 메소드를 지정합니다. 마찬가지로 destroymethod는 컨테이너에서 Bean이 제거되기 직전에 호출되는 메소드를 지정합니다.
초기화 콜백
org.springframework.beans.factory.InitializingBean 인터페이스는 단일 메소드를 지정합니다.
void afterPropertiesSet() throws Exception;
따라서 위의 인터페이스를 간단히 구현할 수 있으며 초기화 작업은 다음과 같이 afterPropertiesSet () 메서드 내에서 수행 할 수 있습니다.
public class ExampleBean implements InitializingBean {
public void afterPropertiesSet() {
// do some initialization work
}
}
XML 기반 구성 메타 데이터의 경우 다음을 사용할 수 있습니다. init-method인수가없는 빈 서명이있는 메서드의 이름을 지정하는 속성입니다. 예를 들면-
<bean id = "exampleBean" class = "examples.ExampleBean" init-method = "init"/>
다음은 클래스 정의입니다-
public class ExampleBean {
public void init() {
// do some initialization work
}
}
파괴 콜백
org.springframework.beans.factory.DisposableBean 인터페이스는 하나의 방법을 지정 -
void destroy() throws Exception;
따라서 위의 인터페이스를 간단히 구현할 수 있으며 다음과 같이 destroy () 메서드 내에서 마무리 작업을 수행 할 수 있습니다.
public class ExampleBean implements DisposableBean {
public void destroy() {
// do some destruction work
}
}
XML 기반 구성 메타 데이터의 경우 다음을 사용할 수 있습니다. destroy-method인수가없는 빈 서명이있는 메서드의 이름을 지정하는 속성입니다. 예를 들면-
<bean id = "exampleBean" class = "examples.ExampleBean" destroy-method = "destroy"/>
다음은 클래스 정의입니다-
public class ExampleBean {
public void destroy() {
// do some destruction work
}
}
웹이 아닌 애플리케이션 환경에서 Spring의 IoC 컨테이너를 사용하고 있다면; 예를 들어, 리치 클라이언트 데스크탑 환경에서 JVM에 종료 후크를 등록합니다. 이렇게하면 정상적인 종료가 보장되고 모든 리소스가 해제되도록 싱글 톤 Bean에서 관련 파괴 메소드를 호출합니다.
XML 구성은 메소드 이름 지정 측면에서 많은 유연성을 제공하므로 InitializingBean 또는 DisposableBean 콜백을 사용하지 않는 것이 좋습니다.
예
작동하는 Eclipse IDE를 준비하고 다음 단계를 수행하여 Spring 애플리케이션을 작성해 보겠습니다.
단계 | 기술 |
---|---|
1 | 이름이 SpringExample 인 프로젝트를 만들고 아래에 com.tutorialspoint 패키지를 만듭니다 .src 생성 된 프로젝트의 폴더. |
2 | Spring Hello World 예제 장에 설명 된대로 Add External JARs 옵션을 사용하여 필요한 Spring 라이브러리를 추가 합니다. |
삼 | com.tutorialspoint 패키지 아래에 Java 클래스 HelloWorld 및 MainApp을 만듭니다 . |
4 | 아래에 Beans 구성 파일 Beans.xml을 만듭니다 .src 폴더. |
5 | 마지막 단계는 모든 Java 파일과 Bean Configuration 파일의 내용을 만들고 아래 설명 된대로 응용 프로그램을 실행하는 것입니다. |
내용은 다음과 같습니다. HelloWorld.java 파일-
package com.tutorialspoint;
public class HelloWorld {
private String message;
public void setMessage(String message){
this.message = message;
}
public void getMessage(){
System.out.println("Your Message : " + message);
}
public void init(){
System.out.println("Bean is going through init.");
}
public void destroy() {
System.out.println("Bean will destroy now.");
}
}
다음은의 내용입니다 MainApp.java파일. 여기에서 종료 후크를 등록해야합니다.registerShutdownHook()AbstractApplicationContext 클래스에 선언 된 메서드입니다. 이것은 정상적인 종료를 보장하고 관련 파괴 메소드를 호출합니다.
package com.tutorialspoint;
import org.springframework.context.support.AbstractApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class MainApp {
public static void main(String[] args) {
AbstractApplicationContext context = new ClassPathXmlApplicationContext("Beans.xml");
HelloWorld obj = (HelloWorld) context.getBean("helloWorld");
obj.getMessage();
context.registerShutdownHook();
}
}
다음은 구성 파일입니다. Beans.xml init 및 destroy 메소드에 필요-
<?xml version = "1.0" encoding = "UTF-8"?>
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">
<bean id = "helloWorld" class = "com.tutorialspoint.HelloWorld" init-method = "init"
destroy-method = "destroy">
<property name = "message" value = "Hello World!"/>
</bean>
</beans>
소스 및 빈 구성 파일 생성이 완료되면 애플리케이션을 실행 해 보겠습니다. 응용 프로그램에 문제가 없으면 다음 메시지가 인쇄됩니다.
Bean is going through init.
Your Message : Hello World!
Bean will destroy now.
기본 초기화 및 삭제 방법
같은 이름의 초기화 및 / 또는 파괴 메소드를 가진 Bean이 너무 많으면 선언 할 필요가 없습니다. init-method 과 destroy-method각 개별 콩에. 대신 프레임 워크는 다음을 사용하여 이러한 상황을 구성 할 수있는 유연성을 제공합니다.default-init-method 과 default-destroy-method 다음과 같이 <beans> 요소의 속성-
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd"
default-init-method = "init"
default-destroy-method = "destroy">
<bean id = "..." class = "...">
<!-- collaborators and configuration for this bean go here -->
</bean>
</beans>
그만큼 BeanPostProcessor 인터페이스는 자체 인스턴스화 로직, 종속성 해결 로직 등을 제공하기 위해 구현할 수있는 콜백 메소드를 정의합니다. Spring 컨테이너가 하나 이상의 BeanPostProcessor 구현을 연결하여 Bean의 인스턴스화, 구성 및 초기화를 완료 한 후 일부 사용자 정의 로직을 구현할 수도 있습니다. .
여러 BeanPostProcessor 인터페이스를 구성 할 수 있으며 다음을 설정하여 이러한 BeanPostProcessor 인터페이스가 실행되는 순서를 제어 할 수 있습니다. order BeanPostProcessor가 Ordered 상호 작용.
BeanPostProcessor는 Bean (또는 객체) 인스턴스에서 작동합니다. 이는 Spring IoC 컨테이너가 Bean 인스턴스를 인스턴스화 한 다음 BeanPostProcessor 인터페이스가 작업을 수행함을 의미합니다.
안 ApplicationContext 구현으로 정의 된 모든 빈을 자동으로 감지합니다. BeanPostProcessor 이 빈을 포스트 프로세서로 등록하고 빈 생성시 컨테이너에 의해 적절하게 호출됩니다.
예
다음 예제는 ApplicationContext의 컨텍스트에서 BeanPostProcessors를 작성, 등록 및 사용하는 방법을 보여줍니다.
작동하는 Eclipse IDE를 준비하고 다음 단계를 수행하여 Spring 애플리케이션을 작성해 보겠습니다.
단계 | 기술 |
---|---|
1 | 이름이 SpringExample 인 프로젝트를 만들고 아래에 com.tutorialspoint 패키지를 만듭니다 .src 생성 된 프로젝트의 폴더. |
2 | Spring Hello World 예제 장에 설명 된대로 Add External JARs 옵션을 사용하여 필요한 Spring 라이브러리를 추가 합니다. |
삼 | com.tutorialspoint 패키지 아래에 Java 클래스 HelloWorld , InitHelloWorld 및 MainApp을 작성하십시오 . |
4 | 아래에 Beans 구성 파일 Beans.xml을 만듭니다 .src 폴더. |
5 | 마지막 단계는 모든 Java 파일과 Bean Configuration 파일의 내용을 만들고 아래 설명 된대로 응용 프로그램을 실행하는 것입니다. |
내용은 다음과 같습니다. HelloWorld.java 파일-
package com.tutorialspoint;
public class HelloWorld {
private String message;
public void setMessage(String message){
this.message = message;
}
public void getMessage(){
System.out.println("Your Message : " + message);
}
public void init(){
System.out.println("Bean is going through init.");
}
public void destroy(){
System.out.println("Bean will destroy now.");
}
}
이것은 Bean의 초기화 전후에 Bean 이름을 인쇄하는 BeanPostProcessor를 구현하는 매우 기본적인 예제입니다. 두 포스트 프로세서 메소드 내에서 Bean 객체에 액세스 할 수 있으므로 Bean 초기화 전후에 더 복잡한 로직을 구현할 수 있습니다.
내용은 다음과 같습니다. InitHelloWorld.java 파일-
package com.tutorialspoint;
import org.springframework.beans.factory.config.BeanPostProcessor;
import org.springframework.beans.BeansException;
public class InitHelloWorld implements BeanPostProcessor {
public Object postProcessBeforeInitialization(Object bean, String beanName)
throws BeansException {
System.out.println("BeforeInitialization : " + beanName);
return bean; // you can return any other object as well
}
public Object postProcessAfterInitialization(Object bean, String beanName)
throws BeansException {
System.out.println("AfterInitialization : " + beanName);
return bean; // you can return any other object as well
}
}
다음은의 내용입니다 MainApp.java파일. 여기에서 종료 후크를 등록해야합니다.registerShutdownHook()AbstractApplicationContext 클래스에 선언 된 메서드입니다. 이것은 정상적인 종료를 보장하고 관련 파괴 메소드를 호출합니다.
package com.tutorialspoint;
import org.springframework.context.support.AbstractApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class MainApp {
public static void main(String[] args) {
AbstractApplicationContext context = new ClassPathXmlApplicationContext("Beans.xml");
HelloWorld obj = (HelloWorld) context.getBean("helloWorld");
obj.getMessage();
context.registerShutdownHook();
}
}
다음은 구성 파일입니다. Beans.xml init 및 destroy 메소드에 필요-
<?xml version = "1.0" encoding = "UTF-8"?>
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">
<bean id = "helloWorld" class = "com.tutorialspoint.HelloWorld"
init-method = "init" destroy-method = "destroy">
<property name = "message" value = "Hello World!"/>
</bean>
<bean class = "com.tutorialspoint.InitHelloWorld" />
</beans>
소스 및 빈 구성 파일 생성이 완료되면 애플리케이션을 실행하겠습니다. 응용 프로그램에 문제가 없으면 다음 메시지가 인쇄됩니다.
BeforeInitialization : helloWorld
Bean is going through init.
AfterInitialization : helloWorld
Your Message : Hello World!
Bean will destroy now.
Bean 정의에는 생성자 인수, 속성 값 및 초기화 메서드, 정적 팩토리 메서드 이름 등과 같은 컨테이너 관련 정보를 비롯한 많은 구성 정보가 포함될 수 있습니다.
하위 Bean 정의는 상위 정의에서 구성 데이터를 상속합니다. 하위 정의는 필요에 따라 일부 값을 재정의하거나 다른 값을 추가 할 수 있습니다.
Spring Bean 정의 상속은 Java 클래스 상속과 관련이 없지만 상속 개념은 동일합니다. 상위 Bean 정의를 템플리트로 정의 할 수 있으며 다른 하위 Bean은 상위 Bean에서 필요한 구성을 상속 할 수 있습니다.
XML 기반 구성 메타 데이터를 사용하는 경우 다음을 사용하여 하위 Bean 정의를 표시합니다. parent 이 속성의 값으로 상위 Bean을 지정하는 속성.
예
작동하는 Eclipse IDE를 준비하고 다음 단계를 수행하여 Spring 애플리케이션을 작성해 보겠습니다.
단계 | 기술 |
---|---|
1 | 이름이 SpringExample 인 프로젝트를 만들고 아래에 com.tutorialspoint 패키지를 만듭니다 .src 생성 된 프로젝트의 폴더. |
2 | Spring Hello World 예제 장에 설명 된대로 Add External JARs 옵션을 사용하여 필요한 Spring 라이브러리를 추가 합니다. |
삼 | com.tutorialspoint 패키지 아래에 Java 클래스 HelloWorld , HelloIndia 및 MainApp을 만듭니다 . |
4 | 아래에 Beans 구성 파일 Beans.xml을 만듭니다 .src 폴더. |
5 | 마지막 단계는 모든 Java 파일과 Bean Configuration 파일의 내용을 만들고 아래 설명 된대로 응용 프로그램을 실행하는 것입니다. |
다음은 구성 파일입니다. Beans.xml여기서 우리는 message1 과 message2 두 개의 속성을 가진 "helloWorld"빈을 정의했습니다 . 다음으로 "helloIndia"bean은 다음을 사용하여 "helloWorld"bean의 자식으로 정의되었습니다.parent속성. 자식 bean 은 message2 속성을 그대로 상속 하고 message1 속성을 재정의 하고 message3 속성을 하나 더 도입 합니다.
<?xml version = "1.0" encoding = "UTF-8"?>
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">
<bean id = "helloWorld" class = "com.tutorialspoint.HelloWorld">
<property name = "message1" value = "Hello World!"/>
<property name = "message2" value = "Hello Second World!"/>
</bean>
<bean id ="helloIndia" class = "com.tutorialspoint.HelloIndia" parent = "helloWorld">
<property name = "message1" value = "Hello India!"/>
<property name = "message3" value = "Namaste India!"/>
</bean>
</beans>
내용은 다음과 같습니다. HelloWorld.java 파일-
package com.tutorialspoint;
public class HelloWorld {
private String message1;
private String message2;
public void setMessage1(String message){
this.message1 = message;
}
public void setMessage2(String message){
this.message2 = message;
}
public void getMessage1(){
System.out.println("World Message1 : " + message1);
}
public void getMessage2(){
System.out.println("World Message2 : " + message2);
}
}
내용은 다음과 같습니다. HelloIndia.java 파일-
package com.tutorialspoint;
public class HelloIndia {
private String message1;
private String message2;
private String message3;
public void setMessage1(String message){
this.message1 = message;
}
public void setMessage2(String message){
this.message2 = message;
}
public void setMessage3(String message){
this.message3 = message;
}
public void getMessage1(){
System.out.println("India Message1 : " + message1);
}
public void getMessage2(){
System.out.println("India Message2 : " + message2);
}
public void getMessage3(){
System.out.println("India Message3 : " + message3);
}
}
다음은의 내용입니다 MainApp.java 파일-
package com.tutorialspoint;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class MainApp {
public static void main(String[] args) {
ApplicationContext context = new ClassPathXmlApplicationContext("Beans.xml");
HelloWorld objA = (HelloWorld) context.getBean("helloWorld");
objA.getMessage1();
objA.getMessage2();
HelloIndia objB = (HelloIndia) context.getBean("helloIndia");
objB.getMessage1();
objB.getMessage2();
objB.getMessage3();
}
}
소스 및 빈 구성 파일 생성이 완료되면 애플리케이션을 실행 해 보겠습니다. 응용 프로그램에 문제가 없으면 다음 메시지가 인쇄됩니다.
World Message1 : Hello World!
World Message2 : Hello Second World!
India Message1 : Hello India!
India Message2 : Hello Second World!
India Message3 : Namaste India!
여기서 살펴보면 "helloIndia"bean을 생성하는 동안 message2를 전달하지 않았지만 Bean Definition Inheritance 때문에 전달되었습니다.
빈 정의 템플릿
많은 노력을 기울이지 않고 다른 자식 빈 정의에서 사용할 수있는 빈 정의 템플릿을 만들 수 있습니다. Bean 정의 템플릿을 정의하는 동안class 속성을 지정해야합니다. abstract 속성 값으로 추상 속성을 지정해야합니다. true 다음 코드 스 니펫에서 볼 수 있듯이-
<?xml version = "1.0" encoding = "UTF-8"?>
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">
<bean id = "beanTeamplate" abstract = "true">
<property name = "message1" value = "Hello World!"/>
<property name = "message2" value = "Hello Second World!"/>
<property name = "message3" value = "Namaste India!"/>
</bean>
<bean id = "helloIndia" class = "com.tutorialspoint.HelloIndia" parent = "beanTeamplate">
<property name = "message1" value = "Hello India!"/>
<property name = "message3" value = "Namaste India!"/>
</bean>
</beans>
부모 빈은 불완전하기 때문에 자체적으로 인스턴스화 할 수 없으며 명시 적으로 abstract 로 표시됩니다 . 정의가 이와 같이 추상적 인 경우 하위 정의에 대한 상위 정의 역할을하는 순수 템플릿 Bean 정의로만 사용할 수 있습니다.
모든 Java 기반 애플리케이션에는 최종 사용자가 작동하는 애플리케이션으로 보는 것을 표시하기 위해 함께 작동하는 몇 가지 개체가 있습니다. 복잡한 Java 애플리케이션을 작성할 때 애플리케이션 클래스는 다른 Java 클래스와 가능한 한 독립적이어야 이러한 클래스를 재사용하고 단위 테스트 중에 다른 클래스와 독립적으로 테스트 할 수 있습니다. 의존성 주입 (또는 와이어 링이라고도 함)은 이러한 클래스를 하나로 묶고 동시에 독립적으로 유지하는 데 도움이됩니다.
텍스트 편집기 구성 요소가 있고 맞춤법 검사를 제공하려는 응용 프로그램이 있다고 가정합니다. 표준 코드는 다음과 같습니다.
public class TextEditor {
private SpellChecker spellChecker;
public TextEditor() {
spellChecker = new SpellChecker();
}
}
여기서 우리가 한 것은 TextEditor와 SpellChecker 사이에 의존성을 생성하는 것입니다. 반전 제어 시나리오에서 대신 다음과 같은 작업을 수행합니다.
public class TextEditor {
private SpellChecker spellChecker;
public TextEditor(SpellChecker spellChecker) {
this.spellChecker = spellChecker;
}
}
여기서 TextEditor는 SpellChecker 구현에 대해 걱정할 필요가 없습니다. SpellChecker는 독립적으로 구현되며 TextEditor 인스턴스화시 TextEditor에 제공됩니다. 이 전체 절차는 Spring Framework에 의해 제어됩니다.
여기서는 TextEditor에서 전체 제어를 제거하고 다른 곳에 보관했습니다 (예 : XML 구성 파일). 종속성 (예 : SpellChecker 클래스)이 TextEditor 클래스에 주입됩니다. Class Constructor. 따라서 일부 외부 시스템에 대한 종속성을 효과적으로 위임했기 때문에 제어 흐름이 DI (Dependency Injection)에 의해 "반전"되었습니다.
의존성을 주입하는 두 번째 방법은 Setter MethodsSpellChecker 인스턴스를 생성 할 TextEditor 클래스의 이 인스턴스는 Setter 메서드를 호출하여 TextEditor의 속성을 초기화하는 데 사용됩니다.
따라서 DI는 두 가지 주요 변형으로 존재하며 다음 두 하위 장에서는 두 가지를 예제로 다룹니다.
Sr. 아니. | 의존성 주입 유형 및 설명 |
---|---|
1 | 생성자 기반 종속성 주입 생성자 기반 DI는 컨테이너가 각각 다른 클래스에 대한 종속성을 나타내는 여러 인수를 사용하여 클래스 생성자를 호출 할 때 수행됩니다. |
2 | 세터 기반 종속성 주입 Setter 기반 DI는 빈을 인스턴스화하기 위해 인수없는 생성자 또는 인수없는 정적 팩토리 메서드를 호출 한 후 빈에서 setter 메서드를 호출하는 컨테이너에 의해 수행됩니다. |
생성자 기반 및 세터 기반 DI를 모두 혼합 할 수 있지만 필수 종속성에는 생성자 인수를 사용하고 선택적 종속성에는 설정자를 사용하는 것이 좋습니다.
코드는 DI 원칙에 따라 더 깔끔하고 디커플링은 객체에 종속성이 제공 될 때 더 효과적입니다. 객체는 종속성을 조회하지 않으며 종속성의 위치 또는 클래스를 알지 못하며 모든 것이 Spring Framework에서 처리됩니다.
아시다시피 Java 내부 클래스는 다른 클래스의 범위 내에서 정의됩니다. inner beans다른 Bean의 범위 내에 정의 된 Bean입니다. 따라서 <property /> 또는 <constructor-arg /> 요소 내부의 <bean /> 요소를 내부 Bean이라고하며 다음과 같이 표시됩니다.
<?xml version = "1.0" encoding = "UTF-8"?>
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">
<bean id = "outerBean" class = "...">
<property name = "target">
<bean id = "innerBean" class = "..."/>
</property>
</bean>
</beans>
예
Eclipse IDE를 제자리에두고 다음 단계에 따라 Spring 애플리케이션을 만듭니다.
단계 | 기술 |
---|---|
1 | 이름이 SpringExample 인 프로젝트를 만들고 아래에 com.tutorialspoint 패키지를 만듭니다 .src 생성 된 프로젝트의 폴더. |
2 | Spring Hello World 예제 장에 설명 된대로 Add External JARs 옵션을 사용하여 필요한 Spring 라이브러리를 추가 합니다. |
삼 | com.tutorialspoint 패키지 아래에 Java 클래스 TextEditor , SpellChecker 및 MainApp을 작성하십시오 . |
4 | 아래에 Beans 구성 파일 Beans.xml을 만듭니다 .src 폴더. |
5 | 마지막 단계는 모든 Java 파일과 Bean Configuration 파일의 내용을 만들고 아래 설명 된대로 응용 프로그램을 실행하는 것입니다. |
내용은 다음과 같습니다. TextEditor.java 파일-
package com.tutorialspoint;
public class TextEditor {
private SpellChecker spellChecker;
// a setter method to inject the dependency.
public void setSpellChecker(SpellChecker spellChecker) {
System.out.println("Inside setSpellChecker." );
this.spellChecker = spellChecker;
}
// a getter method to return spellChecker
public SpellChecker getSpellChecker() {
return spellChecker;
}
public void spellCheck() {
spellChecker.checkSpelling();
}
}
다음은 다른 종속 클래스 파일의 내용입니다. SpellChecker.java −
package com.tutorialspoint;
public class SpellChecker {
public SpellChecker(){
System.out.println("Inside SpellChecker constructor." );
}
public void checkSpelling(){
System.out.println("Inside checkSpelling." );
}
}
다음은의 내용입니다 MainApp.java 파일-
package com.tutorialspoint;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class MainApp {
public static void main(String[] args) {
ApplicationContext context = new ClassPathXmlApplicationContext("Beans.xml");
TextEditor te = (TextEditor) context.getBean("textEditor");
te.spellCheck();
}
}
다음은 구성 파일입니다. Beans.xml setter 기반 주입에 대한 구성이 있지만 inner beans −
<?xml version = "1.0" encoding = "UTF-8"?>
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">
<!-- Definition for textEditor bean using inner bean -->
<bean id = "textEditor" class = "com.tutorialspoint.TextEditor">
<property name = "spellChecker">
<bean id = "spellChecker" class = "com.tutorialspoint.SpellChecker"/>
</property>
</bean>
</beans>
소스 및 빈 구성 파일 생성이 완료되면 애플리케이션을 실행 해 보겠습니다. 응용 프로그램에 문제가 없으면 다음 메시지가 인쇄됩니다.
Inside SpellChecker constructor.
Inside setSpellChecker.
Inside checkSpelling.
다음을 사용하여 기본 데이터 유형을 구성하는 방법을 보았습니다. value 속성 및 객체 참조 refBean 구성 파일에있는 <property> 태그의 속성. 두 경우 모두 단일 값을 빈에 전달하는 작업을 처리합니다.
이제 List, Set, Map 및 Properties와 같은 Java 컬렉션 유형과 같은 복수 값을 전달하려면 어떻게해야합니까? 상황을 처리하기 위해 Spring은 다음과 같은 네 가지 유형의 컬렉션 구성 요소를 제공합니다.
Sr. 아니요 | 요소 및 설명 |
---|---|
1 | <list> 이것은 배선, 즉 값 목록을 삽입하여 중복을 허용하는 데 도움이됩니다. |
2 | <set> 이것은 값 세트를 연결하는 데 도움이되지만 중복은 없습니다. |
삼 | <map> 이것은 이름과 값이 모든 유형이 될 수있는 이름-값 쌍의 컬렉션을 삽입하는 데 사용할 수 있습니다. |
4 | <props> 이것은 이름과 값이 모두 문자열 인 이름-값 쌍의 모음을 삽입하는 데 사용할 수 있습니다. |
<list> 또는 <set>을 사용하여 java.util.Collection 또는 array.
(a) 컬렉션의 직접 값 전달 및 (b) 컬렉션 요소 중 하나로 빈 참조 전달 두 가지 상황이 발생합니다.
예
작동하는 Eclipse IDE를 준비하고 다음 단계를 수행하여 Spring 애플리케이션을 작성해 보겠습니다.
단계 | 기술 |
---|---|
1 | 이름이 SpringExample 인 프로젝트를 만들고 아래에 com.tutorialspoint 패키지를 만듭니다 .src 생성 된 프로젝트의 폴더. |
2 | Spring Hello World 예제 장에 설명 된대로 Add External JARs 옵션을 사용하여 필요한 Spring 라이브러리를 추가 합니다. |
삼 | com.tutorialspoint 패키지 아래에 Java 클래스 JavaCollection 및 MainApp을 작성하십시오 . |
4 | 아래에 Beans 구성 파일 Beans.xml을 만듭니다 .src 폴더. |
5 | 마지막 단계는 모든 Java 파일과 Bean Configuration 파일의 내용을 만들고 아래 설명 된대로 응용 프로그램을 실행하는 것입니다. |
내용은 다음과 같습니다. JavaCollection.java 파일-
package com.tutorialspoint;
import java.util.*;
public class JavaCollection {
List addressList;
Set addressSet;
Map addressMap;
Properties addressProp;
// a setter method to set List
public void setAddressList(List addressList) {
this.addressList = addressList;
}
// prints and returns all the elements of the list.
public List getAddressList() {
System.out.println("List Elements :" + addressList);
return addressList;
}
// a setter method to set Set
public void setAddressSet(Set addressSet) {
this.addressSet = addressSet;
}
// prints and returns all the elements of the Set.
public Set getAddressSet() {
System.out.println("Set Elements :" + addressSet);
return addressSet;
}
// a setter method to set Map
public void setAddressMap(Map addressMap) {
this.addressMap = addressMap;
}
// prints and returns all the elements of the Map.
public Map getAddressMap() {
System.out.println("Map Elements :" + addressMap);
return addressMap;
}
// a setter method to set Property
public void setAddressProp(Properties addressProp) {
this.addressProp = addressProp;
}
// prints and returns all the elements of the Property.
public Properties getAddressProp() {
System.out.println("Property Elements :" + addressProp);
return addressProp;
}
}
다음은의 내용입니다 MainApp.java 파일-
package com.tutorialspoint;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class MainApp {
public static void main(String[] args) {
ApplicationContext context = new ClassPathXmlApplicationContext("Beans.xml");
JavaCollection jc=(JavaCollection)context.getBean("javaCollection");
jc.getAddressList();
jc.getAddressSet();
jc.getAddressMap();
jc.getAddressProp();
}
}
다음은 구성 파일입니다. Beans.xml 모든 유형의 컬렉션에 대한 구성이 있습니다.
<?xml version = "1.0" encoding = "UTF-8"?>
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">
<!-- Definition for javaCollection -->
<bean id = "javaCollection" class = "com.tutorialspoint.JavaCollection">
<!-- results in a setAddressList(java.util.List) call -->
<property name = "addressList">
<list>
<value>INDIA</value>
<value>Pakistan</value>
<value>USA</value>
<value>USA</value>
</list>
</property>
<!-- results in a setAddressSet(java.util.Set) call -->
<property name = "addressSet">
<set>
<value>INDIA</value>
<value>Pakistan</value>
<value>USA</value>
<value>USA</value>
</set>
</property>
<!-- results in a setAddressMap(java.util.Map) call -->
<property name = "addressMap">
<map>
<entry key = "1" value = "INDIA"/>
<entry key = "2" value = "Pakistan"/>
<entry key = "3" value = "USA"/>
<entry key = "4" value = "USA"/>
</map>
</property>
<!-- results in a setAddressProp(java.util.Properties) call -->
<property name = "addressProp">
<props>
<prop key = "one">INDIA</prop>
<prop key = "one">INDIA</prop>
<prop key = "two">Pakistan</prop>
<prop key = "three">USA</prop>
<prop key = "four">USA</prop>
</props>
</property>
</bean>
</beans>
소스 및 빈 구성 파일 생성이 완료되면 애플리케이션을 실행 해 보겠습니다. 응용 프로그램에 문제가 없으면 다음 메시지가 인쇄됩니다.
List Elements :[INDIA, Pakistan, USA, USA]
Set Elements :[INDIA, Pakistan, USA]
ap Elements :{1 = INDIA, 2 = Pakistan, 3 = USA, 4 = USA}
Property Elements :{two = Pakistan, one = INDIA, three = USA, four = USA}
빈 참조 주입
다음 빈 정의는 컬렉션의 요소 중 하나로 빈 참조를 주입하는 방법을 이해하는 데 도움이됩니다. 다음 코드 스 니펫과 같이 참조와 값을 모두 함께 혼합 할 수도 있습니다.
<?xml version = "1.0" encoding = "UTF-8"?>
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">
<!-- Bean Definition to handle references and values -->
<bean id = "..." class = "...">
<!-- Passing bean reference for java.util.List -->
<property name = "addressList">
<list>
<ref bean = "address1"/>
<ref bean = "address2"/>
<value>Pakistan</value>
</list>
</property>
<!-- Passing bean reference for java.util.Set -->
<property name = "addressSet">
<set>
<ref bean = "address1"/>
<ref bean = "address2"/>
<value>Pakistan</value>
</set>
</property>
<!-- Passing bean reference for java.util.Map -->
<property name = "addressMap">
<map>
<entry key = "one" value = "INDIA"/>
<entry key = "two" value-ref = "address1"/>
<entry key = "three" value-ref = "address2"/>
</map>
</property>
</bean>
</beans>
위의 빈 정의를 사용하려면 참조도 처리 할 수있는 방식으로 setter 메서드를 정의해야합니다.
null 및 빈 문자열 값 삽입
빈 문자열을 값으로 전달해야하는 경우 다음과 같이 전달할 수 있습니다.
<bean id = "..." class = "exampleBean">
<property name = "email" value = ""/>
</bean>
앞의 예제는 Java 코드와 동일합니다. exampleBean.setEmail ( "")
NULL 값을 전달해야하는 경우 다음과 같이 전달할 수 있습니다.
<bean id = "..." class = "exampleBean">
<property name = "email"><null/></property>
</bean>
앞의 예제는 Java 코드와 동일합니다. exampleBean.setEmail (null)
XML 구성 파일에서 <bean> 요소를 사용하여 Bean을 선언하고 <constructor-arg> 및 <property> 요소를 사용하여 <bean>을 삽입하는 방법을 배웠습니다.
Spring 컨테이너는 autowire <constructor-arg> 및 <property> 요소를 사용하지 않고 협업 Bean 간의 관계를 제공하므로 대규모 Spring 기반 애플리케이션에 대해 작성하는 XML 구성의 양을 줄이는 데 도움이됩니다.
자동 배선 모드
다음은 Spring 컨테이너가 종속성 주입에 자동 연결을 사용하도록 지시하는 데 사용할 수있는 자동 연결 모드입니다. <bean /> 요소의 autowire 속성을 사용하여autowire 빈 정의 모드.
Sr. 아니요 | 모드 및 설명 |
---|---|
1 | no 이것은 자동 연결이 없음을 의미하는 기본 설정이며 연결을 위해 명시적인 빈 참조를 사용해야합니다. 이 배선에 대해 특별히 할 일은 없습니다. 이것은 Dependency Injection 장에서 이미 본 것입니다. |
2 | 이름으로 속성 이름으로 자동 연결. Spring 컨테이너는 XML 구성 파일에서 autowire 속성이 byName 으로 설정된 Bean의 속성을 확인 합니다. 그런 다음 구성 파일에서 동일한 이름으로 정의 된 Bean과 속성을 일치시키고 연결하려고합니다. |
삼 | byType 속성 데이터 유형별 자동 연결. Spring 컨테이너는 XML 구성 파일에서 autowire 속성이 byType 으로 설정된 Bean의 속성을 확인 합니다. 그런 다음 속성을 일치시키고 연결하려고합니다.type구성 파일의 Bean 이름 중 정확히 하나와 일치합니다. 그러한 Bean이 둘 이상 있으면 치명적인 예외가 발생합니다. |
4 | constructor Similar to byType, but type applies to constructor arguments. If there is not exactly one bean of the constructor argument type in the container, a fatal error is raised. |
5 | autodetect Spring first tries to wire using autowire by constructor, if it does not work, Spring tries to autowire by byType. |
You can use byType or constructor autowiring mode to wire arrays and other typed-collections.
Limitations with autowiring
Autowiring works best when it is used consistently across a project. If autowiring is not used in general, it might be confusing for developers to use it to wire only one or two bean definitions. Though, autowiring can significantly reduce the need to specify properties or constructor arguments but you should consider the limitations and disadvantages of autowiring before using them.
Sr.No. | Limitations & Description |
---|---|
1 | Overriding possibility You can still specify dependencies using <constructor-arg> and <property> settings which will always override autowiring. |
2 | Primitive data types You cannot autowire so-called simple properties such as primitives, Strings, and Classes. |
3 | Confusing nature Autowiring is less exact than explicit wiring, so if possible prefer using explict wiring. |
Starting from Spring 2.5 it became possible to configure the dependency injection using annotations. So instead of using XML to describe a bean wiring, you can move the bean configuration into the component class itself by using annotations on the relevant class, method, or field declaration.
Annotation injection is performed before XML injection. Thus, the latter configuration will override the former for properties wired through both approaches.
Annotation wiring is not turned on in the Spring container by default. So, before we can use annotation-based wiring, we will need to enable it in our Spring configuration file. So consider the following configuration file in case you want to use any annotation in your Spring application.
<?xml version = "1.0" encoding = "UTF-8"?>
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xmlns:context = "http://www.springframework.org/schema/context"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd">
<context:annotation-config/>
<!-- bean definitions go here -->
</beans>
Once <context:annotation-config/> is configured, you can start annotating your code to indicate that Spring should automatically wire values into properties, methods, and constructors. Let us look at a few important annotations to understand how they work −
Sr.No. | Annotation & Description |
---|---|
1 | @Required The @Required annotation applies to bean property setter methods. |
2 | @Autowired The @Autowired annotation can apply to bean property setter methods, non-setter methods, constructor and properties. |
3 | @Qualifier The @Qualifier annotation along with @Autowired can be used to remove the confusion by specifiying which exact bean will be wired. |
4 | JSR-250 Annotations Spring supports JSR-250 based annotations which include @Resource, @PostConstruct and @PreDestroy annotations. |
So far you have seen how we configure Spring beans using XML configuration file. If you are comfortable with XML configuration, then it is really not required to learn how to proceed with Java-based configuration as you are going to achieve the same result using either of the configurations available.
Java-based configuration option enables you to write most of your Spring configuration without XML but with the help of few Java-based annotations explained in this chapter.
@Configuration & @Bean Annotations
Annotating a class with the @Configuration indicates that the class can be used by the Spring IoC container as a source of bean definitions. The @Bean annotation tells Spring that a method annotated with @Bean will return an object that should be registered as a bean in the Spring application context. The simplest possible @Configuration class would be as follows −
package com.tutorialspoint;
import org.springframework.context.annotation.*;
@Configuration
public class HelloWorldConfig {
@Bean
public HelloWorld helloWorld(){
return new HelloWorld();
}
}
The above code will be equivalent to the following XML configuration −
<beans>
<bean id = "helloWorld" class = "com.tutorialspoint.HelloWorld" />
</beans>
Here, the method name is annotated with @Bean works as bean ID and it creates and returns the actual bean. Your configuration class can have a declaration for more than one @Bean. Once your configuration classes are defined, you can load and provide them to Spring container using AnnotationConfigApplicationContext as follows −
public static void main(String[] args) {
ApplicationContext ctx = new AnnotationConfigApplicationContext(HelloWorldConfig.class);
HelloWorld helloWorld = ctx.getBean(HelloWorld.class);
helloWorld.setMessage("Hello World!");
helloWorld.getMessage();
}
You can load various configuration classes as follows −
public static void main(String[] args) {
AnnotationConfigApplicationContext ctx = new AnnotationConfigApplicationContext();
ctx.register(AppConfig.class, OtherConfig.class);
ctx.register(AdditionalConfig.class);
ctx.refresh();
MyService myService = ctx.getBean(MyService.class);
myService.doStuff();
}
Example
Let us have a working Eclipse IDE in place and take the following steps to create a Spring application −
Steps | Description |
---|---|
1 | Create a project with a name SpringExample and create a package com.tutorialspoint under the src folder in the created project. |
2 | Add required Spring libraries using Add External JARs option as explained in the Spring Hello World Example chapter. |
3 | Because you are using Java-based annotations, so you also need to add CGLIB.jar from your Java installation directory and ASM.jar library which can be downloaded from asm.ow2.org. |
4 | Create Java classes HelloWorldConfig, HelloWorld and MainApp under the com.tutorialspoint package. |
5 | The final step is to create the content of all the Java files and Bean Configuration file and run the application as explained below. |
Here is the content of HelloWorldConfig.java file
package com.tutorialspoint;
import org.springframework.context.annotation.*;
@Configuration
public class HelloWorldConfig {
@Bean
public HelloWorld helloWorld(){
return new HelloWorld();
}
}
Here is the content of HelloWorld.java file
package com.tutorialspoint;
public class HelloWorld {
private String message;
public void setMessage(String message){
this.message = message;
}
public void getMessage(){
System.out.println("Your Message : " + message);
}
}
Following is the content of the MainApp.java file
package com.tutorialspoint;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.*;
public class MainApp {
public static void main(String[] args) {
ApplicationContext ctx =
new AnnotationConfigApplicationContext(HelloWorldConfig.class);
HelloWorld helloWorld = ctx.getBean(HelloWorld.class);
helloWorld.setMessage("Hello World!");
helloWorld.getMessage();
}
}
Once you are done creating all the source files and adding the required additional libraries, let us run the application. You should note that there is no configuration file required. If everything is fine with your application, it will print the following message −
Your Message : Hello World!
Injecting Bean Dependencies
When @Beans have dependencies on one another, expressing that the dependency is as simple as having one bean method calling another as follows −
package com.tutorialspoint;
import org.springframework.context.annotation.*;
@Configuration
public class AppConfig {
@Bean
public Foo foo() {
return new Foo(bar());
}
@Bean
public Bar bar() {
return new Bar();
}
}
Here, the foo bean receives a reference to bar via the constructor injection. Now let us look at another working example.
Example
Let us have a working Eclipse IDE in place and take the following steps to create a Spring application −
Steps | Description |
---|---|
1 | Create a project with a name SpringExample and create a package com.tutorialspoint under the src folder in the created project. |
2 | Add required Spring libraries using Add External JARs option as explained in the Spring Hello World Example chapter. |
3 | Because you are using Java-based annotations, so you also need to add CGLIB.jar from your Java installation directory and ASM.jar library which can be downloaded from asm.ow2.org. |
4 | Create Java classes TextEditorConfig, TextEditor, SpellChecker and MainApp under the com.tutorialspoint package. |
5 | The final step is to create the content of all the Java files and Bean Configuration file and run the application as explained below. |
Here is the content of TextEditorConfig.java file
package com.tutorialspoint;
import org.springframework.context.annotation.*;
@Configuration
public class TextEditorConfig {
@Bean
public TextEditor textEditor(){
return new TextEditor( spellChecker() );
}
@Bean
public SpellChecker spellChecker(){
return new SpellChecker( );
}
}
Here is the content of TextEditor.java file
package com.tutorialspoint;
public class TextEditor {
private SpellChecker spellChecker;
public TextEditor(SpellChecker spellChecker){
System.out.println("Inside TextEditor constructor." );
this.spellChecker = spellChecker;
}
public void spellCheck(){
spellChecker.checkSpelling();
}
}
Following is the content of another dependent class file SpellChecker.java
package com.tutorialspoint;
public class SpellChecker {
public SpellChecker(){
System.out.println("Inside SpellChecker constructor." );
}
public void checkSpelling(){
System.out.println("Inside checkSpelling." );
}
}
Following is the content of the MainApp.java file
package com.tutorialspoint;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.*;
public class MainApp {
public static void main(String[] args) {
ApplicationContext ctx =
new AnnotationConfigApplicationContext(TextEditorConfig.class);
TextEditor te = ctx.getBean(TextEditor.class);
te.spellCheck();
}
}
Once you are done creating all the source files and adding the required additional libraries, let us run the application. You should note that there is no configuration file required. If everything is fine with your application, it will print the following message −
Inside SpellChecker constructor.
Inside TextEditor constructor.
Inside checkSpelling.
The @Import Annotation
The @Import annotation allows for loading @Bean definitions from another configuration class. Consider a ConfigA class as follows −
@Configuration
public class ConfigA {
@Bean
public A a() {
return new A();
}
}
You can import above Bean declaration in another Bean Declaration as follows −
@Configuration
@Import(ConfigA.class)
public class ConfigB {
@Bean
public B b() {
return new B();
}
}
Now, rather than needing to specify both ConfigA.class and ConfigB.class when instantiating the context, only ConfigB needs to be supplied as follows −
public static void main(String[] args) {
ApplicationContext ctx = new AnnotationConfigApplicationContext(ConfigB.class);
// now both beans A and B will be available...
A a = ctx.getBean(A.class);
B b = ctx.getBean(B.class);
}
수명주기 콜백
@Bean 주석은 빈 요소에 대한 Spring XML의 init-method 및 destroy-method 속성과 같이 임의의 초기화 및 파괴 콜백 메소드 지정을 지원합니다.
public class Foo {
public void init() {
// initialization logic
}
public void cleanup() {
// destruction logic
}
}
@Configuration
public class AppConfig {
@Bean(initMethod = "init", destroyMethod = "cleanup" )
public Foo foo() {
return new Foo();
}
}
빈 범위 지정
기본 범위는 싱글 톤이지만 다음과 같이 @Scope 주석으로 재정의 할 수 있습니다.
@Configuration
public class AppConfig {
@Bean
@Scope("prototype")
public Foo foo() {
return new Foo();
}
}
당신은 모든 장에서 Spring의 핵심이 ApplicationContext, 빈의 전체 수명주기를 관리합니다. ApplicationContext는 Bean을로드 할 때 특정 유형의 이벤트를 게시합니다. 예를 들어, ContextStartedEvent는 문맥이 시작될 때 게시 ContextStoppedEvent이 컨텍스트가 중지 될 때 게시됩니다.
ApplicationContext의 이벤트 처리 는 ApplicationEvent 클래스와 ApplicationListener 인터페이스를 통해 제공됩니다 . 따라서 Bean이 ApplicationListener를 구현하면 ApplicationEvent 가 ApplicationContext 에 게시 될 때마다 해당 Bean에 알림이 전송됩니다.
Spring은 다음과 같은 표준 이벤트를 제공합니다.
Sr. 아니. | Spring 내장 이벤트 및 설명 |
---|---|
1 | ContextRefreshedEvent 이 이벤트는 ApplicationContext 가 초기화되거나 새로 고쳐질 때 게시됩니다 . ConfigurableApplicationContext 인터페이스 에서 refresh () 메서드를 사용하여 발생할 수도 있습니다 . |
2 | ContextStartedEvent 이 이벤트는 ConfigurableApplicationContext 인터페이스 에서 start () 메서드를 사용하여 ApplicationContext 가 시작될 때 게시됩니다 . 데이터베이스를 폴링하거나이 이벤트를 수신 한 후 중지 된 애플리케이션을 다시 시작할 수 있습니다. |
삼 | ContextStoppedEvent 이 이벤트는 ConfigurableApplicationContext 인터페이스 에서 stop () 메서드를 사용하여 ApplicationContext 가 중지 될 때 게시됩니다 . 이 이벤트를받은 후 필요한 청소 작업을 할 수 있습니다. |
4 | ContextClosedEvent 이 이벤트는 ConfigurableApplicationContext 인터페이스 에서 close () 메서드를 사용하여 ApplicationContext 가 닫힐 때 게시됩니다 . 닫힌 컨텍스트는 수명이 다합니다. 새로 고치거나 다시 시작할 수 없습니다. |
5 | RequestHandledEvent 이것은 HTTP 요청이 서비스되었음을 모든 Bean에 알리는 웹 특정 이벤트입니다. |
Spring의 이벤트 처리는 단일 스레드이므로 이벤트가 게시되면 모든 수신자가 메시지를받을 때까지 프로세스가 차단되고 흐름이 계속되지 않습니다. 따라서 이벤트 처리를 사용하려면 응용 프로그램을 디자인 할 때주의해야합니다.
컨텍스트 이벤트 듣기
컨텍스트 이벤트를 수신하려면 Bean이 하나의 메소드 만 있는 ApplicationListener 인터페이스를 구현해야합니다.onApplicationEvent(). 따라서 이벤트가 전파되는 방식과 특정 이벤트를 기반으로 필요한 작업을 수행하도록 코드를 입력하는 방법을 확인하는 예제를 작성해 보겠습니다.
작동하는 Eclipse IDE를 준비하고 다음 단계를 수행하여 Spring 애플리케이션을 작성해 보겠습니다.
단계 | 기술 |
---|---|
1 | 이름이 SpringExample 인 프로젝트를 만들고 아래에 com.tutorialspoint 패키지를 만듭니다 .src 생성 된 프로젝트의 폴더. |
2 | Spring Hello World 예제 장에 설명 된대로 Add External JARs 옵션을 사용하여 필요한 Spring 라이브러리를 추가 합니다. |
삼 | com.tutorialspoint 패키지 아래에 Java 클래스 HelloWorld , CStartEventHandler , CStopEventHandler 및 MainApp 을 작성하십시오 . |
4 | 아래에 Beans 구성 파일 Beans.xml을 만듭니다 .src 폴더. |
5 | 마지막 단계는 모든 Java 파일과 Bean Configuration 파일의 내용을 만들고 아래 설명 된대로 응용 프로그램을 실행하는 것입니다. |
내용은 다음과 같습니다. HelloWorld.java 파일
package com.tutorialspoint;
public class HelloWorld {
private String message;
public void setMessage(String message){
this.message = message;
}
public void getMessage(){
System.out.println("Your Message : " + message);
}
}
다음은의 내용입니다 CStartEventHandler.java 파일
package com.tutorialspoint;
import org.springframework.context.ApplicationListener;
import org.springframework.context.event.ContextStartedEvent;
public class CStartEventHandler
implements ApplicationListener<ContextStartedEvent>{
public void onApplicationEvent(ContextStartedEvent event) {
System.out.println("ContextStartedEvent Received");
}
}
다음은의 내용입니다 CStopEventHandler.java 파일
package com.tutorialspoint;
import org.springframework.context.ApplicationListener;
import org.springframework.context.event.ContextStoppedEvent;
public class CStopEventHandler
implements ApplicationListener<ContextStoppedEvent>{
public void onApplicationEvent(ContextStoppedEvent event) {
System.out.println("ContextStoppedEvent Received");
}
}
다음은의 내용입니다 MainApp.java 파일
package com.tutorialspoint;
import org.springframework.context.ConfigurableApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class MainApp {
public static void main(String[] args) {
ConfigurableApplicationContext context =
new ClassPathXmlApplicationContext("Beans.xml");
// Let us raise a start event.
context.start();
HelloWorld obj = (HelloWorld) context.getBean("helloWorld");
obj.getMessage();
// Let us raise a stop event.
context.stop();
}
}
다음은 구성 파일입니다. Beans.xml
<?xml version = "1.0" encoding = "UTF-8"?>
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">
<bean id = "helloWorld" class = "com.tutorialspoint.HelloWorld">
<property name = "message" value = "Hello World!"/>
</bean>
<bean id = "cStartEventHandler" class = "com.tutorialspoint.CStartEventHandler"/>
<bean id = "cStopEventHandler" class = "com.tutorialspoint.CStopEventHandler"/>
</beans>
소스 및 빈 구성 파일 생성이 완료되면 애플리케이션을 실행 해 보겠습니다. 응용 프로그램에 문제가 없으면 다음 메시지가 인쇄됩니다.
ContextStartedEvent Received
Your Message : Hello World!
ContextStoppedEvent Received
원하는 경우 고유 한 사용자 지정 이벤트를 게시하고 나중에 동일한 이벤트를 캡처하여 해당 사용자 지정 이벤트에 대해 조치를 취할 수 있습니다. 나만의 커스텀 이벤트를 작성하고 싶다면 Spring 의 커스텀 이벤트를 확인할 수 있습니다 .
사용자 지정 이벤트를 작성하고 게시하려면 여러 단계를 거쳐야합니다. 이 장에 제공된 지침에 따라 Custom Spring Events를 작성, 게시 및 처리합니다.
단계 | 기술 |
---|---|
1 | 이름이 SpringExample 인 프로젝트를 만들고 아래에 com.tutorialspoint 패키지를 만듭니다 .src생성 된 프로젝트의 폴더. 모든 클래스는이 패키지 아래에 생성됩니다. |
2 | Spring Hello World 예제 장에 설명 된대로 Add External JARs 옵션을 사용하여 필요한 Spring 라이브러리를 추가 합니다. |
삼 | 확장 하여 이벤트 클래스 CustomEvent 를 만듭니다.ApplicationEvent. 이 클래스는 ApplicationEvent 클래스에서 생성자를 상속해야하는 기본 생성자를 정의해야합니다. |
4 | 이벤트 클래스가 정의되면 모든 클래스에서 게시 할 수 있습니다 . ApplicationEventPublisherAware 를 구현하는 EventClassPublisher 라고 가정하겠습니다 . 또한 ApplicationEventPublisherAware 인터페이스를 구현하기 때문에 컨테이너가 Bean을 이벤트 게시자로 식별 할 수 있도록 XML 구성 파일에서이 클래스를 Bean으로 선언해야합니다. |
5 | 게시 된 이벤트는 클래스에서 처리 할 수 있습니다. ApplicationListener 인터페이스를 구현 하고 사용자 지정 이벤트에 대한 onApplicationEvent 메서드를 구현 하는 EventClassHandler 라고 가정하겠습니다 . |
6 | 아래에 Beans.xml 구성 파일을 만듭니다 .src폴더와 Spring 애플리케이션으로 작동 할 MainApp 클래스. |
7 | 마지막 단계는 모든 Java 파일과 Bean Configuration 파일의 내용을 만들고 아래 설명 된대로 응용 프로그램을 실행하는 것입니다. |
내용은 다음과 같습니다. CustomEvent.java 파일
package com.tutorialspoint;
import org.springframework.context.ApplicationEvent;
public class CustomEvent extends ApplicationEvent{
public CustomEvent(Object source) {
super(source);
}
public String toString(){
return "My Custom Event";
}
}
다음은의 내용입니다 CustomEventPublisher.java 파일
package com.tutorialspoint;
import org.springframework.context.ApplicationEventPublisher;
import org.springframework.context.ApplicationEventPublisherAware;
public class CustomEventPublisher implements ApplicationEventPublisherAware {
private ApplicationEventPublisher publisher;
public void setApplicationEventPublisher (ApplicationEventPublisher publisher) {
this.publisher = publisher;
}
public void publish() {
CustomEvent ce = new CustomEvent(this);
publisher.publishEvent(ce);
}
}
다음은의 내용입니다 CustomEventHandler.java 파일
package com.tutorialspoint;
import org.springframework.context.ApplicationListener;
public class CustomEventHandler implements ApplicationListener<CustomEvent> {
public void onApplicationEvent(CustomEvent event) {
System.out.println(event.toString());
}
}
다음은의 내용입니다 MainApp.java 파일
package com.tutorialspoint;
import org.springframework.context.ConfigurableApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class MainApp {
public static void main(String[] args) {
ConfigurableApplicationContext context =
new ClassPathXmlApplicationContext("Beans.xml");
CustomEventPublisher cvp =
(CustomEventPublisher) context.getBean("customEventPublisher");
cvp.publish();
cvp.publish();
}
}
다음은 구성 파일입니다. Beans.xml
<?xml version = "1.0" encoding = "UTF-8"?>
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">
<bean id = "customEventHandler" class = "com.tutorialspoint.CustomEventHandler"/>
<bean id = "customEventPublisher" class = "com.tutorialspoint.CustomEventPublisher"/>
</beans>
소스 및 빈 구성 파일 생성이 완료되면 애플리케이션을 실행 해 보겠습니다. 응용 프로그램에 문제가 없으면 다음 메시지가 인쇄됩니다.
y Custom Event
y Custom Event
Spring Framework의 주요 구성 요소 중 하나는 Aspect oriented programming (AOP)뼈대. Aspect-Oriented Programming은 프로그램 로직을 소위 관심사라고하는 별개의 부분으로 분해하는 것을 수반합니다. 응용 프로그램의 여러 지점에 걸쳐있는 함수가 호출됩니다.cross-cutting concerns이러한 교차 문제는 개념적으로 애플리케이션의 비즈니스 로직과 분리되어 있습니다. 로깅, 감사, 선언적 트랜잭션, 보안, 캐싱 등과 같은 측면에 대한 다양한 일반적인 좋은 예가 있습니다.
OOP에서 모듈화의 핵심 단위는 클래스이고 AOP에서는 모듈화 단위가 aspect입니다. 종속성 주입은 애플리케이션 개체를 서로 분리하는 데 도움이되며 AOP는 영향을받는 개체에서 교차 절단 문제를 분리하는 데 도움이됩니다. AOP는 Perl, .NET, Java 등과 같은 프로그래밍 언어의 트리거와 같습니다.
Spring AOP 모듈은 애플리케이션을 가로 채기위한 인터셉터를 제공합니다. 예를 들어 메서드가 실행될 때 메서드 실행 전후에 추가 기능을 추가 할 수 있습니다.
AOP 용어
AOP 작업을 시작하기 전에 AOP 개념과 용어를 익혀 보겠습니다. 이 용어는 Spring에만 국한되지 않고 AOP와 관련이 있습니다.
Sr. 아니요 | 용어 및 설명 |
---|---|
1 | Aspect 교차 절단 요구 사항을 제공하는 API 세트가있는 모듈입니다. 예를 들어, 로깅 모듈은 로깅을 위해 AOP 측면이라고합니다. 응용 프로그램은 요구 사항에 따라 여러 측면을 가질 수 있습니다. |
2 | Join point 이것은 AOP 측면을 플러그인 할 수있는 애플리케이션의 지점을 나타냅니다. 또한 Spring AOP 프레임 워크를 사용하여 작업이 수행되는 애플리케이션의 실제 위치라고 말할 수도 있습니다. |
삼 | Advice 이것은 메소드 실행 전이나 후에 취해야 할 실제 조치입니다. 이것은 Spring AOP 프레임 워크에 의해 프로그램 실행 중에 호출되는 실제 코드 조각입니다. |
4 | Pointcut 어드바이스가 실행되어야하는 하나 이상의 조인 포인트 세트입니다. AOP 예제에서 볼 수 있듯이 표현식이나 패턴을 사용하여 포인트 컷을 지정할 수 있습니다. |
5 | Introduction 소개를 통해 기존 클래스에 새 메소드 또는 속성을 추가 할 수 있습니다. |
6 | Target object 하나 이상의 측면에서 권고하는 개체입니다. 이 개체는 항상 권장 개체라고도하는 프록시 개체입니다. |
7 | Weaving Weaving은 조언 된 객체를 생성하기 위해 다른 응용 프로그램 유형 또는 객체와 측면을 연결하는 프로세스입니다. 이는 컴파일 타임,로드 타임 또는 런타임에 수행 할 수 있습니다. |
조언의 유형
Spring 측면은 다음과 같이 언급 된 5 가지 종류의 조언과 함께 작동 할 수 있습니다.
Sr. 아니요 | 조언 및 설명 |
---|---|
1 | before 메서드 실행 전에 어드바이스를 실행하십시오. |
2 | after 결과에 관계없이 메서드 실행 후에 조언을 실행합니다. |
삼 | after-returning 메서드가 성공적으로 완료된 경우에만 메서드 실행 후 advice를 실행합니다. |
4 | after-throwing 예외를 발생시켜 메소드가 종료되는 경우에만 메소드 실행 후 어드바이스를 실행하십시오. |
5 | around 조언 된 메소드가 호출되기 전과 후에 조언을 실행하십시오. |
사용자 지정 측면 구현
봄은 @AspectJ annotation style 접근 및 schema-based사용자 정의 측면을 구현하는 접근 방식. 이 두 가지 접근 방식은 다음 섹션에서 자세히 설명합니다.
Sr. 아니요 | 접근 및 설명 |
---|---|
1 | XML 스키마 기반 Aspect는 XML 기반 구성과 함께 일반 클래스를 사용하여 구현됩니다. |
2 | @AspectJ 기반 @AspectJ는 aspect를 Java 5 주석으로 주석이 달린 일반 Java 클래스로 선언하는 스타일을 나타냅니다. |
평범한 오래된 JDBC를 사용하여 데이터베이스로 작업하는 동안 예외 처리, 데이터베이스 연결 열기 및 닫기 등을 처리하기 위해 불필요한 코드를 작성하는 것이 번거 롭습니다. 그러나 Spring JDBC Framework는 연결 열기부터 시작하여 모든 하위 수준 세부 정보를 처리하고 준비합니다. SQL 문을 실행하고, 예외를 처리하고, 트랜잭션을 처리하고, 마지막으로 연결을 닫습니다.
따라서 연결 매개 변수를 정의하고 실행할 SQL 문을 지정하고 데이터베이스에서 데이터를 가져 오는 동안 각 반복에 필요한 작업을 수행하기 만하면됩니다.
Spring JDBC는 데이터베이스와 인터페이스하기 위해 여러 가지 접근 방식과 그에 따라 다른 클래스를 제공합니다. 저는 고전적이고 가장 인기있는 접근 방식을 사용하여JdbcTemplate프레임 워크의 클래스. 이것은 모든 데이터베이스 통신 및 예외 처리를 관리하는 중앙 프레임 워크 클래스입니다.
JdbcTemplate 클래스
JDBC 템플릿 클래스는 SQL 쿼리를 실행하고, 문을 업데이트하고, 프로 시저 호출을 저장하고, ResultSet에 대해 반복을 수행하고, 반환 된 매개 변수 값을 추출합니다. 또한 JDBC 예외를 포착하여 org.springframework.dao 패키지에 정의 된 일반적이고보다 유익한 예외 계층 구조로 변환합니다.
JdbcTemplate 클래스의 인스턴스는 일단 구성되면 스레드로부터 안전 합니다. 따라서 JdbcTemplate 의 단일 인스턴스를 구성한 다음이 공유 참조를 여러 DAO에 안전하게 삽입 할 수 있습니다 .
JDBC Template 클래스를 사용할 때 일반적인 관행은 Spring 구성 파일에서 DataSource 를 구성한 다음 해당 공유 DataSource bean을 DAO 클래스에 종속성 주입하고 JdbcTemplate은 DataSource의 setter에 생성됩니다.
데이터 소스 구성
데이터베이스 테이블을 생성하겠습니다. Student 우리 데이터베이스에서 TEST. MySQL 데이터베이스로 작업한다고 가정하고 다른 데이터베이스로 작업하는 경우 그에 따라 DDL 및 SQL 쿼리를 변경할 수 있습니다.
CREATE TABLE Student(
ID INT NOT NULL AUTO_INCREMENT,
NAME VARCHAR(20) NOT NULL,
AGE INT NOT NULL,
PRIMARY KEY (ID)
);
이제 JDBC 템플릿에 데이터 소스를 제공하여 데이터베이스 액세스를 얻기 위해 자체 구성 할 수 있도록해야합니다. 다음 코드 스 니펫과 같이 코드 조각을 사용하여 XML 파일에서 DataSource를 구성 할 수 있습니다.
<bean id = "dataSource"
class = "org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name = "driverClassName" value = "com.mysql.jdbc.Driver"/>
<property name = "url" value = "jdbc:mysql://localhost:3306/TEST"/>
<property name = "username" value = "root"/>
<property name = "password" value = "password"/>
</bean>
데이터 액세스 개체 (DAO)
DAO는 일반적으로 데이터베이스 상호 작용에 사용되는 데이터 액세스 개체를 나타냅니다. DAO는 데이터베이스에 데이터를 읽고 쓰는 수단을 제공하기 위해 존재하며 나머지 응용 프로그램이 액세스 할 인터페이스를 통해이 기능을 노출해야합니다.
Spring의 DAO 지원으로 JDBC, Hibernate, JPA 또는 JDO와 같은 데이터 액세스 기술을 일관된 방식으로 쉽게 사용할 수 있습니다.
SQL 문 실행
SQL 및 JDBC 템플릿 객체를 사용하여 데이터베이스 테이블에서 CRUD (생성, 읽기, 업데이트 및 삭제) 작업을 수행하는 방법을 살펴 보겠습니다.
Querying for an integer
String SQL = "select count(*) from Student";
int rowCount = jdbcTemplateObject.queryForInt( SQL );
Querying for a long
String SQL = "select count(*) from Student";
long rowCount = jdbcTemplateObject.queryForLong( SQL );
A simple query using a bind variable
String SQL = "select age from Student where id = ?";
int age = jdbcTemplateObject.queryForInt(SQL, new Object[]{10});
Querying for a String
String SQL = "select name from Student where id = ?";
String name = jdbcTemplateObject.queryForObject(SQL, new Object[]{10}, String.class);
Querying and returning an object
String SQL = "select * from Student where id = ?";
Student student = jdbcTemplateObject.queryForObject(
SQL, new Object[]{10}, new StudentMapper());
public class StudentMapper implements RowMapper<Student> {
public Student mapRow(ResultSet rs, int rowNum) throws SQLException {
Student student = new Student();
student.setID(rs.getInt("id"));
student.setName(rs.getString("name"));
student.setAge(rs.getInt("age"));
return student;
}
}
Querying and returning multiple objects
String SQL = "select * from Student";
List<Student> students = jdbcTemplateObject.query(
SQL, new StudentMapper());
public class StudentMapper implements RowMapper<Student> {
public Student mapRow(ResultSet rs, int rowNum) throws SQLException {
Student student = new Student();
student.setID(rs.getInt("id"));
student.setName(rs.getString("name"));
student.setAge(rs.getInt("age"));
return student;
}
}
Inserting a row into the table
String SQL = "insert into Student (name, age) values (?, ?)";
jdbcTemplateObject.update( SQL, new Object[]{"Zara", 11} );
Updating a row into the table
String SQL = "update Student set name = ? where id = ?";
jdbcTemplateObject.update( SQL, new Object[]{"Zara", 10} );
Deleting a row from the table
String SQL = "delete Student where id = ?";
jdbcTemplateObject.update( SQL, new Object[]{20} );
DDL 문 실행
사용할 수 있습니다 execute(..)jdbcTemplate의 메서드 를 사용하여 SQL 문 또는 DDL 문을 실행합니다. 다음은 테이블을 생성하기 위해 CREATE 문을 사용하는 예입니다-
String SQL = "CREATE TABLE Student( " +
"ID INT NOT NULL AUTO_INCREMENT, " +
"NAME VARCHAR(20) NOT NULL, " +
"AGE INT NOT NULL, " +
"PRIMARY KEY (ID));"
jdbcTemplateObject.execute( SQL );
Spring JDBC 프레임 워크 예제
위의 개념을 바탕으로 Spring에서 JDBC 프레임 워크의 사용법을 이해하는 데 도움이 될 몇 가지 중요한 예를 살펴 보겠습니다.
Sr. 아니. | 예 및 설명 |
---|---|
1 | Spring JDBC 예제 이 예제는 간단한 JDBC 기반 Spring 애플리케이션을 작성하는 방법을 설명합니다. |
2 | Spring의 SQL 저장 프로 시저 Spring에서 JDBC를 사용하는 동안 SQL 저장 프로 시저를 호출하는 방법을 알아 봅니다. |
데이터베이스 트랜잭션은 단일 작업 단위로 처리되는 일련의 작업입니다. 이러한 작업은 완전히 완료되거나 전혀 효과가 없어야합니다. 트랜잭션 관리는 데이터 무결성과 일관성을 보장하기위한 RDBMS 지향 엔터프라이즈 애플리케이션의 중요한 부분입니다. 트랜잭션의 개념은 다음과 같은 네 가지 주요 속성으로 설명 할 수 있습니다.ACID −
Atomicity − 트랜잭션은 단일 작업 단위로 취급되어야합니다. 즉, 전체 작업 순서가 성공하거나 실패했음을 의미합니다.
Consistency − 이것은 데이터베이스의 참조 무결성, 테이블의 고유 한 기본 키 등의 일관성을 나타냅니다.
Isolation− 동시에 동일한 데이터 세트로 많은 트랜잭션 처리가있을 수 있습니다. 데이터 손상을 방지하려면 각 트랜잭션을 다른 트랜잭션과 격리해야합니다.
Durability − 일단 트랜잭션이 완료되면이 트랜잭션의 결과는 영구적이어야하며 시스템 오류로 인해 데이터베이스에서 지울 수 없습니다.
실제 RDBMS 데이터베이스 시스템은 각 트랜잭션에 대해 네 가지 속성을 모두 보장합니다. SQL을 사용하여 데이터베이스에 발행 된 트랜잭션의 단순한보기는 다음과 같습니다.
begin transaction 명령을 사용하여 트랜잭션을 시작합니다 .
SQL 쿼리를 사용하여 다양한 삭제, 업데이트 또는 삽입 작업을 수행합니다.
모든 작업이 성공하면 커밋 을 수행하고 그렇지 않으면 모든 작업을 롤백 합니다.
Spring 프레임 워크는 다양한 기본 트랜잭션 관리 API 위에 추상 레이어를 제공합니다. Spring의 트랜잭션 지원은 POJO에 트랜잭션 기능을 추가하여 EJB 트랜잭션에 대한 대안을 제공하는 것을 목표로합니다. Spring은 프로그래밍 및 선언적 트랜잭션 관리를 모두 지원합니다. EJB에는 애플리케이션 서버가 필요하지만 애플리케이션 서버 없이도 Spring 트랜잭션 관리를 구현할 수 있습니다.
로컬 대 글로벌 트랜잭션
로컬 트랜잭션은 JDBC 연결과 같은 단일 트랜잭션 리소스에 고유 한 반면 전역 트랜잭션은 분산 시스템의 트랜잭션과 같은 여러 트랜잭션 리소스에 걸쳐있을 수 있습니다.
로컬 트랜잭션 관리는 응용 프로그램 구성 요소와 리소스가 단일 사이트에있는 중앙 집중식 컴퓨팅 환경에서 유용 할 수 있으며 트랜잭션 관리에는 단일 시스템에서 실행되는 로컬 데이터 관리자 만 포함됩니다. 로컬 트랜잭션은 구현하기가 더 쉽습니다.
모든 리소스가 여러 시스템에 분산되어있는 분산 컴퓨팅 환경에서는 글로벌 트랜잭션 관리가 필요합니다. 이러한 경우 트랜잭션 관리는 로컬 및 글로벌 수준에서 수행되어야합니다. 분산 또는 전역 트랜잭션은 여러 시스템에서 실행되며, 그 실행에는 전역 트랜잭션 관리 시스템과 모든 관련 시스템의 모든 로컬 데이터 관리자 간의 조정이 필요합니다.
프로 그래 매틱 vs. 선언
Spring은 두 가지 유형의 트랜잭션 관리를 지원합니다.
프로그래밍 방식의 트랜잭션 관리 -이것은 프로그래밍의 도움으로 트랜잭션을 관리해야 함을 의미합니다. 그것은 당신에게 극도의 유연성을 제공하지만 유지하기가 어렵습니다.
선언적 트랜잭션 관리 -이것은 비즈니스 코드에서 트랜잭션 관리를 분리하는 것을 의미합니다. 주석 또는 XML 기반 구성 만 사용하여 트랜잭션을 관리합니다.
선언적 트랜잭션 관리는 코드를 통해 트랜잭션을 제어 할 수있는 프로그래밍 트랜잭션 관리보다 덜 유연하지만 프로그래밍 트랜잭션 관리보다 선호됩니다. 그러나 일종의 교차 문제로 선언적 트랜잭션 관리는 AOP 접근 방식으로 모듈화 될 수 있습니다. Spring은 Spring AOP 프레임 워크를 통해 선언적 트랜잭션 관리를 지원합니다.
스프링 트랜잭션 추상화
Spring 트랜잭션 추상화의 핵심 은 다음과 같이 org.springframework.transaction.PlatformTransactionManager 인터페이스에 의해 정의됩니다.
public interface PlatformTransactionManager {
TransactionStatus getTransaction(TransactionDefinition definition);
throws TransactionException;
void commit(TransactionStatus status) throws TransactionException;
void rollback(TransactionStatus status) throws TransactionException;
}
Sr. 아니요 | 방법 및 설명 |
---|---|
1 | TransactionStatus getTransaction(TransactionDefinition definition) 이 메서드는 지정된 전파 동작에 따라 현재 활성 트랜잭션을 반환하거나 새 트랜잭션을 만듭니다. |
2 | void commit(TransactionStatus status) 이 메소드는 상태와 관련하여 주어진 트랜잭션을 커밋합니다. |
삼 | void rollback(TransactionStatus status) 이 메소드는 주어진 트랜잭션의 롤백을 수행합니다. |
TransactionDefinition는 봄의 트랜잭션 지원의 핵심 인터페이스이며 다음과 같이 정의된다 -
public interface TransactionDefinition {
int getPropagationBehavior();
int getIsolationLevel();
String getName();
int getTimeout();
boolean isReadOnly();
}
Sr. 아니요 | 방법 및 설명 |
---|---|
1 | int getPropagationBehavior() 이 메서드는 전파 동작을 반환합니다. Spring은 EJB CMT에서 익숙한 모든 트랜잭션 전파 옵션을 제공합니다. |
2 | int getIsolationLevel() 이 메서드는이 트랜잭션이 다른 트랜잭션의 작업과 격리되는 정도를 반환합니다. |
삼 | String getName() 이 메서드는이 트랜잭션의 이름을 반환합니다. |
4 | int getTimeout() 이 메서드는 트랜잭션이 완료되어야하는 시간 (초)을 반환합니다. |
5 | boolean isReadOnly() 이 메서드는 트랜잭션이 읽기 전용인지 여부를 반환합니다. |
다음은 격리 수준의 가능한 값입니다.
Sr. 아니요 | 격리 및 설명 |
---|---|
1 | TransactionDefinition.ISOLATION_DEFAULT 이것이 기본 격리 수준입니다. |
2 | TransactionDefinition.ISOLATION_READ_COMMITTED 더티 읽기가 방지됨을 나타냅니다. 반복 불가능한 읽기 및 팬텀 읽기가 발생할 수 있습니다. |
삼 | TransactionDefinition.ISOLATION_READ_UNCOMMITTED 더티 읽기, 반복 불가능 읽기 및 팬텀 읽기가 발생할 수 있음을 나타냅니다. |
4 | TransactionDefinition.ISOLATION_REPEATABLE_READ 더티 읽기 및 반복 불가능한 읽기가 방지됨을 나타냅니다. 팬텀 읽기가 발생할 수 있습니다. |
5 | TransactionDefinition.ISOLATION_SERIALIZABLE 더티 읽기, 반복 불가능한 읽기 및 팬텀 읽기가 금지됨을 나타냅니다. |
다음은 전파 유형에 대한 가능한 값입니다-
Sr. 아니. | 전파 및 설명 |
---|---|
1 | TransactionDefinition.PROPAGATION_MANDATORY 현재 트랜잭션을 지원합니다. 현재 트랜잭션이 없으면 예외가 발생합니다. |
2 | TransactionDefinition.PROPAGATION_NESTED 현재 트랜잭션이있는 경우 중첩 된 트랜잭션 내에서 실행됩니다. |
삼 | TransactionDefinition.PROPAGATION_NEVER 현재 트랜잭션을 지원하지 않습니다. 현재 트랜잭션이있는 경우 예외를 throw합니다. |
4 | TransactionDefinition.PROPAGATION_NOT_SUPPORTED 현재 트랜잭션을 지원하지 않습니다. 오히려 항상 비 트랜잭션 방식으로 실행합니다. |
5 | TransactionDefinition.PROPAGATION_REQUIRED 현재 트랜잭션을 지원합니다. 존재하지 않는 경우 새로 만듭니다. |
6 | TransactionDefinition.PROPAGATION_REQUIRES_NEW 새 트랜잭션을 만들고 현재 트랜잭션이 있으면 일시 중단합니다. |
7 | TransactionDefinition.PROPAGATION_SUPPORTS 현재 트랜잭션을 지원합니다. 존재하지 않으면 비 트랜잭션 방식으로 실행됩니다. |
8 | TransactionDefinition.TIMEOUT_DEFAULT 기본 트랜잭션 시스템의 기본 제한 시간을 사용하거나 제한 시간이 지원되지 않는 경우 없음을 사용합니다. |
위해 TransactionStatus 인터페이스는 제어 트랜잭션 실행과 쿼리 트랜잭션 상태에 트랜잭션 코드를 작성하기위한 간단한 방법을 제공합니다.
public interface TransactionStatus extends SavepointManager {
boolean isNewTransaction();
boolean hasSavepoint();
void setRollbackOnly();
boolean isRollbackOnly();
boolean isCompleted();
}
Sr. 아니. | 방법 및 설명 |
---|---|
1 | boolean hasSavepoint() 이 메소드는이 트랜잭션이 내부적으로 저장 점을 전달하는지, 즉 저장 점을 기반으로 중첩 된 트랜잭션으로 생성되었는지 여부를 반환합니다. |
2 | boolean isCompleted() 이 메서드는이 트랜잭션이 완료되었는지, 즉 이미 커밋되었는지 롤백되었는지 여부를 반환합니다. |
삼 | boolean isNewTransaction() 이 메서드는 현재 트랜잭션이 새로운 경우 true를 반환합니다. |
4 | boolean isRollbackOnly() 이 메서드는 트랜잭션이 롤백 전용으로 표시되었는지 여부를 반환합니다. |
5 | void setRollbackOnly() 이 메소드는 트랜잭션을 롤백 전용으로 설정합니다. |
Spring Web MVC 프레임 워크는 유연하고 느슨하게 결합 된 웹 애플리케이션을 개발하는 데 사용할 수있는 MVC (Model-View-Controller) 아키텍처와 준비된 구성 요소를 제공합니다. MVC 패턴은 애플리케이션의 다양한 측면 (입력 로직, 비즈니스 로직 및 UI 로직)을 분리하는 동시에 이러한 요소간에 느슨한 결합을 제공합니다.
그만큼 Model 애플리케이션 데이터를 캡슐화하며 일반적으로 POJO로 구성됩니다.
그만큼 View 모델 데이터 렌더링을 담당하며 일반적으로 클라이언트의 브라우저가 해석 할 수있는 HTML 출력을 생성합니다.
그만큼 Controller 사용자 요청을 처리하고 적절한 모델을 빌드하고 렌더링을 위해 뷰로 전달합니다.
DispatcherServlet
Spring 웹 모델-뷰-컨트롤러 (MVC) 프레임 워크는 모든 HTTP 요청과 응답을 처리 하는 DispatcherServlet 을 중심으로 설계되었습니다 . Spring Web MVC DispatcherServlet 의 요청 처리 워크 플로우 는 다음 다이어그램에 설명되어 있습니다.
에 들어오는 HTTP 요청에 해당하는 이벤트의 순서입니다 다음 DispatcherServlet은 -
HTTP 요청을 수신 한 후 DispatcherServlet 은 HandlerMapping 을 참조하여 적절한 Controller 를 호출합니다 .
컨트롤러 요구를 받아 사용 GET 또는 POST 방법에 따라 해당 서비스를 호출 방법. 서비스 메소드는 정의 된 비즈니스 로직을 기반으로 모델 데이터를 설정하고 뷰 이름을 DispatcherServlet에 반환합니다 .
DispatcherServlet은 도움을 걸릴 것 ViewResolver를 픽업 요청에 대한 정의보기를.
뷰가 완성되면 DispatcherServlet 은 브라우저에서 최종적으로 렌더링되는 뷰로 모델 데이터를 전달합니다.
위에서 언급 한 모든 구성 요소, 즉 HandlerMapping, Controller 및 ViewResolver는 웹 응용 프로그램에 필요한 몇 가지 추가 기능 이 포함 된 일반 ApplicationContext 의 확장 인 WebApplicationContext w의 일부입니다.
필수 구성
DispatcherServlet 이 처리 할 요청을 매핑해야 합니다.web.xml파일. 다음은 선언 및 매핑을 보여주는 예입니다.HelloWeb DispatcherServlet 예-
<web-app id = "WebApp_ID" version = "2.4"
xmlns = "http://java.sun.com/xml/ns/j2ee"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<display-name>Spring MVC Application</display-name>
<servlet>
<servlet-name>HelloWeb</servlet-name>
<servlet-class>
org.springframework.web.servlet.DispatcherServlet
</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>HelloWeb</servlet-name>
<url-pattern>*.jsp</url-pattern>
</servlet-mapping>
</web-app>
그만큼 web.xml파일은 웹 애플리케이션의 WebContent / WEB-INF 디렉토리에 보관됩니다. 초기화시HelloWeb DispatcherServlet, 프레임 워크는 이름이 지정된 파일에서 애플리케이션 컨텍스트를로드하려고합니다. [servlet-name]-servlet.xml애플리케이션의 WebContent / WEB-INF 디렉토리에 있습니다. 이 경우 파일은HelloWebservlet.xml.
다음으로 <servlet-mapping> 태그는 어떤 DispatcherServlet에서 처리 할 URL을 나타냅니다. 다음으로 끝나는 모든 HTTP 요청은.jsp 에 의해 처리됩니다 HelloWeb DispatcherServlet.
기본 파일 이름을 [servlet-name] -servlet.xml로 , 기본 위치를 WebContent / WEB-INF 로 사용하지 않으 려면 web.xml 파일에 서블릿 리스너 ContextLoaderListener 를 추가하여이 파일 이름과 위치를 사용자 정의 할 수 있습니다. 다음과 같이-
<web-app...>
<!-------- DispatcherServlet definition goes here----->
....
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/HelloWeb-servlet.xml</param-value>
</context-param>
<listener>
<listener-class>
org.springframework.web.context.ContextLoaderListener
</listener-class>
</listener>
</web-app>
이제 필요한 구성을 확인하겠습니다. HelloWeb-servlet.xml웹 애플리케이션의 WebContent / WEB-INF 디렉토리에있는 파일-
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:context = "http://www.springframework.org/schema/context"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd">
<context:component-scan base-package = "com.tutorialspoint" />
<bean class = "org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name = "prefix" value = "/WEB-INF/jsp/" />
<property name = "suffix" value = ".jsp" />
</bean>
</beans>
다음은에 대한 중요한 사항입니다. HelloWeb-servlet.xml 파일-
[서블릿 이름] -servlet.xml을 파일 전역에서 동일한 이름으로 정의 된 콩의 정의를 무시 정의 된 콩을 만드는 데 사용된다.
<컨텍스트 : 구성 요소 스캔 ...> 태그 등 @Controller와 @RequestMapping 같은 주석의 사용을 만들 수 있습니다 활성화 스프링 MVC 주석 스캐닝 기능에 사용됩니다
의 InternalResourceViewResolver는 뷰 이름을 해결하기 위해 정의 된 규칙이있을 것이다. 위에 정의 된 규칙에 따라hello/WEB-INF/jsp/hello.jsp 에있는 뷰 구현에 위임됩니다 .
다음 섹션에서는 실제 구성 요소 (예 : 컨트롤러, 모델 및보기)를 만드는 방법을 보여줍니다.
컨트롤러 정의
DispatcherServlet은 특정 기능을 실행하기 위해 컨트롤러에 요청을 위임합니다. 그만큼@Controller주석은 특정 클래스가 컨트롤러 역할을 수행함을 나타냅니다. 그만큼@RequestMapping 주석은 URL을 전체 클래스 또는 특정 핸들러 메서드에 매핑하는 데 사용됩니다.
@Controller
@RequestMapping("/hello")
public class HelloController {
@RequestMapping(method = RequestMethod.GET)
public String printHello(ModelMap model) {
model.addAttribute("message", "Hello Spring MVC Framework!");
return "hello";
}
}
그만큼 @Controller주석은 클래스를 Spring MVC 컨트롤러로 정의합니다. 여기에서 첫 번째 사용@RequestMapping 이 컨트롤러의 모든 처리 방법이 /hello통로. 다음 주석@RequestMapping(method = RequestMethod.GET)HTTP GET 요청을 처리하기위한 컨트롤러의 기본 서비스 메서드로 printHello () 메서드를 선언하는 데 사용됩니다. 동일한 URL에서 POST 요청을 처리하는 다른 방법을 정의 할 수 있습니다.
다음과 같이 @RequestMapping 에 추가 속성을 추가 할 수있는 다른 형식으로 위의 컨트롤러를 작성할 수 있습니다.
@Controller
public class HelloController {
@RequestMapping(value = "/hello", method = RequestMethod.GET)
public String printHello(ModelMap model) {
model.addAttribute("message", "Hello Spring MVC Framework!");
return "hello";
}
}
그만큼 value 속성은 핸들러 메소드가 매핑되는 URL과 method속성은 HTTP GET 요청을 처리하기위한 서비스 메소드를 정의합니다. 위에서 정의한 컨트롤러에 대해 다음과 같은 중요한 사항을 유의해야합니다.
서비스 메소드 내에서 필수 비즈니스 로직을 정의합니다. 요구 사항에 따라이 메서드 내에서 다른 메서드를 호출 할 수 있습니다.
정의 된 비즈니스 로직에 따라이 메소드 내에서 모델을 작성합니다. setter 다른 모델 속성을 사용할 수 있으며 이러한 속성은 최종 결과를 표시하기 위해보기에서 액세스됩니다. 이 예에서는 "message"속성을 사용하여 모델을 만듭니다.
정의 된 서비스 메서드는 다음의 이름을 포함하는 문자열을 반환 할 수 있습니다. view모델을 렌더링하는 데 사용됩니다. 이 예에서는 논리적 뷰 이름으로 "hello"를 반환합니다.
JSP보기 만들기
Spring MVC는 다양한 프레젠테이션 기술에 대해 다양한 유형의 뷰를 지원합니다. 여기에는 JSP, HTML, PDF, Excel 워크 시트, XML, Velocity 템플릿, XSLT, JSON, Atom 및 RSS 피드, JasperReports 등이 포함됩니다.하지만 가장 일반적으로 우리는 JSTL로 작성된 JSP 템플릿을 사용합니다.
간단한 hello /WEB-INF/hello/hello.jsp에서보기-
<html>
<head>
<title>Hello Spring MVC</title>
</head>
<body>
<h2>${message}</h2>
</body>
</html>
여기 ${message}컨트롤러 내부에 설정 한 속성입니다. 보기에 여러 속성을 표시 할 수 있습니다.
Spring Web MVC 프레임 워크 예제
위의 개념을 바탕으로 Spring 웹 애플리케이션을 빌드하는 데 도움이 될 몇 가지 중요한 예제를 확인하겠습니다.
Sr. 아니. | 예 및 설명 |
---|---|
1 | Spring MVC Hello World 예제 이 예제는 간단한 Spring Web Hello World 애플리케이션을 작성하는 방법을 설명합니다. |
2 | Spring MVC 양식 처리 예제 이 예제는 데이터를 컨트롤러에 제출하고 처리 된 결과를 표시하기 위해 HTML 양식을 사용하여 Spring 웹 애플리케이션을 작성하는 방법을 설명합니다. |
삼 | 스프링 페이지 리디렉션 예제 Spring MVC Framework에서 페이지 리디렉션 기능을 사용하는 방법을 알아 봅니다. |
4 | 스프링 정적 페이지 예제 Spring MVC Framework에서 동적 페이지와 함께 정적 페이지에 액세스하는 방법을 배웁니다. |
5 | 스프링 예외 처리 예제 Spring MVC 프레임 워크에서 예외를 처리하는 방법을 배웁니다. |
이것은 Spring 애플리케이션 내에서 매우 사용하기 쉬운 Log4J 기능입니다. 다음 예제는 Log4J와 Spring 간의 간단한 통합을 설명하는 간단한 단계를 안내합니다.
우리는 당신이 이미 가지고 있다고 가정합니다 log4J컴퓨터에 설치됩니다. 없는 경우 다음에서 다운로드 할 수 있습니다.https://logging.apache.org/임의의 폴더에서 압축 파일을 추출하기 만하면됩니다. 우리는log4j-x.y.z.jar 우리 프로젝트에서.
다음으로, 작동하는 Eclipse IDE를 마련하고 다음 단계를 수행하여 Spring Web Framework를 사용하여 동적 양식 기반 웹 애플리케이션을 개발해 보겠습니다.
단계 | 기술 |
---|---|
1 | 이름이 SpringExample 인 프로젝트를 만들고 아래에 com.tutorialspoint 패키지를 만듭니다 .src 생성 된 프로젝트의 폴더. |
2 | Spring Hello World 예제 장에 설명 된대로 Add External JARs 옵션을 사용하여 필요한 Spring 라이브러리를 추가 합니다. |
삼 | Add External JARs를 사용하여 프로젝트에 log4j 라이브러리 log4j-xyzjar 도 추가 합니다. |
4 | com.tutorialspoint 패키지 아래에 Java 클래스 HelloWorld 및 MainApp을 만듭니다 . |
5 | 아래에 Beans 구성 파일 Beans.xml을 만듭니다 .src 폴더. |
6 | 아래에 log4j 구성 파일 log4j.properties를 만듭니다 .src 폴더. |
7 | 마지막 단계는 모든 Java 파일과 Bean Configuration 파일의 내용을 만들고 아래 설명 된대로 응용 프로그램을 실행하는 것입니다. |
내용은 다음과 같습니다. HelloWorld.java 파일
package com.tutorialspoint;
public class HelloWorld {
private String message;
public void setMessage(String message){
this.message = message;
}
public void getMessage() {
System.out.println("Your Message : " + message);
}
}
다음은 두 번째 파일의 내용입니다. MainApp.java
package com.tutorialspoint;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.apache.log4j.Logger;
public class MainApp {
static Logger log = Logger.getLogger(MainApp.class.getName());
public static void main(String[] args) {
ApplicationContext context = new ClassPathXmlApplicationContext("Beans.xml");
log.info("Going to create HelloWord Obj");
HelloWorld obj = (HelloWorld) context.getBean("helloWorld");
obj.getMessage();
log.info("Exiting the program");
}
}
당신은 생성 할 수 있습니다 debug 과 error정보 메시지를 생성 한 것과 유사한 방식으로 메시지를 보냅니다. 이제 내용을 살펴 보겠습니다.Beans.xml 파일
<?xml version = "1.0" encoding = "UTF-8"?>
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">
<bean id = "helloWorld" class = "com.tutorialspoint.HelloWorld">
<property name = "message" value = "Hello World!"/>
</bean>
</beans>
다음 내용은 log4j.properties Log4J가 로그 메시지를 생성하는 데 필요한 표준 규칙을 정의합니다.
# Define the root logger with appender file
log4j.rootLogger = DEBUG, FILE
# Define the file appender
log4j.appender.FILE=org.apache.log4j.FileAppender
# Set the name of the file
log4j.appender.FILE.File=C:\\log.out
# Set the immediate flush to true (default)
log4j.appender.FILE.ImmediateFlush=true
# Set the threshold to debug mode
log4j.appender.FILE.Threshold=debug
# Set the append to false, overwrite
log4j.appender.FILE.Append=false
# Define the layout for file appender
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.conversionPattern=%m%n
소스 및 빈 구성 파일 생성이 완료되면 애플리케이션을 실행 해 보겠습니다. 응용 프로그램에 문제가 없으면 Eclipse 콘솔에 다음 메시지가 인쇄됩니다.
Your Message : Hello World!
C : \\ 드라이브를 확인하면 로그 파일을 찾아야합니다. log.out 다음과 같은 다양한 로그 메시지와 함께-
<!-- initialization log messages -->
Going to create HelloWord Obj
Returning cached instance of singleton bean 'helloWorld'
Exiting the program
Jakarta Commons Logging (JCL) API
또는 사용할 수 있습니다 Jakarta Commons Logging (JCL)Spring 애플리케이션에서 로그를 생성하는 API입니다. JCL은 다음에서 다운로드 할 수 있습니다.https://jakarta.apache.org/commons/logging/. 이 패키지에서 기술적으로 필요한 유일한 파일은 commons-logging-xyzjar 파일이며 , 위의 예에서 log4j-xyzjar 를 넣은 것과 비슷한 방식으로 클래스 경로에 배치해야합니다 .
로깅 기능을 사용하려면 org.apache.commons.logging.Log 객체 가 필요하며 요구 사항에 따라 다음 메서드 중 하나를 호출 할 수 있습니다.
- 치명적 (개체 메시지)
- error (객체 메시지)
- 경고 (개체 메시지)
- info (객체 메시지)
- debug (객체 메시지)
- trace (객체 메시지)
다음은 JCL API를 사용하는 MainApp.java의 대체입니다.
package com.tutorialspoint;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.apache.commons.logging. Log;
import org.apache.commons.logging. LogFactory;
public class MainApp {
static Log log = LogFactory.getLog(MainApp.class.getName());
public static void main(String[] args) {
ApplicationContext context = new ClassPathXmlApplicationContext("Beans.xml");
log.info("Going to create HelloWord Obj");
HelloWorld obj = (HelloWorld) context.getBean("helloWorld");
obj.getMessage();
log.info("Exiting the program");
}
}
프로그램을 컴파일하고 실행하기 전에 프로젝트에 commons-logging-xyzjar 파일이 포함되어 있는지 확인해야합니다.
이제 위의 예에서 나머지 구성 및 콘텐츠를 변경하지 않고 유지하면서 응용 프로그램을 컴파일하고 실행하면 Log4J API를 사용하여 얻은 것과 유사한 결과를 얻을 수 있습니다.