だから私は春を学ぼうとしており、多くのチュートリアルを読み、フラッシュドライブにあるプロジェクトからコードをコピーしようとしています。
私はすでにTomcatをセットアップしており、見つけることができますが、ここでまだいくつかの問題があります。問題は、通常、ブラウザからコントローラーのアクションに問題なくアクセスできることですが、注釈とContextLoaderListenerの追加を開始すると、常に404ステータスが表示されます。私は何をしたのかわかりませんが、いくつかのことを微調整することで、私のブラウザーは少なくともコントローラーに再びアクセスしようとします。しかし、この投稿の最後で共有する巨大なエラーログをスローします。
これらは私の依存関係です:
- junit 4.12
- spring-webmvc 4.1.6.RELEASE
- spring-context 4.1.6.RELEASE
- spring-web 4.1.6.RELEASE
- spring-beans 4.1.6.RELEASE
- spring-data-jpa 1.8.0.RELEASE
- spring-jdbc 4.1.6.RELEASE
- mysql-connector-Java 5.1.35
- jstl 1.2
- javax.servlet-api 3.1.0(スコープ提供)
- javax.servlet.jsp-api 3.1.0(スコープ提供)
- jackson-databind 2.5.4
- ジャクソンコア2.5.4
- jackson-core-asl 1.9.13
- jackson-datatype-hibernate4 2.5.4
- hibernate-annotations 3.5.6-最終
- hibernate-commons-annotations 3.2.0。最終
- hibernate-entitymanager 4.3.10。最終
- jsondoc-core 1.1.15
- jsondoc-springmvc 1.1.15
- jsondoc-ui-webjar 1.1.15
- commons-logging 1.2
- commons-logging-api 1.1
- commons-dbcp 1.4
私のビルドプラグインは次のとおりです。
- maven-compiler-plugin 3.1(ソースおよびターゲット1.8)
- maven-war-plugin 2.4
私のweb.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://Java.Sun.com/xml/ns/javaee"
xsi:schemaLocation="http://Java.Sun.com/xml/ns/javaee
http://Java.Sun.com/xml/ns/javaee/web-app_3_0.xsd"
version="3.0">
<display-name>Spring Web MVC Application</display-name>
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>
classpath*:WEB-INF/application-context.xml
classpath*:WEB-INF/persistence-context.xml
</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<servlet>
<servlet-name>mvc-dispatcher</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/mvc-dispatcher-servlet.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>mvc-dispatcher</servlet-name>
<url-pattern>/api/*</url-pattern>
</servlet-mapping>
私のmvc-dispatcher-servlet
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd">
<context:component-scan base-package="com.ve" use-default-filters="false">
<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller" />
</context:component-scan>
<mvc:annotation-driven>
<mvc:message-converters>
<bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">
<property name="objectMapper">
<bean class="com.ve.main.HibernateAwareObjectMapper" />
</property>
</bean>
</mvc:message-converters>
</mvc:annotation-driven>
<bean id="documentationController" class="org.jsondoc.springmvc.controller.JSONDocController">
<constructor-arg name="version" value="1.0"/>
<constructor-arg name="basePath" value="http://localhost:4848/spring2"/>
<constructor-arg name="packages">
<list>
<value>com.ve</value>
</list>
</constructor-arg>
</bean>
私のapplication-context.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd">
<context:component-scan base-package="com.ve" use-default-filters="false">
<context:include-filter type="annotation" expression="org.springframework.stereotype.Repository" />
<context:include-filter type="annotation" expression="org.springframework.stereotype.Service" />
</context:component-scan>
persistence-context.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:jpa="http://www.springframework.org/schema/data/jpa"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd
http://www.springframework.org/schema/data/jpa http://www.springframework.org/schema/data/jpa/spring-jpa.xsd">
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost:3306/my_database" />
<property name="username" value="my_actual_db_user" />
<property name="password" value="my_actual_db_password" />
</bean>
<bean id="persistenceUnitManager" class="org.springframework.orm.jpa.persistenceunit.DefaultPersistenceUnitManager">
<property name="defaultDataSource" ref="dataSource" />
</bean>
<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
<property name="persistenceUnitManager" ref="persistenceUnitManager" />
<property name="persistenceUnitName" value="persistenceUnit" />
</bean>
<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
<property name="entityManagerFactory" ref="entityManagerFactory" />
</bean>
<tx:annotation-driven transaction-manager="transactionManager" />
<jpa:repositories base-package="com.ve" entity-manager-factory-ref="entityManagerFactory" transaction-manager-ref="transactionManager" />
また、情報のために、クラスコードとプロジェクト構造も引用します。
StockController
package com.ve.common.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody;
import com.ve.common.service.StockService;
@Controller
@RequestMapping("/stock")
public class StockController {
@Autowired
private StockService stockService;
public StockController(){}
@RequestMapping(value="/list", method = RequestMethod.GET, produces={"application/json","application/xml"})
@ResponseBody
public String findAllStocks(){
return "stocks";
}
}
StockService
package com.ve.common.service;
import Java.util.List;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import com.ve.common.model.Stock;
import com.ve.common.repo.StockRepository;
@Service
public class StockService {
@Autowired
private StockRepository stockRepository;
StockService(){}
List<Stock> findStock(){
return (List<Stock>) stockRepository.findAll();
}
}
StockRepository
package com.ve.common.repo;
import Java.util.List;
import org.springframework.data.repository.CrudRepository;
import org.springframework.stereotype.Repository;
import com.ve.common.model.Stock;
@Repository
public interface StockRepository extends CrudRepository<Stock, Integer> {
List<Stock> findByStockName(String stockName);
Stock findByStockId(Integer stockId);
}
私のモデルは、Serializable(JPAツールによって作成された)を実装する基本的なEntityクラスです。これが私のプロジェクトの構造です。申し訳ありませんが、画像を小さくすることができませんでした(私は現時点で大騒ぎしています)。
そして、「 http:// localhost:4848/spring2/api/welcome/hi 」または「 http://localhost:4848/spring2/api/stock/list "
HTTPステータス500-サーブレットmvc-dispatcherのServlet.init()が例外をスローしました
タイプ例外レポート
サーブレットmvc-dispatcherのメッセージServlet.init()が例外をスローしました
説明サーバーは、この要求の実行を妨げる内部エラーを検出しました。
例外
javax.servlet.ServletException:サーブレットmvc-dispatcherのServlet.init()は例外org.Apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.Java:472)org.Apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve。 Java:99)org.Apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.Java:936)org.Apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.Java:407)org.Apache.coyote.http11.AbstractHttp11Processor。 process(AbstractHttp11Processor.Java:1004)org.Apache.coyote.AbstractProtocol $ AbstractConnectionHandler.process(AbstractProtocol.Java:589)org.Apache.Tomcat.util.net.JIoEndpoint $ SocketProcessor.run(JIoEndpoint.Java:310)Java。 util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.Java:1142)Java.util.concurrent.ThreadPoolExecutor $ Worker.run(ThreadPoolExecutor.Java:617)Java.lang.Thread.run(Thread.Java:745)
根本的な原因
org.springframework.beans.factory.BeanCreationException:「stockController」という名前のBeanの作成エラー:自動配線された依存関係の挿入に失敗しました。ネストされた例外はorg.springframework.beans.factory.BeanCreationException:フィールドを自動配線できませんでした:private com.ve.common.service.StockService com.ve.common.controller.StockController.stockService;ネストされた例外はorg.springframework.beans.factory.NoSuchBeanDefinitionException:依存関係のタイプ[com.ve.common.service.StockService]の修飾Beanが見つかりません:この依存関係の自動配線候補として修飾される少なくとも1つのBeanが必要です。依存アノテーション:{@ org.springframework.beans.factory.annotation.Autowired(required = true)} org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessPropertyValues(AutowiredAnnotationBeanPostProcessor.Java:334)org.springframework.beans.factory.factory.factory.factory.factory.factoryサポート476)org.springframework.beans.factory.support.AbstractBeanFactory $ 1.getObject(AbstractBeanFactory.Java:303)org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.Java:230)org.springframework.beans.factory .support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.Java:299)org.springframe work.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.Java:194)org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.Java:755)org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization( AbstractApplicationContext.Java:757)org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.Java:480)org.springframework.web.servlet.FrameworkServlet.configureAndRefreshWebApplicationContext(FrameworkServlet.Java:663)org.springframework.web.servlet。 FrameworkServlet.createWebApplicationContext(FrameworkServlet.Java:629)org.springframework.web.servlet.FrameworkServlet.createWebApplicationContext(FrameworkServlet.Java:677)org.springframework.web.servlet.FrameworkServlet.initWebApplicationContext(FrameworkServlet.Java:548)org.springframework。 web.servlet.FrameworkServlet.initServletBean(FrameworkServlet.Java:489)org.springframework.web.s ervlet.HttpServletBean.init(HttpServletBean.Java:136)javax.servlet.GenericServlet.init(GenericServlet.Java:160)org.Apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.Java:472)org.Apache.catalina。 valve.ErrorReportValve.invoke(ErrorReportValve.Java:99)org.Apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.Java:936)org.Apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.Java:407)組織。 Apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.Java:1004)org.Apache.coyote.AbstractProtocol $ AbstractConnectionHandler.process(AbstractProtocol.Java:589)org.Apache.Tomcat.util.net.JIoEndpoint $ SocketProcessor.run(run JIoEndpoint.Java:310)Java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.Java:1142)Java.util.concurrent.ThreadPoolExecutor $ Worker.run(ThreadPoolExecutor.Java:617)Java.lang.Thread.run(Thread。 Java:745)
根本的な原因
org.springframework.beans.factory.BeanCreationException:フィールドを自動配線できませんでした:private com.ve.common.service.StockService com.ve.common.controller.StockController.stockService;ネストされた例外はorg.springframework.beans.factory.NoSuchBeanDefinitionException:依存関係のタイプ[com.ve.common.service.StockService]の修飾Beanが見つかりません:この依存関係の自動配線候補として修飾される少なくとも1つのBeanが必要です。依存アノテーション:{@ org.springframework.beans.factory.annotation.Autowired(required = true)} org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor $ AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.Java:561)org.springframework.beans.beans工場。 Java:1210)org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.Java:537)org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.Java:476)org.springframework.bean:s factory.support.AbstractBeanFactory $ 1.getObject(AbstractBeanFac tory.Java:303)org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.Java:230)org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.Java:299)org.springframework。 beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.Java:194)org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.Java:755)org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext(AbstractApplicationContext。 Java:757)org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.Java:480)org.springframework.web.servlet.FrameworkServlet.configureAndRefreshWebApplicationContext(FrameworkServlet.Java:663)org.springframework.web.servlet.FrameworkServlet。 createWebApplicationContext(FrameworkServlet.Java:629)org.springframework.web.servlet.FrameworkServlet.createWebApplicatio nContext(FrameworkServlet.Java:677)org.springframework.web.servlet.FrameworkServlet.initWebApplicationContext(FrameworkServlet.Java:548)org.springframework.web.servlet.FrameworkServlet.initServletBean(FrameworkServlet.Java:489)org.springframework.web。 servlet.HttpServletBean.init(HttpServletBean.Java:136)javax.servlet.GenericServlet.init(GenericServlet.Java:160)org.Apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.Java:472)org.Apache.catalina。 valve.ErrorReportValve.invoke(ErrorReportValve.Java:99)org.Apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.Java:936)org.Apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.Java:407)組織。 Apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.Java:1004)org.Apache.coyote.AbstractProtocol $ AbstractConnectionHandler.process(AbstractProtocol.Java:589)org.Apache.Tomcat.util.net.JIoEndpoint $ SocketProcessor.run(run JIoEndpoint.Java:310)Java.util.concurrent.ThreadPoolExecutor.runWorker (ThreadPoolExecutor.Java:1142)Java.util.concurrent.ThreadPoolExecutor $ Worker.run(ThreadPoolExecutor.Java:617)Java.lang.Thread.run(Thread.Java:745)
根本的な原因
org.springframework.beans.factory.NoSuchBeanDefinitionException:依存関係のタイプ[com.ve.common.service.StockService]の修飾Beanが見つかりません:この依存関係の自動配線候補として修飾される少なくとも1つのBeanが必要です。依存関係アノテーション:{@ org.springframework.beans.factory.annotation.Autowired(required = true)} org.springframework.beans.factory.support.DefaultListableBeanFactory.raiseNoSuchBeanDefinitionException(DefaultListableBeanFactory.Java:1301)org.springframework.beans.factory。サポートJava:533)org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.Java:88)org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessPropertyValues(AutowiredAnnotationBeanPostProcessor.Java:331)org.springframework.bean:beans factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAu towireCapableBeanFactory.Java:1210)org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.Java:537)org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.Java:spring.org:springwork.org:spring.org) beans.factory.support.AbstractBeanFactory $ 1.getObject(AbstractBeanFactory.Java:303)org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.Java:230)org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean (AbstractBeanFactory.Java:299)org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.Java:194)org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.Java:755)org.springframework .context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.Java:757)組織springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.Java:480)org.springframework.web.servlet.FrameworkServlet.configureAndRefreshWebApplicationContext(FrameworkServlet.Java:663)org.springframework.web.servlet.FrameworkServlet.createWebApplicationContext(FrameworkServlet.Java: 629)org.springframework.web.servlet.FrameworkServlet.createWebApplicationContext(FrameworkServlet.Java:677)org.springframework.web.servlet.FrameworkServlet.initWebApplicationContext(FrameworkServlet.Java:548)org.springframework.web.servlet.FrameworkServlet.initServletBean( FrameworkServlet.Java:489)org.springframework.web.servlet.HttpServletBean.init(HttpServletBean.Java:136)javax.servlet.GenericServlet.init(GenericServlet.Java:160)org.Apache.catalina.authenticator.AuthenticatorBase.invoke( AuthenticatorBase.Java:472)org.Apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.Java:99)org.Apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.Java:936)o rg.Apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.Java:407)org.Apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.Java:1004)org.Apache.coyote.AbstractProtocol $ AbstractConnectionProtocol Java:589)org.Apache.Tomcat.util.net.JIoEndpoint $ SocketProcessor.run(JIoEndpoint.Java:310)Java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.Java:1142)Java.util.concurrent.ThreadPoolExecutor $ Worker.run(ThreadPoolExecutor.Java:617)Java.lang.Thread.run(Thread.Java:745)
コードの過剰なブロックとブロッククォートをおaびしますが、提供する情報が多ければ多いほど、より良い助けが得られると思います。そして、私に手を差し伸べることができる人に感謝します。
org.springframework.beans.factory。NoSuchBeanDefinitionException:タイプ[com.ve.common.service。StockService]
エラー自体は、SpringContainerはnameStockService
のBeanを見つけられないと言っています。そのため、applicationContext.xml
ファイルにBeanを作成するか、または @Bean
アノテーションでBeanを宣言します。
@ Autowired :この注釈により、applicationContext.xml
でBeanを明示的に宣言しないようにすることができます。ただし、 @Bean
注釈を使用して自動配線するクラスのBeanを作成し、XML
に<context:conponent-scan>
を追加して、Beanが @Bean
注釈。
Beanの宣言:Beanを宣言するには、次のように @Bean
アノテーションでメソッドに注釈を付けます。
@Configuration
public class AppConfig {
@Bean
public StockService stockService() {
return new StockServiceImpl();
}
}
これは、applicationContext.xml
でBeanを宣言することと同じです。
<beans>
<bean name="stockService" class="com.ve.common.service.StockServiceImpl"/>
</beans>
[〜#〜]または[〜#〜]
Beanクラスで @Autowired
アノテーションを使用する場合は、最初に以下の構成を使用して、春にアノテーションを有効にする必要があります。
<context:annotation-config />
または
<bean class ="org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor"/>
詳細:
これがお役に立てば幸いです。
問題はweb.xmlにあります。 contextconfiglocationを次のように変更してください
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>
WEB-INF/application-context.xml
WEB-INF/persistence-context.xml
</param-value>
</context-param>
classpath*:WEB-INF/application-context.xml
。WEB-INF /を使用しました。パスがクラスパスにない(WEB-INF/classesのみ)コンテキストローダーは2つのコンテキストファイルを見つけることができません。