今天在帮公司的新手弄SSH的一个登录程序时,出现了Servlet action is not available异常,第一反应应该是struts配置的问题,找了段时间发现配置没错,搜索了下,找了几篇好文,问题成功解决,原来是那个大头虾将spring的配置文件中hibernate的model文件路径写错了,这种问题还真难找,我眼睛睁得圆圆的,找了N久才找到。
共享下网上资料:
1.
http://community.csdn.net/Expert/TopicView3.asp?id=4927147 原文如下:
最近在做开发用STRUTS+SPRING+HIBERNATE
遇到一个很棘手的错误:Servlet action is not available
具体症状如下:
文件夹系统:
com.Athena.data.hibernate 存放HIBERNATE的工厂类
com.Athena.data.po.imp 存放持久化对象
com.Athena.data.dao.imp 存放数据访问对象
com.Athena.data.bo.imp 存放业务逻辑处理BEAN
com.Athena.service 存放功能总接口类
com.Athena.action 存放ACTION
com.Athena.form 存放FORM
com.Athena.prop 存放信息文件properties
开发工具ECLIPSE 3.1.1
由于开发中用的是MYECLIPSE4.1 所以生成数据表的影射文件的时候没有被放到指定的包中,全部被工具自动放到了缺省包中
被放到缺省包中的文件:(影射的表为user_first)
AbstractUser_First.java
User_First.java
User_FirstDAO.java
User_First.hbm.xml
此时,各个配置文件的关键代码是:
applicationContext.xml:
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref bean="mssqldata" />
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">
org.hibernate.dialect.SQLServerDialect
</prop>
</props>
</property>
<property name="mappingResources">
<list>
<value>User_First.hbm.xml</value>
</list>
</property>
</bean>
<bean id="User_FirstDAO" class="User_FirstDAO">
<property name="sessionFactory">
<ref bean="sessionFactory" />
</property>
</bean>
struts-config.xml:
<action-mappings >
<action
attribute="loginForm"
input="/login.jsp"
name="loginForm"
path="/login"
scope="request"
type="org.springframework.web.struts.DelegatingActionProxy" />
</action-mappings>
在STRUTS中我写了一个登陆,包括loginForm.java , loginAction.java ,login.jsp
登陆的逻辑是:输入用户名和密码都为“HAHA”的时候 在页面上返回登陆成功字样,否则则返回登陆失败(为了测试,所以ACTION中没有涉及任何访问数据的东西,仅仅是在其中通过SPRING的注入机制,向里面注入了一个字符串,并在控制台打出)
loginAction关键源码:
private String sm;
public ActionForward execute(
ActionMapping mapping,
ActionForm form,
HttpServletRequest request,
HttpServletResponse response) {
LoginForm loginForm = (LoginForm) form;
String username=loginForm.getUsername();
String userpass=loginForm.getUserpass();
if(username.equals("haha")&&(userpass.equals("haha"))){
ActionMessages meg=new ActionMessages();
meg.add("userlogout",new ActionMessage("user.logon"));
saveErrors(request,meg);
System.out.println(username+" "+userpass+" "+sm);
return mapping.findForward("logout");
}else{
ActionMessages meg=new ActionMessages();
meg.add("userlogon",new ActionMessage("user.logout"));
saveErrors(request,meg);
System.out.println(username+" "+userpass+" ");
return mapping.findForward("logout");
}
}
public String getSm() {
return sm;
}
public void setSm(String sm) {
this.sm = sm;
}
在applicationContext.xml中的注入代码:
<bean name="/login" class="com.Athena.action.LoginAction" singleton="false">
<property name="sm">
<value>dadadada</value>
</property>
</bean>
---------------------------------------------------------------------------------
以上是没有任何问题,网页运行正常,但是当我把被工具自动放到缺省包的那些文件转移到相应包之后,我修改了如下东西(以下是修改的):
applicationContext.xml:
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref bean="mssqldata" />
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">
org.hibernate.dialect.SQLServerDialect</prop>
</props>
</property>
<property name="mappingResources">
<list>
<value>com/Athena/data/po/imp/User_First.hbm.xml</value> //在此我添加了路径
</list>
</property>
</bean>
<bean id="User_FirstDAO" class="com.Athena.data.dao.imp.User_FirstDAO">
//在此我添加了路径
<property name="sessionFactory">
<ref bean="sessionFactory" />
</property>
</bean>
User_First.htm.xml 的修改:
<hibernate-mapping package="com.Athena.data.po.imp">
<class name="com.Athena.data.po.imp.User_First" table="AthenaCompany" >
被自动放到缺省包的文件的路径变更:
AbstractUser_First.java com.Athena.data.po
User_First.java com.Athena.data.po.imp
User_FirstDAO.java com.Athena.data.dao.imp
User_First.hbm.xml com.Athena.data.po.imp
------------------------------------------------------------------------------
做了以上修改后(以上各个配置文件的路径修改都是我仔细检查过的,只不过现在有点眼花了,所以如果写错了,请不用给予纠正,那可能是我打错了),再次启动网页,登陆界面正常出,一点提交,就会返回错误:Servlet action is not available
疑问:
ACTION中没有涉及任何的数据访问和业务逻辑,仅仅是简单的判断,为什么移动了几个不相关的文件就说是找不到ACTION了呢? (网络上也有很多答案,结果还是一无所获)
如果哪位大侠可以赐教,请加我的MSN:Mars.Eric@hotmail.com
在此拜托了,处理了3天了,快死了。
|
回复人:Eric_Mars() ( ) 信誉:100 |
2006-8-4 17:10:50 |
得分:0 |
|
|
? |
问题解决了 解决方法: 在SPRING的配置文件中生命.HBM.XML文件的时候一定要注意: 例如路径为:com.hibernate.xxx.hbm.xml 那么声明的时候应该写成 /com/hibernate/xxx.hbm.xml
同时记得改好xxx.hbm.xml内部的路径配置
|
|
2. Servlet action is not available 问题解决 原文出处
:http://blog.csdn.net/lijiuu/archive/2007/03/22/1538069.aspx 文章如下:
环境eclipse3.2+myeclipse+tomcat5.0x
重要提示:出现这个问题的原因很多,最多见的是配置文件出错不能初始化出现Servlet action is not available提示。要解决问题需要具体问题具体分析,多看容器的logs。
背景提示,我要做struts+spring+hibernate的配置,但是按照书上说的配置好了后,总是错误,提示Servlet action is not available后台log就提示2006-03-22 22:34:09 StandardWrapperValve[action]: Servlet action is currently unavailable。弄了很久没有弄好。后来看了很久的log才发现提示配置文件中有错误,所以把action设置为null。
在找这个错误,找了很久才发现:一个是
<plug-in
className="org.springframework.web.struts.ContextLoaderPlugIn">
<set-property property="contextConfigLocation"
value="/WEB-INF/classes/applicationContext.xml" />
</plug-in>
在struts中配置spring插件时,applicationContext.xml(spring的配置文件)位置错了,书上一般是"/WEB-INF/applicationContext.xml" 但是有的时候不是在这个下面。所以一定要自己到容器下看看具体位置。比如我的就是在web-inf/classes下。
二是:在spring的配置文件下的插入hibernate的配置文件
<bean id="SessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="configLocation">
<value>file:src/hibernate.cfg.xml</value>
</property>
</bean>
myeclipse自动添加的是这样的,我一直没有注意,结果应该为:
<bean id="SessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="configLocation">
<value>file:src/hibernate.cfg.xml</value>
</property>
</bean>
提示:hibernate.cfg.xml文件的具体位置你要到容器下去看。
重要提示:
1、还有就是一定要在struts配置文件中加: <controller processorClass="org.springframework.web.struts.DelegatingRequestProcessor"/>。这样你的action才能真的委托给spring。
2、我发现我的myeclipse没有把spring.jar拷贝到lib下,以后大家出了问题可以看看。
利用spring+hibernate+struts过程中,发现一个问题,在action中将一个hibernate读取出来的ArrayList存入session:request.getSession().setAttribute("treeFromRoot", treeList.iterator());
在jsp中用标签 读取代码如下:会出现Cannot create iterator for this collection 错误,弄了一下午都没有搞定。
<logic:notEmpty name="treeFromRoot">
<logic:iterate type="edu.scnu.es.struts.vo.Tree" id="tree"
name="treeFromRoot">
</logic:iterate>
</logic:notEmpty>
最后决定用JSTL试一试,代码改为:成功了。
<c:forEach items="${sessionScope.treeFromRoot}" var="treeFromRoot1">
${treeFromRoot1.id };
</c:forEach>
其中:edu.scnu.es.struts.vo.Tree是treeFromRoot这个list的成员的原形类。
posted on 2007-04-27 17:05
阿蜜果 阅读(20443)
评论(5) 编辑 收藏 所属分类:
Spring