Spring:如何查看Spring应用对外提供了哪些API接口?

在开发Spring应用时一般都会通过Controller层对外提供API接口,另外Spring自身也会隐式的提供一些API接口。这里就有一个问题,在应用启动时,Controller层API接口和隐式API接口到底有哪些能真正对外提供服务呢?

下面先把方法提供了出来,然后再详细讲解。

一、配置方法

以spring和logback的如下版本进行说明

spring-webmvc-5.3.31.jar

logback-classic-1.2.12.jar

logback-core-1.2.12.jar

logback.xml

XML 复制代码
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
	<property name="LOG_HOME" value="/applog" />
	<appender name="console" class="ch.qos.logback.core.ConsoleAppender">
		<encoder>
			<pattern>%msg%n</pattern>
		</encoder>
	</appender>
	<appender name="rollingFile" class="ch.qos.logback.core.rolling.RollingFileAppender">
		<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
			<fileNamePattern>${LOG_HOME}/app.%d{yyyy-MM-dd}.log</fileNamePattern>
		</rollingPolicy>
		<encoder>
			<pattern>%d|%-5p|%t|%logger|%C.%M[%L]|%m%n</pattern>
		</encoder>
	</appender>

	<root level="info" additivity="false">
		<appender-ref ref="rollingFile" />
	</root>
	<logger name="com.test" level="INFO" additivity="false">
		<appender-ref ref="rollingFile" />
	</logger>
	<logger name="_org.springframework.web.servlet.HandlerMapping.Mappings" level="DEBUG" additivity="false">
		<appender-ref ref="rollingFile" />
	</logger>
	<logger name="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping" level="DEBUG" additivity="false">
		<appender-ref ref="rollingFile" />
	</logger>

</configuration>

spring应用启动后会打印如下日志:

红色框是由配置_org.springframework.web.servlet.HandlerMapping.Mappings打印的,这个配置前的下划线是必须有的,没有下划线的话是打印不出来的。打印出的内容就是这个spring应用支持的API接口及它对应的Controller类和方法,其中既包含用户自定义的(比如:SseController),也包含Spring隐式提供的(比如:BasicErrorController)。

绿色框是由配置org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping打印的,它显示了spring应用总共提供了多少个API接口。

通过上述配置,就能打印出这个spring应用实际能够提供的API接口。如果用户自定义的Controller中的API接口在这里没有显示出来,就需要查一下代码或配置中是否存在什么问题了。

二、配置说明

红色框中打印的内容是由如下代码生成的:

org.springframework.web.servlet.handler.AbstractHandlerMethodMapping

其中mappingsLogger是在如下类中定义的:

org.springframework.web.servlet.handler.AbstractHandlerMapping

而为什么要加下划线,是因为调用了如下方法:

org.springframework.core.log.LogDelegateFactory

绿色框中打印的内容是由如下代码生成的:

org.springframework.web.servlet.handler.AbstractHandlerMethodMapping

经过以上讲解,应该已经清楚说明怎样配置及为什么要这样配置了,以后开发spring应用时只要采用以上方法就能比较方便的查看所有API接口。

相关推荐
二月夜2 小时前
剖析Java正则表达式回溯问题
java·正则表达式
xuhaoyu_cpp_java2 小时前
项目学习(三)分页查询
java·经验分享·笔记·学习
程序员二叉3 小时前
【Java】集合面试全套精讲|HashMap/ArrayList高频考点完整版
java·面试·哈希算法
cfm_29143 小时前
JVM GC垃圾回收初步了解
java·开发语言·jvm
心之伊始3 小时前
LangChain4j RAG 实战:Java 后端如何把本地文档接入 Embedding 检索链路
java·架构·源码分析·csdn
许彰午4 小时前
17_synchronized关键字深度解析
java·开发语言
Xzh04235 小时前
AI Agent 学习路线(Java 后端方向)
java·人工智能·学习
艾利克斯冰6 小时前
Java 设计模式-行为型模式(更新中)
java·开发语言·设计模式
倒霉蛋小马6 小时前
Java新特性:record关键字
java·开发语言
折哥的程序人生 · 物流技术专研6 小时前
《Java 100 天进阶之路》第95篇:消息队列基础(RocketMQ/Kafka)(2026版)
java·面试·kafka·rocketmq·java-rocketmq·求职招聘