jersey
Jersey와 함께 Spring Boot 사용하기
수색…
스프링 부츠와 저지 소재의 간단한 적용
스프링 부트는 스프링 애플리케이션을위한 부트 스트래핑 프레임 워크입니다. Jersey와의 통합을 완벽하게 지원합니다. Jersey 사용자의 관점에서 볼 때이 장점 중 하나는 Spring의 방대한 생태계에 액세스 할 수 있다는 것입니다.
시작하려면 새로운 독립형 (wepapp가 아닌) Maven 프로젝트를 만듭니다. webapp도 만들 수 있지만이 가이드에서는 독립 실행 형 앱만 사용합니다. 프로젝트를 만들었 으면 pom.xml
다음을 추가합니다.
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
</properties>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.4.0.RELEASE</version>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jersey</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
우리는 단지 두 가지 의존성이 필요합니다. 하나는 Jersey Spring Boot 모듈 용이고 다른 하나는 임베디드 Tomcat 서버용입니다. 테스트 할 응용 프로그램을 실행하는 데 사용할 플러그인입니다.
일단 프로젝트에 다음 클래스를 추가하십시오.
com/example
|
+-- GreetingApplication.class
+-- JerseyConfig.class
|
+ com/example/services
| |
| +-- GreetingService.class
| +-- NiceGreetingService.class
|
+ com/examples/resources
|
+-- GreetingResource.class
GreetingApplication.class
이것은 부트 스트랩 클래스입니다 (매우 간단합니다).
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class GreetingApplication {
public static void main(String[] args) {
SpringApplication.run(GreetingApplication.class, args);
}
}
JerseyConfig.class
저지 구성 클래스입니다.
import javax.ws.rs.ApplicationPath;
import org.glassfish.jersey.server.ResourceConfig;
import org.springframework.stereotype.Component;
@Component
@ApplicationPath("/api")
public class JerseyConfig extends ResourceConfig {
public JerseyConfig() {
packages("com.example");
}
}
GreetingService.class
및 NiceGreetingService.class
public interface GreetingService {
public String getGreeting(String name);
}
import org.springframework.stereotype.Component;
@Component
public class NiceGreetingService implements GreetingService {
@Override
public String getGreeting(String name) {
return "Hello " + name + "!";
}
}
GreetingResource
이 클래스는 Spring이 GreetingService
를 삽입 할 리소스 클래스입니다.
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.QueryParam;
import org.springframework.beans.factory.annotation.Autowired;
import com.example.service.GreetingService;
@Path("greeting")
public class GreetingResource {
private GreetingService greetingService;
@Autowired
public GreetingResource(GreetingService greetingService) {
this.greetingService = greetingService;
}
@GET
public String getGreeting(@QueryParam("name") String name) {
return this.greetingService.getGreeting(name);
}
}
그리고 그게 다야. 이제 응용 프로그램을 실행할 수 있습니다. 터미널을 잡고 프로젝트의 루트에서 다음 명령을 실행하십시오.
mvn spring-boot:run
응용 프로그램을 시작하려면 몇 초가 걸립니다. 약간의 로깅이있을 것이고, 봄의 아스키 아트를 보게 될 것입니다. 그 예술 후에, 그것은 더 많은 로깅의 약 30 라인 정도가되어야합니다, 그러면보아야합니다.
15.784 seconds (JVM running for 38.056)
이제 앱이 시작됩니다. cURL을 사용하는 경우 다음과 같이 테스트 할 수 있습니다.
curl -v 'http://localhost:8080/api/greeting?name=peeskillet'
Windows를 사용하는 경우 URL 주위에 큰 따옴표를 사용하십시오. cURL을 사용하지 않는 경우 브라우저에 입력하십시오. 결과가 나타납니다.
Hello peeskillet!
처음 요청할 때 요청에 몇 초가 걸릴 수 있습니다. 이는 앱이 출시 될 때 Jersey가 완전히로드되지 않았기 때문입니다. src/main/resources
폴더에 application.properties
파일을 추가하여 변경할 수 있습니다. 이 파일에 다음을 추가하십시오.
spring.jersey.servlet.load-on-startup=1