<%@ page contentType="text/html; charset=gb2312"%> 在Weblogic环境下调试Turbine Servlet实例
网站公告:   ◆北天JAVA技术网热情为java爱好者服务,本网内容包括JAVA(JSP、servlet、EJB、webservice、j2ee、javabean、应用服务器、JavaScript),数据库(MYSQL、SQL Server、Sybase、Oracle、DB2、数据库综合知识),设计研究(设计模式、Struts、Spring、Hibernate、设计框架、设计综合知识),WEB2.0新技术(主要介绍AJAX),以及各种技术的入门、实例、例子等等,欢迎各位多来坐坐!◆  诚邀各位JAVA爱好者加盟!◆  本网站内容丰富,更新快,保证每周20篇以上!  
加入收藏
设为首页
联系站长
承接项目
  相关资源:网站首页 | 免费培训学院 | 技术论坛 | JAVA聊天室 | 作家专栏 | 开发工具 | 认证考试 | 会员俱乐部
  JAVA技术初学者园地 | jsp与servlet | javascript | Java源代码 | EJB | web service | 应用服务器 | JAVA综合知识
  设计研究设计模式 | 设计框架 | Struts | Spring | Hibernate | 开源项目 | 面向对象设计 | 设计综合知识
  数 据 库MYSQL | SQL Server | Sybase | Oracle | DB2 | Informix | Access | 数据库综合知识
  其他资源:AJAX新技术 | 网站开发 | ERP软件 | OA办公软件 | 商业智能BI | 开发综合知识 | 承接项目 | 项目试用

 
 
在Weblogic环境下调试Turbine Servlet实例
     发布者: 发布时间:2007-11-26
在Weblogic环境下调试Turbine Servlet实例Turbine是Jetspeed1.x使用的Servlet引擎,本文的目的不在于告诉读者如何调试本文中讲述的Bug,而是让大家通过本例的Bug的追踪调试过程,来了解一下Turbine的工作机理。(由于本文讲述的Turbine对Java初学者可能比较陌生,专业性比较强,所以点击率如果很低也是意料之中的事情)一、异常描述我们公司的门户平台产品是基于Jetspeed1.4的,使用Turbine2.2作为Servlet引擎,将产品部署到Weblogic上,启动后打开首页,出现下面的错误:'weblogic.kernel.Default'> <> <> <[ServletContext(id=6718343,name=portal,context-path=/portal)] getRealPath() called with unsafe path: ".".weblogic.utils.io.FilenameEncoder$UnsafeFilenameException: D:\bea\user_projects\domains\webapps\portal\. ends with illegal characterat weblogic.utils.io.FilenameEncoder.getSafeFile(FilenameEncoder.java:210)at weblogic.servlet.internal.WebAppServletContext.getRealPath(WebAppServletContext.java:916)at org.apache.turbine.services.servlet.TurbineServletService.getRealPath(TurbineServletService.java:218)at org.apache.turbine.services.servlet.TurbineServlet.getRealPath(TurbineServlet.java:134)二、解决方法打开WEB-INF\conf\TurbineResources.properties找到下面一句:services.UploadService.repository=.将此句等号右边的.改为/或/后加一个目录名,Weblogic控制台不再报异常。三、异常分析从Weblogic控制台输出的信息来看,.是一个不安全的路径,这个异常的产生过程是这样的:1、 Turbine Servlet启动。2、 在org.apache.Turbine的doGet方法中有data.setScreen(data.getParameters().getString("screen"))的代码。3、 RunData的实例是DefaultJetspeedRunData,此类继承了org.apache.turbine.services.DefaultTurbineRunData,所以在Turbine类的doGet方法中的data.getParameters实际是调用了DefaultTurbineRunData方法,此方法返回ParameterParser类型,ParameterParser是一个接口,实际的类是org.apache.turbine.util.parser.DefaultParameterParser。在getParameters方法中有一行代码this.parameters.setRequest(this.req),异常是调用setRequest方法产生的。4、 再看DefaultParameterParser的setRequest方法,经调试,异常是从此方法中的语句TurbineUpload.getAutomatic()产生的,然后再看TurbineUpload(org.apache.turbine.services.upload.TurbineUpload),此类是一个抽象类,在getAutomatic方法中调用了upload = getService();5、 再看一下TurbineUpload的getService()方法:public static UploadService getService(){return (UploadService)TurbineServices.getInstance().getService(UploadService.SERVICE_NAME); //SERVICE_NAME=UploadService}TurbineServices.getInstance().getService(UploadService.SERVICE_NAME)返回的类实例是org.apache.turbine.services.upload.TurbineUploadService,而TurbineServices类的getService方法实际是调用了其父类的方法,在其父类的getService方法中有service.init()的语句,实际上是调用了TurbineUploadService父类BaseUploadService的init()方法,看一下此方法内部的代码:String path = getProperties().getProperty(UploadService.REPOSITORY_KEY,UploadService.REPOSITORY_DEFAULT.toString()); //REPOSITORY_KEY=repository//REPOSITORY_DEFAULT = "."if(!path.startsWith("/")){String realPath = TurbineServlet.getRealPath(path);if(realPath != null){path = realPath;}}getProperties().setProperty(UploadService.REPOSITORY_KEY, path);setInit(true);从以上代码分析,path的值是从TurbineResources.properties文件中读取的,从此文件中找到下面一行:services.UploadService.repository=.path读取的等号右面的值,从上面代码中看出,如果路径不是以”/”开头,就调用TurbineServlet.getRealPath(path)得到实际的路径,而此方法实际是调用了TurbineServletService的getRealPath,看TurbineServletService中的getRealPath,有这样一行代码:path = getServletContext().getRealPath( uri );uri的值是从TurbineServlet.getRealPath传递进来的,也就是从TurbineResources.properties读取services.UploadService.repository的值,目前是.getServletContext().getRealPath(“.”)在Weblogic环境下抛出了异常,所以需要修改TurbineResources.properties,将services.UploadService.repository=.改为services.UploadService.repository=/ ,等号右面也可以写绝对路径或以”/”开头的相对路径。
(转载文章请保留出处:北天JAVA技术网(www.java114.com))
 
更多精彩文章:
基于Ajax的应用程序架构汇总
如何详细了解更多有关RMI的资源?
EJB—从EJB会话bean访问EJB实体bean
EJB的继承和多态 [www.theserverside.com]
JMS 1.02规范(URL)
JMS消息类型
 
最近评论:
        
冰封的往事!
wow power leveling,wow gold,wow power leveling,wow gold max(2465)
        
冰封的往事!
wow power leveling,wow gold,WoW Gold,wow gold max(3024)
        
冰封的往事!
wow power leveling,wow gold,WoW Gold,wow gold max(9807)
        
飞舞的传奇!
传世私服,传世私服.传奇世界私服传奇世界私服,传世私服传世私服, 传奇世界私服传奇世界私服.传奇私服传奇私服. max(6520)
        
标 题:   
内 容:   
 
                                  
 
免责声明:该文章由网友发表,如果对您造成侵权,请联系站长

首页 - 承接项目 - 网站地图 - 联系我们 -
版权所有北天JAVA技术工作室 ICP证号:粤ICP备06079815号