У меня есть небольшое приложение для загрузки весны, которое предоставляет API через контроллер. Контроллер использует некоторые службы, в которых пользовательские репозитории mongodb.Веб-приложение Spring Boot не запускается
Мой pom.xml:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.springboot.testapp</groupId>
<artifactId>event-api</artifactId>
<version>1.0.0-SNAPSHOT</version>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.1.RELEASE</version>
</parent>
<properties>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
</properties>
<dependencies>
<!-- MONGO DB -->
<dependency>
<groupId>org.mongodb</groupId>
<artifactId>mongo-java-driver</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.data</groupId>
<artifactId>spring-data-mongodb</artifactId>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-mongodb</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
Контроллер:
@Controller
public class EventController {
@Autowired
private EventService eventService;
@Autowired
private EventAttendantService eventAttendantService;
@Autowired
private EventDayService eventDayService;
@GetMapping(value = "/event/{id}")
@ResponseBody
public Event getEventById(@PathVariable Long id) {
return eventService.getEventById(id);
}
@GetMapping(value = "/eventDays")
@ResponseBody
public List<EventDay> getEventDays() {
return eventDayService.getAllEventDays();
}
@GetMapping(value = "/eventDay/{id}")
@ResponseBody
public List<Event> getEventsForDay(@PathVariable Long eventDayId) {
EventDay eventDay = eventDayService.findById(eventDayId);
List<Event> events = eventDay.getEvents()
.stream()
.map(id -> eventService.getEventById(id))
.collect(Collectors.toList());
events.sort(new Comparator<Event>() {
@Override
public int compare(Event o1, Event o2) {
return o1.getStartTime().compareTo(o2.getStartTime());
}
});
return events;
}
@GetMapping(value = "/event/{id}/attendants")
@ResponseBody
public List<EventAttendant> getAttendantsForEvent(@PathVariable Long eventId) {
Event event = eventService.getEventById(eventId);
return event.getAttendants()
.stream()
.map(id -> eventAttendantService.getById(id))
.collect(Collectors.toList());
}
@PostMapping(value = "/eventDay")
@ResponseBody
public EventDay createEventDay(@RequestParam(value = "date") String date) {
return eventDayService.createEventDay(date);
}
@DeleteMapping(value = "/eventDay/{eventDayId}")
public void removeEventDay(@PathVariable(value = "eventDayId") Long eventDayId) {
EventDay eventDay = eventDayService.findById(eventDayId);
eventDay.getEvents()
.stream()
.forEach(eventId -> eventService.deleteEvent(eventId));
eventDayService.removeEventDay(eventDayId);
}
@PostMapping(value = "/event")
@ResponseBody
public Event createEvent(@RequestParam(value = "eventDayId") Long eventDayId,
@RequestParam(value = "name") String name,
@RequestParam(value = "description") String description,
@RequestParam(value = "location") String location,
@RequestParam(value = "startTime") String startTime,
@RequestParam(value = "endTime") String endTime) {
Event event = eventService.createEvent(name, description, location, startTime, endTime);
eventDayService.addEvent(eventDayId, event.getId());
return event;
}
@DeleteMapping(value = "/event/{eventId}")
@ResponseBody
public void removeEvent(@PathVariable(value = "eventId") Long eventId) {
List<EventDay> allEventDays = eventDayService.getAllEventDays();
Optional<EventDay> eventDayForEvent = allEventDays.stream()
.filter(eventDay -> eventDay.getEvents().contains(eventId))
.findFirst();
if (eventDayForEvent.isPresent()) {
eventDayService.removeEvent(eventId, eventDayForEvent.get().getId());
}
}
@PostMapping(value = "/attendant")
@ResponseBody
public EventAttendant createAttendant(@RequestParam(value = "firstName") String firstName,
@RequestParam(value = "lastName") String lastName) {
return eventAttendantService.create(firstName, lastName);
}
@PostMapping("/event/assign")
public void assignAttendant(@RequestParam(value = "eventId") Long eventId,
@RequestParam(value = "attendantId") Long attendantId) {
eventService.addAttendant(eventId, attendantId);
}
@PostMapping("/event/remove")
public void removeAttendant(@RequestParam(value = "eventId") Long eventId,
@RequestParam(value = "attendantId") Long attendantId) {
eventService.removeAttendant(eventId, attendantId);
}
}
Основной класс приложения:
@SpringBootApplication(scanBasePackages = "com.springboot.test")
public class EventsAPI {
private static final Logger LOG = LoggerFactory.getLogger(EventsAPI .class);
public static void main(String[] args) {
SpringApplication.run(EventsAPI .class, args);
}
@Bean
public EmbeddedServletContainerFactory servletContainer() {
TomcatEmbeddedServletContainerFactory factory = new TomcatEmbeddedServletContainerFactory();
factory.setPort(9000);
factory.setSessionTimeout(10, TimeUnit.MINUTES);
return factory;
}
}
Когда я бегу МВН весна-загрузки: запустить из запятой nd или Eclipse Я получаю всевозможные ошибки. Если удалить метод "servletContainer", я получаю:
org.springframework.context.ApplicationContextException: Unable to start EmbeddedWebApplicationContext due to missing EmbeddedServletContainerFactory bean.
Если это есть, я получаю другую ошибку:
Caused by: org.springframework.context.ApplicationContextException: Unable to start embedded container; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'servletContainer' defined in com.centric.centricexpress.CentricExpressAPI: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.springframework.boot.context.embedded.EmbeddedServletContainerFactory]: Factory method 'servletContainer' threw exception; nested exception is java.lang.NoClassDefFoundError: org/apache/catalina/LifecycleListener
Maven добавляет кот-встраивать-ядро-8.5.11 в зависимости , так что класс, который, как сообщается, не найден, существует. Это очень смущает меня.
Я также пробовал некоторые демонстрационные проекты, которые я нашел в Интернете, но мне не удается запустить любое приложение для загрузки весны, при этом встроенный контейнер прослушивает запросы.
Может ли кто-нибудь указать, что я делаю неправильно?
Большое спасибо.
Можете ли вы добавить полную трассировку стека исключений? На первый взгляд ваш код выглядит отлично. Попробуйте запустить 'mvn clean install' перед запуском' mvn spring-boot: run'? – artemisian
Я создам ответ с помощью stacktrace. – Cristian