繁体   English   中英

映射后加载fxml时出现javafx应用程序异常的Spring

[英]spring with javafx application exception when load fxml after mapping

在不映射fxml的情况下,此代码可以完美运行并加载fxml

如果我映射fxml遇到异常,我会尝试很多,但无法理解是什么问题.....

我认为SpringFxmlLoader类方法load()return语句不返回任何内容

javafx.fxml.LoadException:/ E:/aa/JavaFXwithSpringBoot/bin/test/spring/boot/LoginPage.fxml:15

在javafx.fxml.FXMLLoader.constructLoadException(FXMLLoader.java:2601)在javafx.fxml.FXMLLoader.loadImpl(FXMLLoader.java:2579)在javafx.fxml.FXMLLoader.loadImpl(FXMLLoader.java:2441)在javafx.fxml。在test.spring.boot.config.FXMLLoader.load(FXMLLoader.java:2409)在test.spring.boot.config.StageManager.loadViewNodeHierarchy(StageManager.java:80)的SpringFXMLLoader.load(SpringFXMLLoader.java:34)在test.spring.boot.Main.displayInitialScene(Main.java:35)的.spring.boot.config.StageManager.switchScene(StageManager.java:31)在test.spring.boot.Main.start(Main.java:24) )com.sun.javafx.application.LauncherImpl.lambda $ launchApplication1 $ 162(LauncherImpl.java:863)com.sun.javafx.application.PlatformImpl.lambda $ runAndWait $ 175(PlatformImpl.java:326)com.sun。 javafx.application.PlatformImpl.lambda $ null $ 173(PlatformImpl.java:295)(位于java.security.AccessController.doPrivileged(本机方法))(com.sun.javafx.application.PlatformImpl.lambda $ runLater $ 174(PlatformImpl.java:294) )在com.sun。 glass.ui.InvokeLaterDispatcher $ Future.run(InvokeLaterDispatcher.java:95)在com.sun.glass.ui.win.WinApplication._runLoop(本机方法)在com.sun.glass.ui.win.WinApplication.lambda $ null $ 148(WinApplication.java:191)at java.lang.Thread.run(未知源)原因:org.springframework.beans.factory.NoSuchBeanDefinitionException:在组织上没有类型为'test.spring.boot.LoginPageController'的合格bean .org.springframework.beans.factory.support.DefaultListableBeanFactory.getBean(DefaultListableBeanFactory.java:353)位于org.springframework.beans.factory.support.DefaultListableBeanFactory.getBean(DefaultListableBeanFactory.java:340)位于org.springframework.context.support.AbstractApplicationContext .getBean(AbstractApplicationContext.java:1090)at javafx.fxml.FXMLLoader $ ValueElement.processAttribute(FXMLLoader.java:929)at javafx.fxml.FXMLLoader $ InstanceDeclarationElement.processAttribute(FXMLLoader.java:971)at javafx.fxml.FXMLLoader $ Element.processStartElement(FXMLLoader.java:220)位于 位于javafx.fxml.FXMLLoader.processStartElement(FXMLLoader.java:2707)的javafx.fxml.FXMLLoader $ ValueElement.processStartElement(FXMLLoader.java:744)位于javafx.fxml.FXMLLoader.loadImpl(FXMLLoader.java:2527)... 16应用程序启动方法中的更多异常2017-10-24 17:18:03.779错误6416 --- [许可线程] test.spring.boot.config.StageManager:无法加载FXML视图>> / test / spring / boot / LoginPage .fxml

