关于运行jar文件和jar文件路径和dom4j读取jar文件

6个月的实习结束了  离开前把自己摸索的一些东西贴出来

首先用eclipse敲好代码,打包成jar文件,注意此时可能无法用“Java -jar name.jar”来执行 。.class .project 只是在eclipse有用 可删掉 

       上面的是eclipse中的目录 。bin目录下面是各个包的目录 ,src是源码 ,在运行jar包的时候不起作用。

这是jar文件中的目录(可用压缩文件打开jar包,jar包其实就是压缩文件)  没有了bin 和 src 目录,直接就是各个包的目录了。


上面的是MANIFEST.MF文件 ,   很重要, 在这里要配置classPath 。   路径要求:依赖的jar包和要运行的jar包根目录要相同(参考下图,logs目录下面是依赖的jar包),到这里就可以运行了 jar包了。



eclipse生成的项目在磁盘上的目录有个bin下面是包。
关于如何调用jar包中的文件:
xxx.class.getClassLoader().getResourceAsStream("gg/test.xml")返回的是InputStream对象,在jar文件中getResourceAsStream("gg/test.xml")里的参数是一个路径,这个路径是从项目根路径开始算起。而在eclipse中路径是从bin目录下开始算起。关于路径的关系可对照前几张截图分析。不多说。目前只能做到读取jar包中的数据还不能改变其中的数据。
Class.getResource()和class.getClassLoader().getResource()区别:
前者定位到包最里面的目录,也就是class文件存放的目录,而后者定位到所有包的父目录。下面是个例子程序
package parseXML.gafa;
import java.io.File;

public class FileTest {
    public static void main(String[] args) throws Exception {
        System.out.println(Thread.currentThread().getContextClassLoader().getResource(""));
 
        System.out.println(FileTest.class.getClassLoader().getResource(""));
 
        System.out.println(ClassLoader.getSystemResource(""));
        System.out.println(FileTest.class.getResource(""));
        System.out.println(FileTest.class.getResource("/"));
        //Class文件所在路径
        System.out.println(new File("/").getAbsolutePath());
        System.out.println(System.getProperty("user.dir"));
//System.out.println(new File("C:\\ccc\\123").getParent()); //获取上一级目录
    }
}  
输出为:
file:/D:/workSpace/parseXML/bin/
file:/D:/workSpace/parseXML/bin/
file:/D:/workSpace/parseXML/bin/
file:/D:/workSpace/parseXML/bin/parseXML/gafa/
file:/D:/workSpace/parseXML/bin/
D:\
D:\workSpace\parseXML

下面是用dom4j和xpath读取jar中文件的代码。这个问题关键是 eclipse生成的项目目录和打包成jar文件后的目录是不相同的
package parseXML.gafa;


import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.FileWriter;
import java.io.IOException;
import java.io.InputStream;
import java.net.URL;
import java.util.Iterator;
import java.util.List;


import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;


import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.DOMReader;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;


public class parseService {
public String readText(String filePath,String xpath) throws DocumentException{//读取节点的值
SAXReader saxReader = new SAXReader();
Document xmlDoc = saxReader.read(parseService.class.getClassLoader().getResourceAsStream(filePath));
Element root = xmlDoc.getRootElement();
Element obj = null;
try {
obj = (Element) root.selectObject(xpath);// 根据XPath查找元素
} catch (Exception e) {
System.out.print("xpath is wrong!!");
}
return obj.getText();
}


public String readAttribute(String filePath,String xpath,String type) throws DocumentException{//读取某个节点的属性
SAXReader saxReader = new SAXReader();
Document xmlDoc = saxReader.read(new File(parseService.class.getClassLoader()
.getResource(filePath).getPath()));
Element root = xmlDoc.getRootElement();
Element obj = null;
try {
obj = (Element) root.selectObject(xpath);// 根据XPath查找元素
} catch (Exception e) {
System.out.print("xpath is wrong!!");
}
Attribute attribute = obj.attribute(type);
return attribute.getValue();
}



public static void main(String[] args) throws Exception {
String str =new parseService().readText("parseXML/gafa/test.xml","//pro[@type='att']");
System.out.print(str);
}
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值