论坛首页 Java企业应用论坛

spring入门编程问题集锦

浏览 76812 次
该帖已经被评为精华帖
作者 正文
   发表时间:2005-01-17  
http://blog.csdn.net/yzhz/archive/2005/01/17/springqa.aspx

我写的一篇文章,希望对spring初学者有所帮助:

1、如何学习Spring?
你可以通过下列途径学习spring:
(1) spring下载包中doc目录下的MVC-step-by-step和sample目录下的例子都是比较好的spring开发的例子。

(2) AppFuse集成了目前最流行的几个开源轻量级框架或者工具Ant,XDoclet,Spring,Hibernate(iBATIS),JUnit,Cactus,StrutsTestCase,Canoo's WebTest,Struts Menu,Display Tag Library,OSCache,JSTL,Struts 。
你可以通过AppFuse源代码来学习spring。
AppFuse网站:http://raibledesigns.com/wiki/Wiki.jsp?page=AppFuse

(3)Spring 开发指南(夏昕)(http://www.xiaxin.net/Spring_Dev_Guide.rar)
一本spring的入门书籍,里面介绍了反转控制和依赖注射的概念,以及spring的bean管理,spring的MVC,spring和hibernte,iBatis的结合。

(4) spring学习的中文论坛
SpringFramework中文论坛(http://spring.jactiongroup.net)
Java视线论坛(http://forum.iteye.com)的spring栏目

2、利用Spring框架编程,console打印出log4j:WARN Please initialize the log4j system properly?
说明你的log4j.properties没有配置。请把log4j.properties放到工程的classpath中,eclipse的classpath为bin目录,由于编译后src目录下的文件会拷贝到bin目录下,所以你可以把log4j.properties放到src目录下。
这里给出一个log4j.properties的例子:

log4j.rootLogger=DEBUG,stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d %5p (%F:%L) - %m%n


3、出现 java.lang.NoClassDefFoundError?
一般情况下是由于你没有把必要的jar包放到lib中。

比如你要采用spring和hibernate(带事务支持的话),你除了spring.jar外还需要hibernat.jar、aopalliance.jar、cglig.jar、jakarta-commons下的几个jar包。

http://www.springframework.org/download.html下载spring开发包,提供两种zip包
spring-framework-1.1.3-with-dependencies.zip和spring-framework-1.1.3.zip,我建议你下载spring-framework-1.1.3-with-dependencies.zip。这个zip解压缩后比后者多一个lib目录,其中有hibernate、j2ee、dom4j、aopalliance、jakarta-commons等常用包。


4、java.io.FileNotFoundException: Could not open class path resource [....hbm.xml],提示找不到xml文件?
原因一般有两个:
(1)该xml文件没有在classpath中。
(2)applicationContext-hibernate.xml中的xml名字没有带包名。比如:
<bean id="sessionFactory" class="org.springframework.orm.hibernate.LocalSessionFactoryBean">
        <property name="dataSource"><ref bean="dataSource"/></property>
        <property name="mappingResources">
            <list>
                <value>User.hbm.xml</value>         错,改为: <value>com/yz/spring/domain/User.hbm.xml</value>
            </list>
        </property>
        <property name="hibernateProperties">
         <props>
         <prop key="hibernate.dialect"> net.sf.hibernate.dialect.MySQLDialect </prop>
         <prop key="hibernate.show_sql">true</prop>
        </props>
        </property>
</bean>


5、org.springframework.beans.NotWritablePropertyException: Invalid property 'postDao' of bean class?
出现异常的原因是在application-xxx.xml中property name的错误。
<property name="...."> 中name的名字是与bean的set方法相关的,而且要注意大小写。
比如
public class PostManageImpl extends BaseManage implements PostManage {
    private PostDAO dao = null;
    public void setPostDAO(PostDAO postDAO){
        this.dao = postDAO;
    }
}
那么xml的定义应该是:
<bean id="postManage" parent="txProxyTemplate">
        <property name="target">
            <bean class="com.yz.spring.service.implement.PostManageImpl">
                <property name="postDAO"><ref bean="postDAO"/></property>    对
                <property name="dao"><ref bean="postDAO"/></property>             错
            </bean>
        </property>
</bean>


6、Spring中如何实现事务管理?
        首先,如果使用mysql,确定mysql为InnoDB类型。
        事务管理的控制应该放到商业逻辑层。你可以写个处理商业逻辑的JavaBean,在该JavaBean中调用DAO,然后把该Bean的方法纳入spring的事务管理。

比如:xml文件定义如下:
<bean id="txProxyTemplate" abstract="true"
        class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
        <property name="transactionManager"><ref bean="transactionManager"/></property>
        <property name="transactionAttributes">
            <props>
                <prop key="save*">PROPAGATION_REQUIRED</prop>
                <prop key="remove*">PROPAGATION_REQUIRED</prop>
                <prop key="*">PROPAGATION_REQUIRED</prop>
            </props>
        </property>
</bean>

<bean id="userManage" parent="txProxyTemplate">
      <property name="target">
          <bean class="com.yz.spring.service.implement.UserManageImpl">
              <property name="userDAO"><ref bean="userDAO"/></property>
          </bean>
      </property>
</bean>

com.yz.spring.service.implement.UserManageImpl就是我们的实现商业逻辑的JavaBean。我们通过parent元素声明其事务支持。


7、如何管理Spring框架下更多的JavaBean?
        JavaBean越多,spring配置文件就越大,这样不易维护。为了使配置清晰,我们可以将JavaBean分类管理,放在不同的配置文件中。 应用启动时将所有的xml同时加载。
比如:
        DAO层的JavaBean放到applicationContext-hibernate.xml中,商业逻辑层的JavaBean放到applicationContext-service.xml中。然后启动类中调用以下代码载入所有的ApplicationContext。

String[] paths = {"com/yz/spring/dao/hibernate/applicationContext-hibernate.xml",
                          "com/yz/spring/service/applicationContext-service.xml"};
ctx = new ClassPathXmlApplicationContext(paths);


8、web应用中如何加载ApplicationContext?
可以通过定义web.xml,由web容器自动加载。

<servlet>
  <servlet-name>context</servlet-name>
  <servlet-class>org.springframework.web.context.ContextLoaderServlet</servlet-class>
  <load-on-startup>1</load-on-startup>
</servlet>

<context-param>
  <param-name>contextConfigLocation</param-name>
  <param-value>/WEB-INF/applicationContext-hibernate.xml</param-value>
  <param-value>/WEB-INF/applicationContext-service.xml</param-value>
</context-param>

9、在spring中如何配置的log4j?
在web.xml中加入以下代码即可。
<context-param>
  <param-name>log4jConfigLocation</param-name>
  <param-value>/WEB-INF/log4j.properties</param-value>
</context-param>


10、Spring框架入门的编程问题解决了,我该如何更深地领会Spring框架呢?
这两本书你该去看看。这两本书是由Spring的作者Rod Johnson编写的。
Expert One on one J2EE Design and Development
Expert One on one J2EE Development Without EJB
你也该看看martinfowler的Inversion of Control Containers and the Dependency Injection pattern。
http://www.martinfowler.com/articles/injection.html

再好好研读一下spring的文档。
http://www.jactiongroup.net/reference/html/index.html(中文版,未全部翻译)

还有就是多实践吧。
   发表时间:2005-02-16  
如何在weblogic8中配置dataAccessContext-jta.xml中dataSource的jndiName

在配置spring自带的例子jpetstore的JTA方式时,不知道如何在weblogic8i中配置
<bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean">
<property name="jndiName"><value>java:comp/env/jdbc/jpetstore</value></property>
</bean>


java:comp/env/jdbc/jpetstore

在登陆weblogic8i的admin后,在mydomain/services/jdbc/下有4个节点(connection pools, multipools, data sources, data source factories)那么在这个应用中我应该在哪个节点下配置呢,如何配置,谢谢!

另外这个地方的datasource是否就是一般在weblogic中配置的connection pools + data sources里面的jndi Name?
0 请登录后投票
   发表时间:2005-02-17  
引用
再好好研读一下spring的文档。
http://www.jactiongroup.net/reference/html/index.html(中文版,未全部翻译)

这个怎么总是404notfound啊?
0 请登录后投票
   发表时间:2005-02-22  
z_jordon 写道
引用
再好好研读一下spring的文档。
http://www.jactiongroup.net/reference/html/index.html(中文版,未全部翻译)

这个怎么总是404notfound啊?


http://www.jactiongroup.net/reference/html/index.html

原来的把(中文版,未全部翻译)也放到url中去了
0 请登录后投票
   发表时间:2005-03-24  
引用
9、在spring中如何配置的log4j?
在web.xml中加入以下代码即可。
&lt;context-param&gt;
&lt;param-name&gt;log4jConfigLocation&lt;/param-name&gt;
&lt;param-value&gt;/WEB-INF/log4j.properties&lt;/param-value&gt;
&lt;/context-param&gt;


为什么我配置log4j的时候和你的不一样 ? 也能正常使用  ?

引用
  &lt;servlet&gt;
    &lt;description&gt;This is the description of my J2EE component&lt;/description&gt;
    &lt;display-name&gt;This is the display name of my J2EE component&lt;/display-name&gt;
    &lt;servlet-name&gt;Log4JInit&lt;/servlet-name&gt;
    &lt;servlet-class&gt;org.common.util.Log4JInit&lt;/servlet-class&gt;
    &lt;init-param&gt;
       &lt;param-name&gt; log4j-config-file &lt;/param-name&gt;
       &lt;param-value&gt;WEB-INF\classes\org\common\util\log4j.properties&lt;/param-value&gt;
    &lt;/init-param&gt;
    &lt;load-on-startup&gt;2&lt;/load-on-startup&gt;
  &lt;/servlet&gt;

  &lt;servlet-mapping&gt;
    &lt;servlet-name&gt;Log4JInit&lt;/servlet-name&gt;
    &lt;url-pattern&gt;/servlet/Log4JInit&lt;/url-pattern&gt;
  &lt;/servlet-mapping&gt;
0 请登录后投票
   发表时间:2006-04-09  
学习夏昕的SpringGuide.pdf发现的问题,如是我个人理解问题请大家指正:
1、第33页最后一行:应该是successView
2、第36页,第3个小注的位置,对应上面的问题,要返回的应该是:getSuccessView()
3、第36页,第1个小注,类的参数有问题,应该是:protected ModelAndView onSubmit(Object cmd),BindException ex不需要
4、不能算是问题:记得在web-inf/lib下面除要放入spring.jar、log4j.jar、commons-logging.jar外,还需要两个JAR:jstl.jar、standard.jar
5、第70页:&lt;form action="/login.action"&gt; 应该是:&lt;form action="login.action"&gt;

呵呵,这个文档在我学习的时候起了很大的作用,上面的几个问题导致我用了一整天才调试好这段范例,但解决后印象特别深刻。
0 请登录后投票
   发表时间:2006-04-09  
我根据夏昕那个教程(56页)学习时遇到这个问题(发现很多人遇到这个问题,但找不到回复,估计是水平到了一定程度会自己找到问题所在的):
在JSP中加入&lt;spring:bind&gt;就会出现:“no ContextLoaderListener registered”的错误,根据文档应在web.xml里加入&lt;listener&gt;,可是加入&lt;listener&gt;后:
listerner要求有xml文件是默认的,Dispatcher也需要一个xml文件,我把两个xml设为同一个(applicationContext.xml),然后会出现:“Neither Errors instance nor plain target object for bean name 'command' available as request attribute” 的错误。
不知各位在学习时有没有遇到,还请多多指教。
0 请登录后投票
   发表时间:2006-04-09  
JSP文件:
&lt;%@ taglib prefix="c" uri="http://java.sun.com/jstl/core_rt"%&gt;
&lt;%@ taglib prefix="spring" uri="WEB-INF/spring.tld"%&gt;
&lt;%@ page language="java" contentType="text/html; charset=gb2312"
pageEncoding="gb2312"%&gt;
&lt;!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"&gt;
&lt;html&gt;
&lt;head&gt;
&lt;title&gt;用户注册&lt;/title&gt;
&lt;/head&gt;
&lt;body style="text-align: center"&gt;
&lt;form method="POST" action="/register.do"&gt;&lt;spring:bind path="command.*"&gt;
&lt;font color="#FF0000"&gt; &lt;c:forEach items="${status.errorMessages}"
var="error"&gt;
错误:&lt;c:out value="${error}" /&gt;
&lt;br&gt;
&lt;/c:forEach&gt; &lt;/font&gt;
&lt;/spring:bind&gt;
&lt;table border="0" width="450" height="101" cellspacing="0"
cellpadding="0"&gt;
&lt;tr&gt;
&lt;td height="27" width="408" colspan="2"&gt;
&lt;p align="center"&gt;&lt;b&gt;用户注册&lt;/b&gt;
&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td height="23" width="104"&gt;用户名:&lt;/td&gt;
&lt;td height="23" width="450"&gt;&lt;spring:bind path="command.username"&gt;
&lt;input type="text" value="&lt;c:out value="${status.value}"/&gt;"
name="&lt;c:out value="${status.expression}"/&gt;"&gt;
必须大于四个字符
&lt;br&gt;
&lt;c:if test="${status.error}"&gt;
&lt;font color="#FF0000"&gt;错误&lt;c:forEach
items="${status.errorMessages}" var="error"&gt;
&lt;c:out value="${error}" /&gt;
&lt;/c:forEach&gt; &lt;/font&gt;
&lt;/c:if&gt;
&lt;/spring:bind&gt;&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td height="23" width="104"&gt;密码:&lt;/td&gt;
&lt;td height="23" width="450"&gt;&lt;spring:bind path="command.password1"&gt;
&lt;input type="password" value="&lt;c:out value="${status.value}"/&gt;"
name="&lt;c:out value="${status.expression}"/&gt;"&gt;
必须大于6个字符
&lt;br&gt;
&lt;c:if test="${status.error}"&gt;
&lt;font color="#FF0000"&gt;错误:&lt;c:forEach
items="${status.errorMessages}" var="error"&gt;
&lt;c:out value="${error}" /&gt;
&lt;/c:forEach&gt; &lt;/font&gt;
&lt;/c:if&gt;
&lt;/spring:bind&gt;&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td height="23" width="104"&gt;重复密码:&lt;/td&gt;
&lt;td height="23" width="450"&gt;&lt;spring:bind path="command.password2"&gt;
&lt;input type="password" value="&lt;c:out value="${status.value}"/&gt;"
name="&lt;c:out value="${status.expression}"/&gt;"&gt;
&lt;br&gt;
&lt;c:if test="${status.error}"&gt;
&lt;font color="#FF0000"&gt;错误:&lt;c:forEach
items="${status.errorMessages}" var="error"&gt;
&lt;c:out value="${error}" /&gt;
&lt;/c:forEach&gt; &lt;/font&gt;
&lt;/c:if&gt;
&lt;/spring:bind&gt;&lt;/td&gt;
&lt;/tr&gt;
&lt;/table&gt;
&lt;p&gt;&lt;input type="submit" value="提交" name="B1"&gt; &lt;input type="reset"
value="重置" name="B2"&gt;&lt;/p&gt;
&lt;/form&gt;
&lt;/body&gt;
&lt;/html&gt;
0 请登录后投票
   发表时间:2006-04-09  
web.xml

&lt;?xml version="1.0" encoding="UTF-8"?&gt;
&lt;web-app xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
version="2.4"&gt;

&lt;!-- &lt;listener&gt;
&lt;listener-class&gt; org.springframework.web.context.ContextLoaderListener
&lt;/listener-class&gt;
&lt;/listener&gt;--&gt;
&lt;servlet&gt;
&lt;servlet-name&gt;Dispatcher&lt;/servlet-name&gt;
&lt;servlet-class&gt; org.springframework.web.servlet.DispatcherServlet
&lt;/servlet-class&gt;
&lt;init-param&gt;
&lt;param-name&gt;contextConfigLocation&lt;/param-name&gt;
&lt;param-value&gt;/WEB-INF/config.xml&lt;/param-value&gt;
&lt;/init-param&gt;
&lt;/servlet&gt;

&lt;servlet&gt;
&lt;servlet-name&gt;Test&lt;/servlet-name&gt;
&lt;servlet-class&gt; com.eastviking.l1.Test &lt;/servlet-class&gt;
&lt;/servlet&gt;
&lt;servlet&gt;
&lt;servlet-name&gt;Test1&lt;/servlet-name&gt;
&lt;servlet-class&gt; com.eastviking.l1.Test1 &lt;/servlet-class&gt;
&lt;/servlet&gt;
&lt;servlet-mapping&gt;
&lt;servlet-name&gt;Test&lt;/servlet-name&gt;
&lt;url-pattern&gt;/Test&lt;/url-pattern&gt;
&lt;/servlet-mapping&gt;

&lt;servlet-mapping&gt;
&lt;servlet-name&gt;Dispatcher&lt;/servlet-name&gt;
&lt;url-pattern&gt;*.do&lt;/url-pattern&gt;
&lt;/servlet-mapping&gt;
&lt;!-- &lt;taglib&gt;
&lt;taglib-uri&gt;/spring&lt;/taglib-uri&gt;
&lt;taglib-location&gt;/WEB-INF/spring.tld&lt;/taglib-location&gt;
&lt;/taglib&gt;--&gt;

&lt;/web-app&gt;
0 请登录后投票
   发表时间:2006-04-09  
config.xml
&lt;?xml version="1.0" encoding="UTF-8"?&gt;
&lt;!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN"
"http://www.springframework.org/dtd/spring-beans.dtd"&gt;
&lt;beans&gt;
&lt;!--Definition of View Resolver --&gt;
&lt;bean id="viewResolver"
class="org.springframework.web.servlet.view.InternalResourceViewResolver"&gt;
&lt;property name="viewClass"&gt;
&lt;value&gt; org.springframework.web.servlet.view.JstlView &lt;/value&gt;
&lt;/property&gt;
&lt;property name="prefix"&gt;
&lt;value&gt;WEB-INF/view/&lt;/value&gt;
&lt;/property&gt;
&lt;property name="suffix"&gt;
&lt;value&gt;.jsp&lt;/value&gt;
&lt;/property&gt;
&lt;/bean&gt;
&lt;!---Action Definition--&gt;

&lt;bean id="LoginAction" class="com.eastviking.l1.LoginAction"&gt;
&lt;property name="commandClass"&gt;
&lt;value&gt;com.eastviking.l1.LoginInfo&lt;/value&gt;
&lt;/property&gt;
&lt;property name="fail_view"&gt;
&lt;value&gt;loginfail&lt;/value&gt;
&lt;/property&gt;
&lt;property name="successView"&gt;
&lt;value&gt;main&lt;/value&gt;
&lt;/property&gt;
&lt;/bean&gt;
&lt;bean id="RegisterValidator" class="com.eastviking.l1.RegisterValidator"/&gt;
&lt;bean id="RegisterAction" class="com.eastviking.l1.RegisterAction"&gt;
&lt;property name="commandClass"&gt;
&lt;value&gt;com.eastviking.l1.RegisterInfo&lt;/value&gt;
&lt;/property&gt;
&lt;property name="validator"&gt;
&lt;ref local="RegisterValidator"/&gt;
&lt;/property&gt;
&lt;property name="formView"&gt;
&lt;value&gt;register&lt;/value&gt;
&lt;/property&gt;
&lt;property name="successView"&gt;
&lt;value&gt;RegisterSuccess&lt;/value&gt;
&lt;/property&gt;
&lt;/bean&gt;
&lt;!--Request Mapping --&gt;
&lt;bean id="urlMapping"
class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping"&gt;
&lt;property name="mappings"&gt;
&lt;props&gt;
&lt;prop key="/login.do"&gt;LoginAction&lt;/prop&gt;
&lt;prop key="/register.do"&gt;RegisterAction&lt;/prop&gt;
&lt;/props&gt;
&lt;/property&gt;
&lt;/bean&gt;
&lt;/beans&gt;
0 请登录后投票
论坛首页 Java企业应用版

跳转论坛:
Global site tag (gtag.js) - Google Analytics