org.springframework.beans.factory.NoSuchBeanDefinitionException:在org.springframework.beans.factory.support.DefaultListableBeanFactory.getBean(DefaultListableBeanFactory.java:353)上没有类型为'test.spring.boot.LoginPageController'的合格Bean。 org.springframework.beans.factory.support.DefaultListableBeanFactory.getBean(DefaultListableBeanFactory.java:340)处的beans-4.3.11.RELEASE.jar:4.3.11.RELEASE]〜[spring-beans-4.3.11.RELEASE.jar :4.3.11.RELEASE]在org.springframework.context.support.AbstractApplicationContext.getBean(AbstractApplicationContext.java:1090)〜[spring-context-4.3.11.RELEASE.jar:4.3.11.RELEASE]在javafx.fxml .FXMLLoader $ ValueElement.processAttribute(FXMLLoader.java:929)〜[jfxrt.jar:na]在javafx.fxml.FXMLLoader $ InstanceDeclarationElement.processAttribute(FXMLLoader.java:971)〜[jfxrt.jar:na]在javafx.fxml .FXMLLoader $ Element.processStartElement(FXMLLoader.java:220)〜[jfxrt.jar:na] at javafx.fxml.FXMLLoader $ ValueElement.processStartElement(FXMLLoader。 java:744)〜[jfxrt.jar:na]在javafx.fxml.FXMLLoader.processStartElement(FXMLLoader.java:2707)〜[jfxrt.jar:na]在javafx.fxml.FXMLLoader.loadImpl(FXMLLoader.java:2527) javafx.fxml.FXMLLoader.loadImpl(FXMLLoader.java:2441)的[jfxrt.jar:na] javafx.fxml.FXMLLoader.load(FXMLLoader.java:2409)的[jfxrt.jar:na]〜[jfxrt。 jar:na]在test.spring.boot.config.SpringFXMLLoader.load(SpringFXMLLoader.java:34)〜[bin /:na]在test.spring.boot.config.StageManager.loadViewNodeHierarchy(StageManager.java:80)[ bin /:na]在test.spring.boot.config.StageManager.switchScene(StageManager.java:31)[bin /:na]在test.spring.boot.Main.displayInitialScene(Main.java:35)[bin / :na]在test.spring.boot.Main.start(Main.java:24)[bin /:na]在com.sun.javafx.application.LauncherImpl.lambda $ launchApplication1 $ 162(LauncherImpl.java:863)[jfxrt .jar:na]在com.sun.javafx.application.PlatformImpl.lambda $ runAndWait $ 175(PlatformImpl.java:326)〜[jfxrt.jar:na]在com.sun.javafx.application.PlatformImpl.lambda $ null $ 173 (PlatformImpl。 java:295)〜[jfxrt.jar:na] at java.security.AccessController.doPrivileged(本机方法)〜[na:1.8.0_131] at com.sun.javafx.application.PlatformImpl.lambda $ runLater $ 174(PlatformImpl。 java:294)〜[jfxrt.jar:na]在com.sun.glass.ui.InvokeLaterDispatcher $ Future.run(InvokeLaterDispatcher.java:95)〜[jfxrt.jar:na]在com.sun.glass.ui。 win.WinApplication._runLoop(本机方法)〜[jfxrt.jar:na]在com.sun.glass.ui.win.WinApplication.lambda $ null $ 148(WinApplication.java:191)〜[jfxrt.jar:na]在java.lang.Thread.run(未知来源)〜[na:1.8.0_131]

