java SWT:Display.addFilter设置快捷键的例子-切换全屏

本文介绍如何使用Eclipse SWT的addFilter方法实现全局快捷键功能。通过示例代码展示了如何为F11键设置全屏切换功能,并提供了一种在自定义组件中添加和移除全局热键的方法。

以前只知道org.eclipse.swt.widgets.Widget以及子类可以添加Listener。
今天才搞清楚:
Display也有addListener方法,而且还有优先级更高的addFilter方法:

addFilter方法的原文说明:
Adds the listener to the collection of listeners who will be notified when an event of the given type occurs anywhere in a widget. The event type is one of the event constants defined in class SWT. When the event does occur, the listener is notified by sending it the handleEvent() message.

Setting the type of an event to SWT.None from within the handleEvent() method can be used to change the event type and stop subsequent Java listeners from running. Because event filters run before other listeners, event filters can both block other listeners and set arbitrary fields within an event. For this reason, event filters are both powerful and dangerous. They should generally be avoided for performance, debugging and code maintenance reasons.

从上面的说明可以知道使用addFilter方法添加Listener,可以拦截所有Widget的事件.
so,利用addFilter方法的这个特性可以实现全局的快捷键。
如下代码实现了F11切换全屏状态

        // F11全局快捷键,在切换全屏
        Display.getDefault().addFilter(SWT.KeyDown, new Listener(){
            @Override
            public void handleEvent(Event e) {
                if(SWTKeySupport.convertEventToUnmodifiedAccelerator(e)==SWT.F11){
                    Control focusControl = Display.getDefault().getFocusControl();              
                    boolean fullScreen = !getShell().getFullScreen();
                    {
                        // 应用代码。。。。
                    }                   
                    getShell().setFullScreen(fullScreen);
                    //shell.setMaximized(fullScreen);
                    // 恢复焦点
                    if(null!=focusControl)
                        focusControl.forceFocus();
                    e.doit=false;
                }
            }});

如果在普通的Widget中加入全局热键,则要记得在dispose中删除Listener,否则如果widget被销毁后,产生热键事件时会抛出异常
TestAddFilter.java

package testwb;

import org.eclipse.jface.bindings.keys.SWTKeySupport;
import org.eclipse.swt.SWT;
import org.eclipse.swt.widgets.Composite;
import org.eclipse.swt.widgets.Display;
import org.eclipse.swt.widgets.Event;
import org.eclipse.swt.widgets.Listener;

public class TestAddFilter extends Composite {
    // 侦听Ctrl-M键,实现全屏切换
    private final Listener ctrlmListener = new Listener() {
        @Override
        public void handleEvent(Event e) {
            if (SWTKeySupport.convertEventToUnmodifiedAccelerator(e) == (SWT.CTRL + 'M')) {
                System.out.println("Ctrl-M");
            }
        }
    };

    public TestAddFilter(Composite parent, int style) {
        super(parent, style);
        // 加入Ctrl-M全局快捷键监听
        getShell().getDisplay().addFilter(SWT.KeyDown, ctrlmListener);
        // 添加DisposeListener,对象被销毁时,删除filter
        addDisposeListener(new DisposeListener() {
            public void widgetDisposed(DisposeEvent e) {
                getShell().getDisplay().removeFilter(SWT.KeyDown, ctrlmListener);
            }
        });
    }
}

参考:
http://help.eclipse.org/neon/nftopic/org.eclipse.platform.doc.isv/reference/api/org/eclipse/swt/widgets/Display.html#addFilter-int-org.eclipse.swt.widgets.Listener-

