zoukankan      html  css  js  c++  java
  • Spring Boot-右键maven build成功但是直接运行main方法出错的解决方案

    1、代码就一个Controller,从官网复制过来的,如下

     1 package com.springboot.controller;
     2 
     3 import org.springframework.boot.SpringApplication;
     4 import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
     5 import org.springframework.stereotype.Controller;
     6 import org.springframework.web.bind.annotation.*;
     7 
     8 @Controller
     9 @EnableAutoConfiguration
    10 public class SampleController {
    11     
    12     @RequestMapping("/index")
    13     @ResponseBody
    14     String home() {
    15         return "Hello World";
    16     }
    17 
    18     public static void main(String[] args) throws Exception {
    19         SpringApplication.run(SampleController.class, args);
    20     }
    21 }

    2、在项目上右键,maven build,输入 spring-boot:run,过几秒后控制台能看见success,也能看见Hello World,但是没有传说中的那个用字符拼拼出来的spring图案,而且http://localhost:8080/也打不开,于是我机智的在上面的SampleController类中右键->java Application,果真,出错了,还more than 18... 错误如下:

    1 Cannot instantiate interface org.springframework.boot.SpringApplicationRunListener : org.springframework.boot.context.event.EventPublishingRunListener

    等等之类的,就是找不到类的error

    3、我的解决办法

    之前我的pom.xml:

    1 <parent>
    2     <groupId>org.springframework.boot</groupId>
    3     <artifactId>spring-boot-starter-parent</artifactId>
    4     <version>1.5.8.RELEASE</version>
    5 </parent>

    百度、搜狗、谷歌找了2个小时的方法,自己手动引入其他dependency等等都不行,但是更改了springboot的版本就好了,更改后如下:

    1 <parent>
    2     <groupId>org.springframework.boot</groupId>
    3     <artifactId>spring-boot-starter-parent</artifactId>
    4     <version>1.4.7.RELEASE</version>
    5 </parent>

    4、最后在SampleController类中右键->java Application,终于再console中输出了:

      .   ____          _            __ _ _
     /\ / ___'_ __ _ _(_)_ __  __ _    
    ( ( )\___ | '_ | '_| | '_ / _` |    
     \/  ___)| |_)| | | | | || (_| |  ) ) ) )
      '  |____| .__|_| |_|_| |_\__, | / / / /
     =========|_|==============|___/=/_/_/_/
     :: Spring Boot ::        (v1.4.7.RELEASE)
    
    2017-11-03 16:17:14.954  INFO 6416 --- [           main] c.s.controller.SampleController          : Starting SampleController on USER-20170626MT with PID 6416 (D:j2ee_workspaceSpringTest	argetclasses started by Administrator in D:j2ee_workspaceSpringTest)
    2017-11-03 16:17:14.956  INFO 6416 --- [           main] c.s.controller.SampleController          : No active profile set, falling back to default profiles: default
    2017-11-03 16:17:15.005  INFO 6416 --- [           main] ationConfigEmbeddedWebApplicationContext : Refreshing org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@411f53a0: startup date [Fri Nov 03 16:17:15 CST 2017]; root of context hierarchy
    2017-11-03 16:17:16.688  INFO 6416 --- [           main] s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat initialized with port(s): 8080 (http)
    2017-11-03 16:17:16.702  INFO 6416 --- [           main] o.apache.catalina.core.StandardService   : Starting service [Tomcat]

    打开http://localhost:8080/也能看见我的Hello World

    仔细观察了最后一句,应该还有一些问题。

    ps:如果你也遇见类似的问题,不要放弃,坚持,一定能解决的。由此纪念我的这个下午,好了,我开测了~

  • 相关阅读:
    Catharanthus roseus(长春花碱)的生物合成
    论文好句积累
    C# OpenFileDialog用法
    JAVA配置环境变量的意义
    如何为织梦表单添加时间
    winform开发基础
    tomcat中jsp编译
    垂直居中——父元素高度确定的单行文本、父元素高度确定的多行文本
    水平居中——行内元素、定宽块、不定宽块
    批处理文件
  • 原文地址:https://www.cnblogs.com/youreyebows/p/7778973.html
Copyright © 2011-2022 走看看