2017年10月24日17:18:03.846 INFO 6416 --- [lication Thread] scaAnnotationConfigApplicationContext:关闭org.springframework.context.annotation.AnnotationConfigApplicationContext@f096164:启动日期[2010年10月24日星期二17:18:02 IST]; 上下文层次结构的根2017-10-24 17:18:03.848 INFO 6416 --- [lication Thread] osjeaAnnotationMBeanExporter:在关闭java.lang.reflect.InvocationTargetException时在Sun.reflect.NativeMethodAccessorImpl.invoke0(本机方法)上注销JMX暴露的bean )处sun.reflect.NativeMethodAccessorImpl.invoke(未知源)处com.sun.javafx.application.LauncherImpl处java.lang.reflect.Method.invoke(未知源)处sun.reflect.DelegatingMethodAccessorImpl.invoke(未知源)处com.sun.javafx.application.LauncherImpl.launchApplication(LauncherImpl.java:328)上的launchApplicationWithArgs(LauncherImpl.java:389)在sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)处在sun.reflect.NativeMethodAccessorImpl.invoke(未知源) )在sun.reflect.DelegatingMethodAccessorImpl.invoke(未知源)在java.lang.reflect.Method.invoke(未知源)在sun.launcher.LauncherHelper $ FXHelper.main(未知源)原因:java.lang.RuntimeException:应用程序启动方法异常 od在com.sun.javafx.application.LauncherImpl.lambda $ launchApplication $ 155(LauncherImpl.java:182)处的com.sun.javafx.application.LauncherImpl.launchApplication1(LauncherImpl.java:917)处在java.lang.Thread.run (未知源)原因:java.lang.NullPointerException:在test.spring的javafx.scene.Scene。(Scene.java:194)处的javafx.scene.Scene。(Scene.java:336)根不能为null。在test.spring.boot.config.StageManager.show(StageManager.java:36)的boot.config.StageManager.prepareScene(StageManager.java:62)在test.spring.boot.config.StageManager.switchScene(StageManager.java: 32)在test.spring.boot.Main.displayInitialScene(Main.java:35)在test.spring.boot.Main.start(Main.java:24)在com.sun.javafx.application.LauncherImpl.lambda $ launchApplication1 com.sun.javafx.application.PlatformImpl.lambda $ runAndWait $ 175(PlatformImpl.java:326)com.sun.javafx.application.PlatformImpl.lambda $ null $ 173(PlatformImpl.java: 295)at java.security.AccessController.doPrivileged(Nat ive方法)com.sun.glass.ui.InvokeLaterDispatcher $ Future.run(InvokeLaterDispatcher.java:95)com.sun.javafx.application.PlatformImpl.lambda $ runLater $ 174(PlatformImpl.java:294) .glass.ui.win.WinApplication._runLoop(本机方法),位于com.sun.glass.ui.win.WinApplication.lambda $ null $ 148(WinApplication.java:191)... 1更多运行应用程序test.spring的异常。 boot.Main

Main.java

@ComponentScan("test.spring.boot")
@SpringBootApplication
public class Main extends Application {

    protected ConfigurableApplicationContext springContext;
    protected StageManager stageManager;

    @Override
    public void start(Stage primaryStage) throws IOException {
        stageManager = springContext.getBean(StageManager.class, primaryStage);
        displayInitialScene();
    }

    @Override
    public void init() throws Exception
    {
        springContext=springBootApplicationContext();
    }


    protected void displayInitialScene() {
        stageManager.switchScene(FxmlView.LOGIN);
    }


     @Override
     public void stop() throws Exception {
        springContext.close();
     }

    private ConfigurableApplicationContext springBootApplicationContext() {
        SpringApplicationBuilder builder = new SpringApplicationBuilder(Main.class);
        String[] args = getParameters().getRaw().stream().toArray(String[]::new);
        return builder.run(args);
    }

    public static void main(String[] args) {
        Application.launch(args);
    }
}

Controller.java

public class LoginPageController implements Initializable{

    @FXML
    private TextField txtUserName;

    @FXML
    private PasswordField txtPassward;

    @FXML
    private Button btnLogin;

    @FXML
    private Label lblLogin; 

    @Autowired
    private UserService userService;

    @Lazy
    @Autowired
    private StageManager stageManager;

    @FXML
    public void login()
    {
        if(userService.authenticate(txtUserName.getText(), txtPassward.getText()))
        {
            stageManager.switchScene(FxmlView.USER);
        }
        else
        {
            lblLogin.setText("Login Failed.");
        }
    }


    @Override
    public void initialize(URL location, ResourceBundle resources) {

    }
}

FxmlView.java

public enum FxmlView {
    USER {
        @Override
        public String getTitle() {
            return getStringFromResourceBundle("user.title");
        }

        @Override
        public String getFxmlFile() {
            return "/test/spring/boot/TestSpring.fxml";
        }
    }, 


    LOGIN {
        @Override
        public String getTitle() {
            return getStringFromResourceBundle("login.title");
        }

        @Override
        public String getFxmlFile() {
            return "/test/spring/boot/LoginPage.fxml";
        }
    };

    public abstract String getTitle();
    public abstract String getFxmlFile();

