解决war包中文件路径问题

2024-09-06 16:08
文章标签 问题 路径 解决 war 包中

本文主要是介绍解决war包中文件路径问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在j2EE项目中,我们一般会把项目打包发布,一般是war包,作为独立单元,可以远程上传,加载,发布,还可以实现版本控制,但这与我们开发过程中使用MyEclipse自动部署有所不同,以下做详细说明.

使用war包部署,在tomcat和WebLogic下部署有很大的区别,tomcat会把war自动加压到当前目录下,然后再用解压的目录来发布,这与一般不会出现太大的意外,但如果是用WebLogic发布,就不会被解压,如果开发过程中不注意,war包发布后就有可能出现找不到文件的现象。例如:使用以下方法获取路径:

this.getClass().getClassLoader().getResource("/").getPath();

这与得到的是绝对Uri路径,例如::/D:/jboss-4.2.2.GA/server/default/deploy/hp.war/WEB-INF/classes/,带盘符的路径,显然在war中无法根据盘符来找到文件

第二种方式:

this.getClass().getResource("/").getPath();

那么这样获取行不行呢?经试验,这与获取的是当前类的Uri目录,例如:/D:/jboss-4.2.2.GA/server/default/deploy/hp.war/WEB-INF/classes/com/jebel/helper/ 也是绝对路径,显然无法适用于war包。

其实以上两种方式都走入了岔路,因为读取文件未必要读取路径,文件操作一般都要转换为流的方式,既然要读取文件,不如直接读成输入流,也少了一步封装。请看以下方式:

InputStream is= this.getClass().getResourceAsStream("/config/bctcms/" + templateFileName);

意思是读取classes目录中,目录config/bctcms/下,文件名为templateFileName的文件输入流。经试验在war中可以正常读取到。

该方法存在一个弊端,只能读取classes目录下的文件,对于其他目录下的文件无能为力,显然并不适用于所有场景。

如果文件在WEB-INF目录下,如何进行读取呢?

答案是使用ServletContext.getResourceAsStream(String)方法。也就是先得到上下文信息,然后通过以工程目录为root的绝对路径,找到文件,举例说明:

InputStream is= context.getResourceAsStream(templatePath + "/" + templateFileName);templatePath="/WEB-INF/classes/config/bctcms/"templateFileName="source.xls"

可以看到templatePath是相对于context root 的路径,而不是相对于classes,这样即使文件在WEB-INF其他目录下,也可以顺利找到,经测试,对war的情况支持良好。请来看看ServletContext.getResourceAsStreamAPI

文档,

Returns a URL to the resource that is mapped to a specified path. The path must begin with a "/" and is interpreted as relative to the current context root. 

This method allows the servlet container to make a resource available to servlets from any source. 

Resources can be located on a local or remote file system, in a database, or in a .war file.

相信大家都看得懂,就不用赘述了。只是有个问题,context是个什么东西?答案:ServletContext,上下文信息,在j2EE类中使用request获得,如:

ServletContext context = request.getSession().getServletContext();

那么在普通类中如何获取呢?暂时特别好的办法,使用application是一种方式,另外一种方式就是想办法先后去request对象,如:

RequestAttributes ra = RequestContextHolder.getRequestAttributes();HttpServletRequest request = ((ServletRequestAttributes) ra).getRequest();this.context = request.getSession().getServletContext();

这样也是可以获得Context的

但如果是JSP中,可以直接这么获取输入流:

application.getResourceAsStream("xxx”);

路径问题不要纠结太久,根据以上办法解决,最好都用

ServletContext方法来获取,只需要知道一种情况就可以了。达到目的才是最重要的,对吧?

 

这篇关于解决war包中文件路径问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1142478

相关文章

Oracle登录时忘记用户名或密码该如何解决

《Oracle登录时忘记用户名或密码该如何解决》:本文主要介绍如何在Oracle12c中忘记用户名和密码时找回或重置用户账户信息,文中通过代码介绍的非常详细,对同样遇到这个问题的同学具有一定的参... 目录一、忘记账户:二、忘记密码:三、详细情况情况 1:1.1. 登录到数据库1.2. 查看当前用户信息1.

springboot3.4和mybatis plus的版本问题的解决

《springboot3.4和mybatisplus的版本问题的解决》本文主要介绍了springboot3.4和mybatisplus的版本问题的解决,主要由于SpringBoot3.4与MyBat... 报错1:spring-boot-starter/3.4.0/spring-boot-starter-

在 Spring Boot 中使用异步线程时的 HttpServletRequest 复用问题记录

《在SpringBoot中使用异步线程时的HttpServletRequest复用问题记录》文章讨论了在SpringBoot中使用异步线程时,由于HttpServletRequest复用导致... 目录一、问题描述:异步线程操作导致请求复用时 Cookie 解析失败1. 场景背景2. 问题根源二、问题详细分

解读为什么@Autowired在属性上被警告,在setter方法上不被警告问题

《解读为什么@Autowired在属性上被警告,在setter方法上不被警告问题》在Spring开发中,@Autowired注解常用于实现依赖注入,它可以应用于类的属性、构造器或setter方法上,然... 目录1. 为什么 @Autowired 在属性上被警告?1.1 隐式依赖注入1.2 IDE 的警告:

解决java.lang.NullPointerException问题(空指针异常)

《解决java.lang.NullPointerException问题(空指针异常)》本文详细介绍了Java中的NullPointerException异常及其常见原因,包括对象引用为null、数组元... 目录Java.lang.NullPointerException(空指针异常)NullPointer

Android开发中gradle下载缓慢的问题级解决方法

《Android开发中gradle下载缓慢的问题级解决方法》本文介绍了解决Android开发中Gradle下载缓慢问题的几种方法,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、网络环境优化二、Gradle版本与配置优化三、其他优化措施针对android开发中Gradle下载缓慢的问

关于Nginx跨域问题及解决方案(CORS)

《关于Nginx跨域问题及解决方案(CORS)》文章主要介绍了跨域资源共享(CORS)机制及其在现代Web开发中的重要性,通过Nginx,可以简单地解决跨域问题,适合新手学习和应用,文章详细讲解了CO... 目录一、概述二、什么是 CORS?三、常见的跨域场景四、Nginx 如何解决 CORS 问题?五、基

python安装whl包并解决依赖关系的实现

《python安装whl包并解决依赖关系的实现》本文主要介绍了python安装whl包并解决依赖关系的实现,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录一、什么是whl文件?二、我们为什么需要使用whl文件来安装python库?三、我们应该去哪儿下

MySQL安装时initializing database失败的问题解决

《MySQL安装时initializingdatabase失败的问题解决》本文主要介绍了MySQL安装时initializingdatabase失败的问题解决,文中通过图文介绍的非常详细,对大家的学... 目录问题页面:解决方法:问题页面:解决方法:1.勾选红框中的选项:2.将下图红框中全部改为英

MySQL9.0默认路径安装下重置root密码

《MySQL9.0默认路径安装下重置root密码》本文主要介绍了MySQL9.0默认路径安装下重置root密码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录问题描述环境描述解决方法正常模式下修改密码报错原因问题描述mysqlChina编程采用默认安装路径,