weblogic 下自定义标签<tag>错误
?
?
keywords weblogic?? Tag??? BodyTag?? BodyTag.EVAL_BODY_BUFFERED
?
问题描述? 在weblogic下部署工程时报以下错误 但在Tomcat下不会报错
?
javax.servlet.jsp.JspTagException: Since tag class com.szkd.tags.ListOne does not implement BodyTag, it cannot return BodyTag.EVAL_BODY_BUFFERED
??? at jsp_servlet._page._kd._dict.__dict._jsp__tag4(__dict.java:454)
??? at jsp_servlet._page._kd._dict.__dict._jspService(__dict.java:251)
??? at weblogic.servlet.jsp.JspBase.service(JspBase.java:34)
??? at weblogic.servlet.internal.StubSecurityHelper$ServletServiceAction.run(StubSecurityHelper.java:226)
??? at weblogic.servlet.internal.StubSecurityHelper.invokeServlet(StubSecurityHelper.java:124)
??? at weblogic.servlet.internal.ServletStubImpl.execute(ServletStubImpl.java:283)
??? at weblogic.servlet.internal.ServletStubImpl.onAddToMapException(ServletStubImpl.java:391)
??? at weblogic.servlet.internal.ServletStubImpl.execute(ServletStubImpl.java:309)
??? at weblogic.servlet.internal.TailFilter.doFilter(TailFilter.java:26)
??? at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:42)
??? at com.szkd.filter.UserSessionFilter.doFilter(UserSessionFilter.java:134)
??? at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:42)
??? at com.szkd.filter.UserSessionFilter.doFilter(UserSessionFilter.java:134)
??? at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:42)
??? at com.szkd.filter.ResponseHeaderFilter.doFilter(ResponseHeaderFilter.java:36)
??? at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:42)
??? at com.szkd.filter.CharsetFilter.doFilter(CharsetFilter.java:31)
??? at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:42)
??? at weblogic.servlet.internal.WebAppServletContext$ServletInvocationAction.run(WebAppServletContext.java:3368)
??? at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:321)
??? at weblogic.security.service.SecurityManager.runAs(Unknown Source)
??? at weblogic.servlet.internal.WebAppServletContext.securedExecute(WebAppServletContext.java:2117)
??? at weblogic.servlet.internal.WebAppServletContext.execute(WebAppServletContext.java:2023)
??? at weblogic.servlet.internal.ServletRequestImpl.run(ServletRequestImpl.java:1359)
??? at weblogic.work.ExecuteThread.execute(ExecuteThread.java:200)
??? at weblogic.work.ExecuteThread.run(ExecuteThread.java:172)
?
后来发现是我的自定义标签中的doStartTag()方法的返回值写错了
?
public int doStartTag() throws JspException { MyResult rs = (MyResult )pageContext.getAttribute(this.name); if (rs == null) { throw new JspTagException("XXX"); } List listResult = (List)rs.getResult(); if (listResult == null) { return SKIP_BODY; } itList = listResult.iterator(); if (itList.hasNext()) { pageContext.setAttribute(var,itList.next()); pageContext.setAttribute(next, new Integer(nRow)); nRow++; return EVAL_BODY_AGAIN; //这一句返回值错了 原来返回的是 EVAL_BODY_AGAIN //但不知为什么在tomcat中不会报错 } else { return SKIP_BODY; } }?
下面部分是从网上搜到的? 转自 http://hi.baidu.com/yuweiming/blog/item/48bb6c2219d0c1a34723e82b.html
载BodyTagSupport类的方法:
他们执行顺序如下:
doStartTag()→doInitBody()→setBodyContent()→doAfterBody()→doEndTag()
doStartTag()方法可返回EVAL_BODY_INCLUDE或SKIP_BODY,
如果返回EVAL_BODY_INCLUDE则继续执行;
如果返回SKIP_BODY则接下来的doInitBody(),setBodyContent(), doAfterBody()三个方法不会被执行,
而直接执行doEndTag()方法。
setBodyContent()方法用于设置标签体内容,如果在此之前要作一些初始化工作,则在doInitBody()方法中完成。
标签体内容执行完后,会调用doAfterBody()方法,此方法可返回EVAL_BODY_TAG, SKIP_BODY,
EVAL_PAGE或SKIP_PAGE。
如果返回EVAL_BODY_TAG则会再次设置标签体内容,直到返回SKIP_BODY;
如果返回EVAL_PAGE则标签体执行完后会继续执行JSP页面中接下来的部分;
如果返回SKIP_PAGE,则JSP页面的后续内容将不再执行。
?
标签中静态常量:
EVAL_BODY_INCLUDE:告诉服务器正文的内容,并把这些内容送入输出流
SKIP_BODY:告诉服务器不要处理正文内容
EVAL_PAGE:让服务器继续执行页面
SKIP_PAGE:让服务器不要处理剩余的页面
EVAL_BODY_AGAIN:让服务器继续处理正文内容,只有doAfterBody方法可以返回
EVAL_BODY_BUFFERED:BodyTag接口的字段,在doStartTag()返回
EVAL_BODY_INCLUDE、SKIP_BODY一般由doStartTag()返回,而EVAL_PAPGE、SKIP_PAGE由doEndTag()返回。
?