    String getStringFromResourceBundle(String key){
        return ResourceBundle.getBundle("Bundle").getString(key);
    }
}

SpringFxmlLoader.java

@Component
public class SpringFXMLLoader {
    private final ResourceBundle resourceBundle;
    private final ApplicationContext context;

    @Autowired
    public SpringFXMLLoader(ApplicationContext context, ResourceBundle resourceBundle) {
        this.resourceBundle = resourceBundle;
        this.context = context;
    }

    public Parent load(String fxmlPath) throws IOException {      
        FXMLLoader loader = new FXMLLoader();
        loader.setControllerFactory(context::getBean); //Spring now FXML Controller Factory
        loader.setResources(resourceBundle);
        loader.setLocation(getClass().getResource(fxmlPath));
        System.out.println("springfxmlloader class : "+fxmlPath);
        System.out.println("LOADER : ");
        return loader.load();
    }
}

StageManager.java

public class StageManager {

 private static final Logger LOG = getLogger(StageManager.class);
    private final Stage primaryStage;
    private final SpringFXMLLoader springFXMLLoader;

    public StageManager(SpringFXMLLoader springFXMLLoader, Stage stage) {

    System.out.println(">>>>>>>>>>>>>>>>>> 1");

        this.springFXMLLoader = springFXMLLoader;
        this.primaryStage = stage;
    }

    public void switchScene(final FxmlView view) {
        System.out.println(">>>>>>>>>>>>>>>>>> 2");
        Parent viewRootNodeHierarchy = loadViewNodeHierarchy(view.getFxmlFile());
        show(viewRootNodeHierarchy, view.getTitle());
    }

    private void show(final Parent rootnode, String title) {
        Scene scene = prepareScene(rootnode);
        //scene.getStylesheets().add("/styles/Styles.css");

        //primaryStage.initStyle(StageStyle.TRANSPARENT);
        primaryStage.setTitle(title);
        primaryStage.setScene(scene);
        primaryStage.sizeToScene();
        primaryStage.centerOnScreen();

        System.out.println(">>>>>>>>>>>>>>>>>> 3");

        try {
            primaryStage.show();
        } catch (Exception exception) {
            logAndExit ("Unable to show scene for title" + title,  exception);
        }
    }

    private Scene prepareScene(Parent rootnode){

        System.out.println(">>>>>>>>>>>>>>>>>> 4");
        Scene scene = primaryStage.getScene();

        System.out.println("SCN >>>>>>>>>>>>>>>>>>>> : "+ scene);

        if (scene == null) {
            scene = new Scene(rootnode);
        }
        scene.setRoot(rootnode);
        return scene;
    }


    private Parent loadViewNodeHierarchy(String fxmlFilePath) {

        System.out.println(">>>>>>>>>>>>>>>>>> 5 path: "+fxmlFilePath);
        Parent rootNode = null;
        try {
            System.out.println(fxmlFilePath);
            rootNode = springFXMLLoader.load(fxmlFilePath);
            System.out.println(">>>>5 : try");
            Objects.requireNonNull(rootNode, "A Root FXML node must not be null");
        } catch (Exception exception) {

            System.out.println("File path????? : "+fxmlFilePath);

            logAndExit("Unable to load FXML view >> " + fxmlFilePath, exception);
            exception.printStackTrace();
        }

        return rootNode;
    }


    private void logAndExit(String errorMsg, Exception exception) {

        System.out.println(">>>>>>>>>>>>>>>>>> 6");
        LOG.error(errorMsg, exception, exception.getCause());
        Platform.exit();
    }
}

你忘了添加一个刻板印象对你LoginPageController类,这就是为什么春节是告诉你:

org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type 'test.spring.boot.LoginPageController'

由于未标记该类,因此组件扫描将忽略它,并且不会为该类型分配Bean寄存器。

尝试:

@Controller
public class LoginPageController implements Initializable{

    @Autowired
    public LoginPageController(UserService userService, private StageManager stageManager){
        this.userService = userService;
        this.stageManager = stageManager;
    }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM