在现代Java开发中,Spring Boot无疑是一个强大且便捷的框架,它通过提供大量的Starter来简化依赖管理和项目配置。有时,我们可能需要为特定功能或团队定制Starter。本文将指导你如何创建自己的Spring Boot Starter并将其推送到远程公共服务器上,以便于团队成员或其他开发者使用。
新建项目
本文准备封装一个简单的 MD5摘要工具的 Starter,命名为 md5test-spring-boot-starter,其本质就是一个 Maven项目,只不过我们需要完善pom文件的相关依赖:
<?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>com.yu</groupId><artifactId>md5Cipher-spring-boot-starter</artifactId><version>1.3.1</version><properties><maven.compiler.source>8</maven.compiler.source><maven.compiler.target>8</maven.compiler.target></properties><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-autoconfigure</artifactId></dependency></dependencies><dependencyManagement><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-dependencies</artifactId><version>2.6.13</version><type>pom</type><scope>import</scope></dependency></dependencies></dependencyManagement></project>
编写业务逻辑
首先提供一个 MD5Util工具类,负责实际的 MD5加密:
package com.yu.utils;import java.security.MessageDigest;public class MD5Util {public static String getMD5(String source) {return getMD5(source.getBytes());}public static String getMD5(byte[] source) {String s = null;char hexDigits[] = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F'};try {MessageDigest md = MessageDigest.getInstance("MD5");byte[] tmp;synchronized (MD5Util.class) {md.update(source);tmp = md.digest();}char str[] = new char[16 * 2];int k = 0;for (int i = 0; i < 16; i++) {byte byte0 = tmp[i];str[k++] = hexDigits[byte0 >>> 4 & 0xf];str[k++] = hexDigits[byte0 & 0xf];}s = new String(str);} catch (Exception e) {e.printStackTrace();}return s;}
}
再来提供一个 MD5Service类 进行一次封装
public class MD5Service {public String getMD5(String input) {return MD5Util.getMD5(input.getBytes());}
}
编写自动装配类
这一步十分重要,也是编写 Spring Boot Starter最重要的一步:
@Configuration
public class MD5AutoConfiguration {@Beanpublic MD5Service md5Service() {return new MD5Service();}}
当然此处可以说是最简自动装配类了,该部分其实还包含各种丰富的可控注解,可以 参考 Spring Boot官方文档!
编写 spring.factories
我们还需要在 resources/META-INF/ 下创建一个名为 spring.factories的文件,然后置入以下内容:
org.springframework.boot.autoconfigure.EnableAutoConfiguration=\com.yu.config.MD5AutoConfiguration
推送到远端仓库
很多公司都搭有私有的 Maven仓库,但个人实验可以借助于 JitPack这个 “远端公服”来为我们托管自制的 Spring Boot Starter。
我们将编写好的 Spring Boot Starter代码置于 Github公有仓库上,然后通过 JitPack来拉取我们的代码并打包生成Jar包即可。
使用 Spring Boot Starter
新建一个测试工程来测试一下我们编写的 md5-cipher-spring-boot-starter。工程创建完毕后,在 pom.xml中加入如下两个元素:
- 添加 JitPack repository
<repositories><repository><id>jitpack.io</id><url>https://jitpack.io</url></repository>
</repositories>
- 添加 md5-cipher-spring-boot-starter依赖:
<dependency><groupId>com.github.lnoom</groupId><artifactId>md5-cipher-spring-boot-starter</artifactId><version>d315929d19</version>
</dependency>
再编写一个测试 Controller来测一下MD5摘要算法的功能:
application.yml
md5:password: zhangyu
@RestController
public class TestController {@Autowiredprivate MD5Service md5Service;@Value("${md5.password}")private String password;@GetMapping("/test")public ResponseEntity<String> getMD5() {String result = "MD5加密结果为:" + md5Service.getMD5(password);return ResponseEntity.ok(result);}
}
调用 /test接口后的加密结果为:
MD5加密结果为:AE61268246C931C4160F1DBD539CC073
(jitpack.io) 引入不生效问题
在当前项目的maven对应的 setting.xml 中,修改一下镜像的配置,即:
原本是
<mirrorOf>*</mirrorOf>
改为:
<mirrorOf>*,!jitpack.io</mirrorOf>
创建并分享一个Spring Boot Starter不仅可以提高开发效率,还能促进团队间的协作和技术共享。通过遵循上述步骤,你可以快速地制作并部署自定义的Starter,让其他开发者也能轻松集成和使用你的代码。