亲宝软件园·资讯

展开

java classpath指向哪里

不仅仅是说说而已 人气:0

今天在项目里看到好多地方都用到了classpath,并且自己对calsspath到底指向哪里还不是很清楚,所以就在网上百度了一下!

上面图片的意思简单来说,就是classpath只能表示lib目录和WEB-inf/classes路径下的文件,calsspath不能表示的src路径下面的文件,

但是从项目结构来看,配置文件一般是不放在放在WEB-INF下面啊,并且也没有看到classes路径,lib目录不是放依赖jar包的吗。此时感觉凉凉了。并且测试了一下,在WEB-INF路径下面创建了lib和classes文件夹,

测试的结果也很明显,访问不到WEB-INF下面的classes和lib路径下面的文件,报错了。

但是,我有一想,不对啊,明明项目中能用classpath引入配置文件,那到底是怎么引入的呢?

从第一张图和第二张图,使用classpath访问到了src路径下面的main/resources文件中的配置文件

打开编译后的项目,发现项目文件中有一个文件名为.classpath的文件,点开看了一下

具体classpath文件的介绍可以参考下面博客

.classpath文件详解

.classpath文件用于记录项目编译环境的所有信息,包括:源文件路径、编译后class文件存放路径、依赖的jar包路径、运行的容器信息、依赖的外部project等信息。如果把该文件删除,则eclipse不能讲该工程识别为一个正常的java工程,仅仅当做普通的文件夹而导致不能正常运行。

总体上说这个文件就是配置整个工程的运行环境。

这就很明白了,classpath值得就是(kind=”src”)所指定的文件,并且此时的可以看到(kind=”src”)的设置并没有包含WEB-INF文件。此时我们要验证WEB-INF文件被classpath访问跟这个设置有关吗。

首先我们将applicationContext.xml文件放在WEB-INF路径下面,并且.classpath文件内容如下图,启动本项目

打开项目的原始文件,发现applicationContext.xml并没有出现

此时我们将.classpath文件中添加

classpathentry kind=”src” path=”WebContent/WEB-INF”/

再次启动本项目

打开项目的原始路径下,发现applicationcontext.xml出现在了WebContent/WEB-INF下面

由此可以总结:

加载全部内容

相关教程
猜你喜欢
用户评论