C:\jdk-21.0.7\bin\java.exe -XX:TieredStopAtLevel=1 -Dspring.output.ansi.enabled=always -Dcom.sun.management.jmxremote -Dspring.jmx.enabled=true -Dspring.liveBeansView.mbeanDomain -Dspring.application.admin.enabled=true "-Dmanagement.endpoints.jmx.exposure.include=*" "-javaagent:D:\IntelliJ IDEA 2024.3.5\lib\idea_rt.jar=62854" -Dfile.encoding=UTF-8 -Dsun.stdout.encoding=UTF-8 -Dsun.stderr.encoding=UTF-8 -classpath C:\Users\86133\IdeaProjects\tools\target\classes;C:\Users\86133\.m2\repository\org\springframework\boot\spring-boot-starter-web\3.3.4\spring-boot-starter-web-3.3.4.jar;C:\Users\86133\.m2\repository\org\springframework\boot\spring-boot-starter\3.3.4\spring-boot-starter-3.3.4.jar;C:\Users\86133\.m2\repository\org\springframework\boot\spring-boot\3.3.4\spring-boot-3.3.4.jar;C:\Users\86133\.m2\repository\org\springframework\boot\spring-boot-autoconfigure\3.3.4\spring-boot-autoconfigure-3.3.4.jar;C:\Users\86133\.m2\repository\org\springframework\boot\spring-boot-starter-logging\3.3.4\spring-boot-starter-logging-3.3.4.jar;C:\Users\86133\.m2\repository\ch\qos\logback\logback-classic\1.5.8\logback-classic-1.5.8.jar;C:\Users\86133\.m2\repository\ch\qos\logback\logback-core\1.5.8\logback-core-1.5.8.jar;C:\Users\86133\.m2\repository\org\apache\logging\log4j\log4j-to-slf4j\2.23.1\log4j-to-slf4j-2.23.1.jar;C:\Users\86133\.m2\repository\org\apache\logging\log4j\log4j-api\2.23.1\log4j-api-2.23.1.jar;C:\Users\86133\.m2\repository\org\slf4j\jul-to-slf4j\2.0.16\jul-to-slf4j-2.0.16.jar;C:\Users\86133\.m2\repository\jakarta\annotation\jakarta.annotation-api\2.1.1\jakarta.annotation-api-2.1.1.jar;C:\Users\86133\.m2\repository\org\yaml\snakeyaml\2.2\snakeyaml-2.2.jar;C:\Users\86133\.m2\repository\org\springframework\boot\spring-boot-starter-json\3.3.4\spring-boot-starter-json-3.3.4.jar;C:\Users\86133\.m2\repository\com\fasterxml\jackson\datatype\jackson-datatype-jdk8\2.17.2\jackson-datatype-jdk8-2.17.2.jar;C:\Users\86133\.m2\repository\com\fasterxml\jackson\datatype\jackson-datatype-jsr310\2.17.2\jackson-datatype-jsr310-2.17.2.jar;C:\Users\86133\.m2\repository\com\fasterxml\jackson\module\jackson-module-parameter-names\2.17.2\jackson-module-parameter-names-2.17.2.jar;C:\Users\86133\.m2\repository\org\springframework\boot\spring-boot-starter-tomcat\3.3.4\spring-boot-starter-tomcat-3.3.4.jar;C:\Users\86133\.m2\repository\org\apache\tomcat\embed\tomcat-embed-core\10.1.30\tomcat-embed-core-10.1.30.jar;C:\Users\86133\.m2\repository\org\apache\tomcat\embed\tomcat-embed-websocket\10.1.30\tomcat-embed-websocket-10.1.30.jar;C:\Users\86133\.m2\repository\org\springframework\spring-web\6.1.13\spring-web-6.1.13.jar;C:\Users\86133\.m2\repository\org\springframework\spring-beans\6.1.13\spring-beans-6.1.13.jar;C:\Users\86133\.m2\repository\io\micrometer\micrometer-observation\1.13.4\micrometer-observation-1.13.4.jar;C:\Users\86133\.m2\repository\io\micrometer\micrometer-commons\1.13.4\micrometer-commons-1.13.4.jar;C:\Users\86133\.m2\repository\org\springframework\spring-webmvc\6.1.13\spring-webmvc-6.1.13.jar;C:\Users\86133\.m2\repository\org\springframework\spring-context\6.1.13\spring-context-6.1.13.jar;C:\Users\86133\.m2\repository\org\springframework\spring-expression\6.1.13\spring-expression-6.1.13.jar;C:\Users\86133\.m2\repository\org\springframework\boot\spring-boot-starter-data-jpa\3.3.4\spring-boot-starter-data-jpa-3.3.4.jar;C:\Users\86133\.m2\repository\org\springframework\boot\spring-boot-starter-aop\3.3.4\spring-boot-starter-aop-3.3.4.jar;C:\Users\86133\.m2\repository\org\aspectj\aspectjweaver\1.9.22.1\aspectjweaver-1.9.22.1.jar;C:\Users\86133\.m2\repository\org\springframework\boot\spring-boot-starter-jdbc\3.3.4\spring-boot-starter-jdbc-3.3.4.jar;C:\Users\86133\.m2\repository\com\zaxxer\HikariCP\5.1.0\HikariCP-5.1.0.jar;C:\Users\86133\.m2\repository\org\springframework\spring-jdbc\6.1.13\spring-jdbc-6.1.13.jar;C:\Users\86133\.m2\repository\org\hibernate\orm\hibernate-core\6.5.3.Final\hibernate-core-6.5.3.Final.jar;C:\Users\86133\.m2\repository\jakarta\persistence\jakarta.persistence-api\3.1.0\jakarta.persistence-api-3.1.0.jar;C:\Users\86133\.m2\repository\jakarta\transaction\jakarta.transaction-api\2.0.1\jakarta.transaction-api-2.0.1.jar;C:\Users\86133\.m2\repository\org\jboss\logging\jboss-logging\3.5.3.Final\jboss-logging-3.5.3.Final.jar;C:\Users\86133\.m2\repository\org\hibernate\common\hibernate-commons-annotations\6.0.6.Final\hibernate-commons-annotations-6.0.6.Final.jar;C:\Users\86133\.m2\repository\io\smallrye\jandex\3.1.2\jandex-3.1.2.jar;C:\Users\86133\.m2\repository\com\fasterxml\classmate\1.7.0\classmate-1.7.0.jar;C:\Users\86133\.m2\repository\net\bytebuddy\byte-buddy\1.14.19\byte-buddy-1.14.19.jar;C:\Users\86133\.m2\repository\org\glassfish\jaxb\jaxb-runtime\4.0.5\jaxb-runtime-4.0.5.jar;C:\Users\86133\.m2\repository\org\glassfish\jaxb\jaxb-core\4.0.5\jaxb-core-4.0.5.jar;C:\Users\86133\.m2\repository\org\eclipse\angus\angus-activation\2.0.2\angus-activation-2.0.2.jar;C:\Users\86133\.m2\repository\org\glassfish\jaxb\txw2\4.0.5\txw2-4.0.5.jar;C:\Users\86133\.m2\repository\com\sun\istack\istack-commons-runtime\4.1.2\istack-commons-runtime-4.1.2.jar;C:\Users\86133\.m2\repository\jakarta\inject\jakarta.inject-api\2.0.1\jakarta.inject-api-2.0.1.jar;C:\Users\86133\.m2\repository\org\antlr\antlr4-runtime\4.13.0\antlr4-runtime-4.13.0.jar;C:\Users\86133\.m2\repository\org\springframework\data\spring-data-jpa\3.3.4\spring-data-jpa-3.3.4.jar;C:\Users\86133\.m2\repository\org\springframework\data\spring-data-commons\3.3.4\spring-data-commons-3.3.4.jar;C:\Users\86133\.m2\repository\org\springframework\spring-orm\6.1.13\spring-orm-6.1.13.jar;C:\Users\86133\.m2\repository\org\springframework\spring-tx\6.1.13\spring-tx-6.1.13.jar;C:\Users\86133\.m2\repository\org\slf4j\slf4j-api\2.0.16\slf4j-api-2.0.16.jar;C:\Users\86133\.m2\repository\org\springframework\spring-aspects\6.1.13\spring-aspects-6.1.13.jar;C:\Users\86133\.m2\repository\org\springframework\boot\spring-boot-starter-security\3.3.4\spring-boot-starter-security-3.3.4.jar;C:\Users\86133\.m2\repository\org\springframework\spring-aop\6.1.13\spring-aop-6.1.13.jar;C:\Users\86133\.m2\repository\org\springframework\security\spring-security-config\6.3.3\spring-security-config-6.3.3.jar;C:\Users\86133\.m2\repository\org\springframework\security\spring-security-core\6.3.3\spring-security-core-6.3.3.jar;C:\Users\86133\.m2\repository\org\springframework\security\spring-security-crypto\6.3.3\spring-security-crypto-6.3.3.jar;C:\Users\86133\.m2\repository\org\springframework\security\spring-security-web\6.3.3\spring-security-web-6.3.3.jar;C:\Users\86133\.m2\repository\org\springframework\boot\spring-boot-starter-validation\3.3.4\spring-boot-starter-validation-3.3.4.jar;C:\Users\86133\.m2\repository\org\apache\tomcat\embed\tomcat-embed-el\10.1.30\tomcat-embed-el-10.1.30.jar;C:\Users\86133\.m2\repository\org\hibernate\validator\hibernate-validator\8.0.1.Final\hibernate-validator-8.0.1.Final.jar;C:\Users\86133\.m2\repository\jakarta\validation\jakarta.validation-api\3.0.2\jakarta.validation-api-3.0.2.jar;C:\Users\86133\.m2\repository\org\mybatis\spring\boot\mybatis-spring-boot-starter\3.0.3\mybatis-spring-boot-starter-3.0.3.jar;C:\Users\86133\.m2\repository\org\mybatis\spring\boot\mybatis-spring-boot-autoconfigure\3.0.3\mybatis-spring-boot-autoconfigure-3.0.3.jar;C:\Users\86133\.m2\repository\org\mybatis\mybatis\3.5.14\mybatis-3.5.14.jar;C:\Users\86133\.m2\repository\org\mybatis\mybatis-spring\3.0.3\mybatis-spring-3.0.3.jar;C:\Users\86133\.m2\repository\com\mysql\mysql-connector-j\8.3.0\mysql-connector-j-8.3.0.jar;C:\Users\86133\.m2\repository\org\projectlombok\lombok\1.18.34\lombok-1.18.34.jar;C:\Users\86133\.m2\repository\com\auth0\java-jwt\4.4.0\java-jwt-4.4.0.jar;C:\Users\86133\.m2\repository\com\fasterxml\jackson\core\jackson-databind\2.17.2\jackson-databind-2.17.2.jar;C:\Users\86133\.m2\repository\com\fasterxml\jackson\core\jackson-annotations\2.17.2\jackson-annotations-2.17.2.jar;C:\Users\86133\.m2\repository\com\fasterxml\jackson\core\jackson-core\2.17.2\jackson-core-2.17.2.jar;C:\Users\86133\.m2\repository\io\jsonwebtoken\jjwt-api\0.11.5\jjwt-api-0.11.5.jar;C:\Users\86133\.m2\repository\io\jsonwebtoken\jjwt-impl\0.11.5\jjwt-impl-0.11.5.jar;C:\Users\86133\.m2\repository\io\jsonwebtoken\jjwt-jackson\0.11.5\jjwt-jackson-0.11.5.jar;C:\Users\86133\.m2\repository\jakarta\xml\bind\jakarta.xml.bind-api\4.0.2\jakarta.xml.bind-api-4.0.2.jar;C:\Users\86133\.m2\repository\jakarta\activation\jakarta.activation-api\2.1.3\jakarta.activation-api-2.1.3.jar;C:\Users\86133\.m2\repository\org\springframework\spring-core\6.1.13\spring-core-6.1.13.jar;C:\Users\86133\.m2\repository\org\springframework\spring-jcl\6.1.13\spring-jcl-6.1.13.jar com.org.example.tools.ToolsApplication . ____ _ __ _ _ /\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \ ( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \ \\/ ___)| |_)| | | | | || (_| | ) ) ) ) ' |____| .__|_| |_|_| |_\__, | / / / / =========|_|==============|___/=/_/_/_/ :: Spring Boot :: (v3.3.4) 2025-08-02T13:53:30.651+08:00 INFO 17212 --- [tools] [ main] com.org.example.tools.ToolsApplication : Starting ToolsApplication using Java 21.0.7 with PID 17212 (C:\Users\86133\IdeaProjects\tools\target\classes started by 86133 in C:\Users\86133\IdeaProjects\tools) 2025-08-02T13:53:30.653+08:00 INFO 17212 --- [tools] [ main] com.org.example.tools.ToolsApplication : No active profile set, falling back to 1 default profile: "default" 2025-08-02T13:53:32.143+08:00 INFO 17212 --- [tools] [ main] .s.d.r.c.RepositoryConfigurationDelegate : Bootstrapping Spring Data JPA repositories in DEFAULT mode. 2025-08-02T13:53:32.213+08:00 INFO 17212 --- [tools] [ main] .s.d.r.c.RepositoryConfigurationDelegate : Finished Spring Data repository scanning in 60 ms. Found 2 JPA repository interfaces. 2025-08-02T13:53:32.296+08:00 DEBUG 17212 --- [tools] [ main] o.m.s.mapper.ClassPathMapperScanner : Identified candidate component class: file [C:\Users\86133\IdeaProjects\tools\target\classes\com\org\example\tools\mapper\BorrowRecordMapper.class] 2025-08-02T13:53:32.296+08:00 DEBUG 17212 --- [tools] [ main] o.m.s.mapper.ClassPathMapperScanner : Identified candidate component class: file [C:\Users\86133\IdeaProjects\tools\target\classes\com\org\example\tools\mapper\FeedbackMapper.class] 2025-08-02T13:53:32.296+08:00 DEBUG 17212 --- [tools] [ main] o.m.s.mapper.ClassPathMapperScanner : Identified candidate component class: file [C:\Users\86133\IdeaProjects\tools\target\classes\com\org\example\tools\mapper\RequestMapper.class] 2025-08-02T13:53:32.296+08:00 DEBUG 17212 --- [tools] [ main] o.m.s.mapper.ClassPathMapperScanner : Identified candidate component class: file [C:\Users\86133\IdeaProjects\tools\target\classes\com\org\example\tools\mapper\SysUserMapper.class] 2025-08-02T13:53:32.296+08:00 DEBUG 17212 --- [tools] [ main] o.m.s.mapper.ClassPathMapperScanner : Identified candidate component class: file [C:\Users\86133\IdeaProjects\tools\target\classes\com\org\example\tools\mapper\ToolMapper.class] 2025-08-02T13:53:32.296+08:00 DEBUG 17212 --- [tools] [ main] o.m.s.mapper.ClassPathMapperScanner : Identified candidate component class: file [C:\Users\86133\IdeaProjects\tools\target\classes\com\org\example\tools\mapper\ToolOperationLogMapper.class] 2025-08-02T13:53:32.296+08:00 DEBUG 17212 --- [tools] [ main] o.m.s.mapper.ClassPathMapperScanner : Identified candidate component class: file [C:\Users\86133\IdeaProjects\tools\target\classes\com\org\example\tools\mapper\UserMapper.class] 2025-08-02T13:53:32.296+08:00 DEBUG 17212 --- [tools] [ main] o.m.s.mapper.ClassPathMapperScanner : Identified candidate component class: file [C:\Users\86133\IdeaProjects\tools\target\classes\com\org\example\tools\mapper\UserRequestMapper.class] 2025-08-02T13:53:32.297+08:00 DEBUG 17212 --- [tools] [ main] o.m.s.mapper.ClassPathMapperScanner : Creating MapperFactoryBean with name 'borrowRecordMapper' and 'com.org.example.tools.mapper.BorrowRecordMapper' mapperInterface 2025-08-02T13:53:32.299+08:00 DEBUG 17212 --- [tools] [ main] o.m.s.mapper.ClassPathMapperScanner : Enabling autowire by type for MapperFactoryBean with name 'borrowRecordMapper'. 2025-08-02T13:53:32.299+08:00 DEBUG 17212 --- [tools] [ main] o.m.s.mapper.ClassPathMapperScanner : Creating MapperFactoryBean with name 'feedbackMapper' and 'com.org.example.tools.mapper.FeedbackMapper' mapperInterface 2025-08-02T13:53:32.300+08:00 DEBUG 17212 --- [tools] [ main] o.m.s.mapper.ClassPathMapperScanner : Enabling autowire by type for MapperFactoryBean with name 'feedbackMapper'. 2025-08-02T13:53:32.300+08:00 DEBUG 17212 --- [tools] [ main] o.m.s.mapper.ClassPathMapperScanner : Creating MapperFactoryBean with name 'requestMapper' and 'com.org.example.tools.mapper.RequestMapper' mapperInterface 2025-08-02T13:53:32.301+08:00 DEBUG 17212 --- [tools] [ main] o.m.s.mapper.ClassPathMapperScanner : Enabling autowire by type for MapperFactoryBean with name 'requestMapper'. 2025-08-02T13:53:32.301+08:00 DEBUG 17212 --- [tools] [ main] o.m.s.mapper.ClassPathMapperScanner : Creating MapperFactoryBean with name 'sysUserMapper' and 'com.org.example.tools.mapper.SysUserMapper' mapperInterface 2025-08-02T13:53:32.301+08:00 DEBUG 17212 --- [tools] [ main] o.m.s.mapper.ClassPathMapperScanner : Enabling autowire by type for MapperFactoryBean with name 'sysUserMapper'. 2025-08-02T13:53:32.301+08:00 DEBUG 17212 --- [tools] [ main] o.m.s.mapper.ClassPathMapperScanner : Creating MapperFactoryBean with name 'toolMapper' and 'com.org.example.tools.mapper.ToolMapper' mapperInterface 2025-08-02T13:53:32.301+08:00 DEBUG 17212 --- [tools] [ main] o.m.s.mapper.ClassPathMapperScanner : Enabling autowire by type for MapperFactoryBean with name 'toolMapper'. 2025-08-02T13:53:32.301+08:00 DEBUG 17212 --- [tools] [ main] o.m.s.mapper.ClassPathMapperScanner : Creating MapperFactoryBean with name 'toolOperationLogMapper' and 'com.org.example.tools.mapper.ToolOperationLogMapper' mapperInterface 2025-08-02T13:53:32.303+08:00 DEBUG 17212 --- [tools] [ main] o.m.s.mapper.ClassPathMapperScanner : Enabling autowire by type for MapperFactoryBean with name 'toolOperationLogMapper'. 2025-08-02T13:53:32.303+08:00 DEBUG 17212 --- [tools] [ main] o.m.s.mapper.ClassPathMapperScanner : Creating MapperFactoryBean with name 'userMapper' and 'com.org.example.tools.mapper.UserMapper' mapperInterface 2025-08-02T13:53:32.303+08:00 DEBUG 17212 --- [tools] [ main] o.m.s.mapper.ClassPathMapperScanner : Enabling autowire by type for MapperFactoryBean with name 'userMapper'. 2025-08-02T13:53:32.303+08:00 DEBUG 17212 --- [tools] [ main] o.m.s.mapper.ClassPathMapperScanner : Creating MapperFactoryBean with name 'userRequestMapper' and 'com.org.example.tools.mapper.UserRequestMapper' mapperInterface 2025-08-02T13:53:32.304+08:00 DEBUG 17212 --- [tools] [ main] o.m.s.mapper.ClassPathMapperScanner : Enabling autowire by type for MapperFactoryBean with name 'userRequestMapper'. 2025-08-02T13:53:32.801+08:00 INFO 17212 --- [tools] [ main] o.s.b.w.embedded.tomcat.TomcatWebServer : Tomcat initialized with port 8089 (http) 2025-08-02T13:53:32.814+08:00 INFO 17212 --- [tools] [ main] o.apache.catalina.core.StandardService : Starting service [Tomcat] 2025-08-02T13:53:32.814+08:00 INFO 17212 --- [tools] [ main] o.apache.catalina.core.StandardEngine : Starting Servlet engine: [Apache Tomcat/10.1.30] 2025-08-02T13:53:32.868+08:00 INFO 17212 --- [tools] [ main] o.a.c.c.C.[Tomcat].[localhost].[/api] : Initializing Spring embedded WebApplicationContext 2025-08-02T13:53:32.869+08:00 INFO 17212 --- [tools] [ main] w.s.c.ServletWebServerApplicationContext : Root WebApplicationContext: initialization completed in 2168 ms 2025-08-02T13:53:33.005+08:00 INFO 17212 --- [tools] [ main] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Starting... 2025-08-02T13:53:33.514+08:00 INFO 17212 --- [tools] [ main] com.zaxxer.hikari.pool.HikariPool : HikariPool-1 - Added connection com.mysql.cj.jdbc.ConnectionImpl@51ff3c4b 2025-08-02T13:53:33.516+08:00 INFO 17212 --- [tools] [ main] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Start completed. 2025-08-02T13:53:33.552+08:00 INFO 17212 --- [tools] [ main] o.hibernate.jpa.internal.util.LogHelper : HHH000204: Processing PersistenceUnitInfo [name: default] 2025-08-02T13:53:33.616+08:00 INFO 17212 --- [tools] [ main] org.hibernate.Version : HHH000412: Hibernate ORM core version 6.5.3.Final 2025-08-02T13:53:33.661+08:00 INFO 17212 --- [tools] [ main] o.h.c.internal.RegionFactoryInitiator : HHH000026: Second-level cache disabled 2025-08-02T13:53:34.007+08:00 INFO 17212 --- [tools] [ main] o.s.o.j.p.SpringPersistenceUnitInfo : No LoadTimeWeaver setup: ignoring JPA class transformer 2025-08-02T13:53:34.421+08:00 INFO 17212 --- [tools] [ main] o.h.e.t.j.p.i.JtaPlatformInitiator : HHH000489: No JTA platform available (set 'hibernate.transaction.jta.platform' to enable JTA platform integration) 2025-08-02T13:53:34.427+08:00 INFO 17212 --- [tools] [ main] j.LocalContainerEntityManagerFactoryBean : Initialized JPA EntityManagerFactory for persistence unit 'default' 2025-08-02T13:53:34.446+08:00 WARN 17212 --- [tools] [ main] ConfigServletWebServerApplicationContext : Exception encountered during context initialization - cancelling refresh attempt: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'securityConfig' defined in file [C:\Users\86133\IdeaProjects\tools\target\classes\com\org\example\tools\config\SecurityConfig.class]: Unsatisfied dependency expressed through constructor parameter 0: No qualifying bean of type 'com.org.example.tools.security.JwtAuthenticationFilter' available: expected at least 1 bean which qualifies as autowire candidate. Dependency annotations: {} 2025-08-02T13:53:34.447+08:00 INFO 17212 --- [tools] [ main] j.LocalContainerEntityManagerFactoryBean : Closing JPA EntityManagerFactory for persistence unit 'default' 2025-08-02T13:53:34.449+08:00 INFO 17212 --- [tools] [ main] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Shutdown initiated... 2025-08-02T13:53:34.457+08:00 INFO 17212 --- [tools] [ main] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Shutdown completed. 2025-08-02T13:53:34.458+08:00 INFO 17212 --- [tools] [ main] o.apache.catalina.core.StandardService : Stopping service [Tomcat] 2025-08-02T13:53:34.467+08:00 INFO 17212 --- [tools] [ main] .s.b.a.l.ConditionEvaluationReportLogger : Error starting ApplicationContext. To display the condition evaluation report re-run your application with 'debug' enabled. 2025-08-02T13:53:34.498+08:00 ERROR 17212 --- [tools] [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPLICATION FAILED TO START *************************** Description: Parameter 0 of constructor in com.org.example.tools.config.SecurityConfig required a bean of type 'com.org.example.tools.security.JwtAuthenticationFilter' that could not be found. Action: Consider defining a bean of type 'com.org.example.tools.security.JwtAuthenticationFilter' in your configuration.
最新发布
08-03
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

10km

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值