Small knowledge, big challenge! This article is participating in the creation activity of “Essential Tips for Programmers”.
One of the most important features in SpringBoot compared to SpringMVC is custom Start (custom JAR packages), and Spring also provides a lot of start. For example, spring-boot-starter-data-redis and spring-boot-starter-AMqp. This article will teach you how to customize start. The example is getting a data source from start.
1. What can custom Start do
For architectural purposes, there may be some generic methods extracted as Start that can be introduced directly when used in a project.
2. Create a custom start
1. Create a new Maven project
Create a regular Maven project as the development environment for Start
2. The new application. The properties
Create the application.properties file in Maven. Also add the following code as a constant configuration.
login.className = com.mysql.jdbc.Driver
login.url=jdbc:mysql://localhost:3306/humanresource? useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC
login.user=root
login.password=root
Copy the code
3. Create LoginCheckProperties
Create the LoginCheckProperties class with the @ConfigurationProperties annotation. Prefix = “login” means to call the parameters configured in the application.
@ConfigurationProperties(prefix = "login")
public class LoginCheckProperties {
private String className;
private String url;
private String user;
private String password;
public String getClassName() {
return className;
}
public void setClassName(String className) {
this.className = className;
}
public String getUrl() {
return url;
}
public void setUrl(String url) {
this.url = url;
}
public String getUser() {
return user;
}
public void setUser(String user) {
this.user = user;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password; }}Copy the code
4. The Config class
@ EnableConfigurationProperties (LoginCheckProperties. Class) annotated as fixed writing, meaning is to realize the automatic configuration above, the Properties of the class.
@Configuration
@EnableConfigurationProperties(LoginCheckProperties.class)
@MapperScan(basePackages = MasterDataSourceConfig.PACKAGE, sqlSessionFactoryRef = "masterSqlSessionFactory"MasterDataSourceConfig public class MasterDataSourceConfig public class MasterDataSourceConfig public class MasterDataSourceConfig public class MasterDataSourceConfig"com.airboot.bootdemo.dao.master";
static final String MAPPER_LOCATION = "classpath*:mapper/master/*.xml";
private String className;
private String url;
private String user;
private String password;
public MasterDataSourceConfig(LoginCheckProperties loginCheckProperties) {
this.className = loginCheckProperties.getClassName();
this.url = loginCheckProperties.getUrl();
this.user = loginCheckProperties.getUser();
this.password = loginCheckProperties.getPassword();
}
@Bean(name = "masterDataSource")
public DataSource masterDataSource() {
DruidDataSource dataSource = new DruidDataSource();
dataSource.setDriverClassName(className);
dataSource.setUrl(url);
dataSource.setUsername(user);
dataSource.setPassword(password);
return dataSource;
}
@Bean(name = "masterTransactionManager")
public DataSourceTransactionManager masterTransactionManager() {
return new DataSourceTransactionManager(masterDataSource());
}
@Bean(name = "masterSqlSessionFactory")
public SqlSessionFactory masterSqlSessionFactory(@Qualifier("masterDataSource") DataSource masterDataSource)
throws Exception {
final SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
sessionFactory.setDataSource(masterDataSource);
sessionFactory.setMapperLocations(
new PathMatchingResourcePatternResolver().getResources(MasterDataSourceConfig.MAPPER_LOCATION));
returnsessionFactory.getObject(); }}Copy the code
5. Add the meta-inf/spring. Factories
“> < div style =” box-type: break-word; (Need to be exposed to the referenced)
org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
com.*.*.*.*A,\
com.*.*.*.*B,\
com.*.*.*.*C,\
com.*.*.*.*D,\
com.*.*.*.*Util
Copy the code
6. Display start comment (optional)
If you want to add comments to a JAR, you need to modify the following code in the POM file to generate a.jar and a :source.jar you need to add both jar packages to the project.
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-source-plugin</artifactId>
<version>2.4</version>
<configuration>
<aggregate>true</aggregate>
</configuration>
<executions>
<execution>
<id>attach-javadocs</id>
<goals>
<goal>jar</goal>
</goals>
<configuration>
<additionalparam>-Xdoclint:none</additionalparam>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
Copy the code
Pack 7.
Run the MVN install command. Can generate jar packages.
8. Import the JAR package
<dependency>
<groupId>cn.baocl</groupId>
<artifactId>check-spring-boot-starter</artifactId>
<version>1.1 the SNAPSHOT</version>
</dependency>
Copy the code
Configure groupId, artifactId, version in the POM file of the reference project. The following is the POM in start. This parameter corresponds to the previous configuration.
<? 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>
<groupId>cn.baocl</groupId>
<artifactId>check-spring-boot-starter</artifactId>
<version>1.1 the SNAPSHOT</version>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<version>2.2.1. RELEASE</version>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.3.2</version>
</dependency>
<! -- Druid data connection pool dependency -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.17</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
<version>2.2.1. RELEASE</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
<version>8.0.16</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
<version>2.2.1. RELEASE</version>
</dependency>
</dependencies>
</project>
Copy the code
Use 9.
You can then define a slave data source for the main project, as implemented in this article. So you can use the data source defined above in your main project.
10. Project structure