GAEアプリでSpringBeanを注入する際に問題が発生しました。
サーブレットでは、IOCコンテナによって制御されるプロパティがあります。私のweb.xml:
<?xml version="1.0" encoding="utf-8" standalone="no"?>
<web-app
version="2.5" xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/applicationContext.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<servlet>
<servlet-name>update</servlet-name>
<servlet-class>com.servlet.MyServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>update</servlet-name>
<url-pattern>/update</url-pattern>
</servlet-mapping>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
</welcome-file-list>
</web-app>
およびapplictionContext.xml:
<beans>
<bean class="com.myapp.servlet.MyServlet">
<property name="webServicePort" ref="webServicePort"/>
</bean>
<bean id="webServicePort" class="org.springframework.remoting.jaxws.JaxWsPortProxyFactoryBean" scope="singleton" >
<property name="serviceInterface" value="com.ws.generated.WebServicePortType" />
<property name="wsdlDocumentUrl" value="http://endpoint/doc.wsdl" />
<property name="namespaceUri" value="namespace" />
<property name="serviceName" value="WebService" />
<property name="endpointAddress" value="http://endpoint/soap.php" />
</bean>
</beans>
この場合、コンテックスの作成中に、webServicePort
Beanがサーブレットに注入されました。しかし、最初のリクエストを送信したとき、フィールドはnullでした。
Spring記述子をコンストラクター引数で注入するように変更した場合:
<beans>
<bean class="com.myapp.servlet.MyServlet">
<constructor-arg index="0" ref="webServicePort"/>
</bean>
<bean id="webServicePort" class="org.springframework.remoting.jaxws.JaxWsPortProxyFactoryBean" scope="singleton" >
<property name="serviceInterface" value="com.ws.generated.WebServicePortType" />
<property name="wsdlDocumentUrl" value="http://endpoint/doc.wsdl" />
<property name="namespaceUri" value="namespace" />
<property name="serviceName" value="WebService" />
<property name="endpointAddress" value="http://endpoint/soap.php" />
</bean>
</beans>
Beanは、コンストラクターに注入さMyServet
れて作成されました。webServicePort
しかし、リクエストがサーブレットに送信された後、私は次のようになりました。
[INFO] java.lang.InstantiationException: com.myapp.servlet.MyServlet
[INFO] at java.lang.Class.newInstance0(Class.java:357)
[INFO] at java.lang.Class.newInstance(Class.java:325)
[INFO] at org.mortbay.jetty.servlet.Holder.newInstance(Holder.java:153)
[INFO] at org.mortbay.jetty.servlet.ServletHolder.initServlet(ServletHolder.java:428)
[INFO] at org.mortbay.jetty.servlet.ServletHolder.getServlet(ServletHolder.java:339)
(...)
Servlet
クラスのセッターとコンストラクターの両方にロギングを追加しました。サーバーログにメッセージが1回だけ表示されました。何が起こっているのかはわかりますが、理由はわかりません...
私が間違っているなら、私を訂正してください。アプリケーションコンテキストの取得中に、webServicePort
を作成してに注入しServlet
ます。Servlet
しかし、それに送信する最初のリクエストは、注入されたBeanなしで、の新しいインスタンスを作成することですよね?しかし、なぜ?