Spring Boot Starter는 SpringBoot 컴포넌트에서 제안된 개념으로, 여러 가지 번거로운 구성을 단순화하여 다양한 Spring Boot Starter 패키지를 도입함으로써 프로젝트 스캐폴딩을 빠르게 구축할 수 있습니다.
예를 들어 우리가 자주 사용하는 것들은 다음과 같습니다:
spring-boot-starter-web:
spring-boot-starter-data-redis:
spring-boot-starter-data-mongodb:
spring-boot -starter-data-jpa:
spring-boot-starter-activemq:
일반적으로 스타터는 종속성의 합성입니다.
스타터가 있기 전, 전통적인 SSM 프로젝트의 경우 Spring에서 jpa를 사용하려면 다음을 수행해야 할 수도 있습니다.
먼저 Maven에서 사용되는 데이터베이스의 종속성을 소개합니다>> 그런 다음 jpa의 종속성을 도입하고>>xml에서 일부 속성 정보 구성>>>정상적으로 실행될 수 있을 때까지 호출을 디버깅합니다.
위 작업에는 다음과 같은 몇 가지 문제가 있습니다.
프로세스가 복잡할 경우 이러한 단계별 작업은 오류 가능성을 높입니다.
구성 중에도 시간이 많이 걸리고, 초보자나 초보자에게 그다지 친숙하지 않습니다.
starter는 사용된 모든 종속성을 포함하므로 개발자가 직접 종속성을 도입할 필요가 없습니다. 서로 다른 스타터는 서로 다른 종속성을 해결하도록 설계되었으므로 내부 구현이 매우 다를 수 있습니다. 예를 들어 jpa의 스타터와 Redis의 스타터는 서로 다른 구현을 가질 수 있습니다. 이는 스타터의 본질이 합성 크기에 있기 때문입니다. 이는 논리적 수준의 추상화 계층입니다. 둘 다 "패키징" 작업을 수행하기 때문에 이 개념은 Docker와 다소 유사할 수 있습니다. Docker가 해결해야 할 문제를 알고 있다면 Docker와 스타터 Make를 사용할 수 있습니다. 비유.
스타터마다 구현이 다르지만 기본적으로 ConfigurationProperties와 AutoConfiguration이라는 동일한 두 가지를 사용합니다. Spring Boot는 "구성에 대한 관례"라는 개념을 굳게 믿기 때문에 ConfigurationProperties를 사용하여 구성을 저장하고 이러한 구성은 기본값을 가질 수 있습니다. 즉, 원래 구성을 적극적으로 덮어쓰지 않으면 기본값이 다음과 같습니다. 효과는 많은 상황에서 매우 유용합니다. 또한 스타터의 ConfigurationProperties를 사용하면 모든 구성 속성을 하나의 파일(일반적으로 리소스 디렉터리의 application.properties)로 수집할 수 있으므로 Spring 프로젝트의 XML 지옥에 작별을 고할 수 있습니다.
위의 스타터가 의존하는 jar는 수동으로 구성할 때 의존하는 jar와 다르지 않으므로 스타터는 실제로 이러한 지루한 구성 작업을 자체에 넘겨주고 단순성을 사용자에게 맡긴다고 생각할 수 있습니다. . 사용자가 지루한 빌드 작업을 제거하도록 돕는 것 외에도 ConfigurationProperties는 "구성에 대한 규칙"이라는 개념에 따라 사용자가 불필요한 구성 작업을 줄이는 데도 도움이 됩니다. 그리고application.properties
파일이 있기 때문에 맞춤 구성이 필요한 경우에도 모든 구성을 하나의 파일에서만 수행하면 되므로 사용이 매우 편리합니다. 채택된 스타터는 모두 위에 나열되어 있습니다. Spring Boot Starter 생성 단계
스타터 프로젝트 생성 application.properties
文件的存在,即使需要自定义配置,所有的配置也只需要在一个文件中进行,使用起来非常方便。采用的starter都上面都给大家列出来了。
创建starter 项目
创建ConfigurationProperties 用来保存配置信息
创建AutoConfiguration,引用定义好的配置信息
在 AutoConfiguration 实现所有 starter 应该完成的操作,并且把这个类加入 spring.factories 配置文件中进行声明
打包项在 SpringBoot 项目中引入该项目依赖,然后就可以使用该 starter 了
在idea新建一个starter项目、直接执行下一步即可生成项目。
在xml中加入如下配置文件:
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <artifactId>http-starter</artifactId> <version>0.0.1-SNAPSHOT</version> <!-- 自定义starter都应该继承自该依赖 --> <!-- 如果自定义starter本身需要继承其它的依赖,可以参考 https://stackoverflow.com/a/21318359 解决 --> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starters</artifactId> <version>1.5.2.RELEASE</version> </parent> <dependencies> <!-- 自定义starter依赖此jar包 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</artifactId> </dependency> <!-- lombok用于自动生成get、set方法 --> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.16.10</version> </dependency> </dependencies> </project>
创建 proterties 类来保存配置信息
@ConfigurationProperties(prefix = "http") @Getter public class HttpProperties { // 如果配置文件中配置了http.url属性,则该默认属性会被覆盖 private String url = "https://blog.csdn.net/weixin_39709134?type=blog"; }
@Setter @Getter public class HttpClient { private String url; // 根据url获取网页数据 public String getHtml() { try { URL url = new URL(this.url); URLConnection urlConnection = url.openConnection(); BufferedReader br = new BufferedReader(new InputStreamReader(urlConnection.getInputStream(), "utf-8")); String line = null; StringBuilder sb = new StringBuilder(); while ((line = br.readLine()) != null) { sb.append(line).append("\n"); } return sb.toString(); } catch (Exception e) { e.printStackTrace(); } return "error"; } }
这个业务类包含了url
属性和一个getHtml
方法,用于获取一个网页HTML 数据
创建 AutoConfiguration
@Configuration @EnableConfigurationProperties(HttpProperties.class) public class HttpAutoConfiguration { @Resource private HttpProperties properties; // 使用配置 // 在Spring上下文中创建一个对象 @Bean @ConditionalOnMissingBean public HttpClient init() { HttpClient client = new HttpClient(); String url = properties.getUrl(); client.setUrl(url); return client; } }
在上面的 AutoConfiguration 中我们实现了自己要求:在 Spring 的上下文中创建了一个 HttpClient 类的 bean,并且我们把 properties 中的一个参数赋给了该 bean。
最后,我们在resources
文件夹下新建目录META-INF
,在目录中新建spring.factories
文件,并且在spring.factories
org.springframework.boot.autoconfigure.EnableAutoConfiguration=\ com.nosuchfield.httpstarter.HttpAutoConfiguration
@Component public class RunIt { @Resource private HttpClient httpClient; public void hello() { System.out.println(httpClient.getHtml()); } }
url
속성과 getHtml
이 포함되어 있습니다. code> 웹 페이지의 HTML 데이터를 얻는 데 사용되는 메서드🎜🎜Create AutoConfiguration🎜rrreee🎜위의 AutoConfiguration에서 우리는 요구 사항을 구현했습니다. Spring 컨텍스트에서 HttpClient 클래스의 Bean을 생성하고 매개 변수를 할당했습니다. 빈의 속성. 🎜🎜마지막으로 resources
폴더 아래에 새 디렉토리 META-INF
를 생성하고 해당 디렉토리에 새 spring.factories
파일을 생성한 다음 추가 >spring.factories에서 자동 구성 구성: 🎜org.springframework.boot.autoconfigure.EnableAutoConfiguration=\ com.nosuchfield.httpstarter.HttpAutoConfiguration
最后使用 Maven 打包该项目。之后创建一个 SpringBoot 项目,在项目中添加我们之前打包的 starter 作为依赖,然后使用 SringBoot 来运行我们的 starter
@Component public class RunIt { @Resource private HttpClient httpClient; public void hello() { System.out.println(httpClient.getHtml()); } }
之后可以在 application.properties中修改配置来进行测试证明 properties 中的数据确实被覆盖
위 내용은 SpringCloud-Spring Boot Starter 사용 테스트 인스턴스 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!