开发小技巧 - springboot项目启动控制台输出访问地址
在Spring Boot项目中,有时我们需要记录或输出访问的地址和IP,以便进行调试、监控或日志记录。以下是如何在Spring Boot中实现这一需求的方法:
1、编写获取所有访问地址工具类
package com.example.utils;
import cn.hutool.core.util.StrUtil;
import org.springframework.boot.web.context.WebServerApplicationContext;
import java.net.InetAddress;
import java.net.NetworkInterface;
import java.net.SocketException;
import java.util.*;
/**
* IP地址工具类
* @author 李东阳
*/
public class IpAddressUtils {
/**
* 获取项目启动的IP地址
* 注: 仅限springboot项目
**/
public static List < String > getIpAddressOfStartUp(WebServerApplicationContext context) {
List < String > addressList = new ArrayList < > ();
try {
Enumeration < NetworkInterface > interfaces = NetworkInterface.getNetworkInterfaces();
for(NetworkInterface networkInterface: Collections.list(interfaces)) {
Enumeration < InetAddress > inetAddresses = networkInterface.getInetAddresses();
for(InetAddress inetAddress: Collections.list(inetAddresses)) {
if(!inetAddress.isLoopbackAddress() && inetAddress.isSiteLocalAddress()) {
String address = StrUtil.utf8Str(inetAddress.getHostAddress());
int port = context.getWebServer().getPort();
String ipAddress = StrUtil.format("http://{}:{}", address, port);
addressList.add(ipAddress);
}
}
}
return addressList;
} catch (SocketException e) {
e.printStackTrace();
return addressList;
}
}
}
2、在启动类中使用
package com.example;
import cn.hutool.core.lang.Console;
import com.example.utils.IpAddressUtils;
import org.springframework.boot.ApplicationArguments;
import org.springframework.boot.ApplicationRunner;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.web.context.WebServerApplicationContext;
import org.springframework.context.annotation.Bean;
import java.util.List;
/**
* 项目启动器
* @author lidy
*/
@SpringBootApplication
public class BlogApplication {
public static void main(String[] args) {
SpringApplication.run(BlogApplication.class, args);
}
/**
* 项目启动输出访问地址
*/
@Bean
public ApplicationRunner applicationRunner(WebServerApplicationContext context) {
return (ApplicationArguments args) - > {
try {
Console.log("===============项目启动成功 start===============");
List < String > ipAddressList = IpAddressUtils.getIpAddressOfStartUp(context);
ipAddressList.forEach(Console::log);
Console.log("================项目启动成功 end================");
} catch (Exception e) {
e.printStackTrace();
}
};
}
}
注:本案例中使用到了hutool工具来做控制台输出,需要在pom.xml引入如下如下坐标。
<dependency>
<groupId>cn.hutool</groupId>
<artifactId>hutool-all</artifactId>
<version>5.8.22</version>
</dependency>
如果不想引入相关工具,可以使用其他控制台输出方案即可。
3、效果展示:
热门相关:明朝败家子 我和超级大佬隐婚了 奈何老公太宠我 与校花同居:高手风流 绝代疯少