当前位置: 代码迷 >> Java Web开发 >> java解析xml文件时提示找不到文件解决办法
  详细解决方案

java解析xml文件时提示找不到文件解决办法

热度:49   发布时间:2016-04-16 22:09:11.0
java解析xml文件时提示找不到文件
首先users.xml在src下

XmlUtils.java
----------------------------------------------------------------------
package cn.itcast.Utils;

import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.UnsupportedEncodingException;

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;

public class XmlUtils {

private static String filePath;
static {
filePath=XmlUtils.class.getClassLoader().getResource("users.xml").getPath();
}

public static Document getDocument() throws Exception, DocumentException{

SAXReader reader =new SAXReader();
Document document=reader.read(new File(filePath));
return document;
}

public static void write2Xml(Document document) throws IOException, IOException {
org.dom4j.io.OutputFormat format=org.dom4j.io.OutputFormat.createPrettyPrint();
format.setEncoding("UTF-8");
XMLWriter writer=new XMLWriter(new FileOutputStream(filePath),format);
writer.write(document); 
writer.close();
}
}
报错内容如下:
---------------------------------

java.lang.RuntimeExceptionjava.net.MalformedURLException: C:\Workspaces\MyEclipse%208.5\day07\WebRoot\WEB-INF\classes\users.xml (找不到路径)
at cn.itcast.dao.impl.UserDaoImpl.add(UserDaoImpl.java:34)
at junit.test.UserDaoTest.testAdd(UserDaoTest.java:23)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:44)
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15)
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:41)
at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:20)
at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:28)
at org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:31)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:73)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:46)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:180)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:41)
at org.junit.runners.ParentRunner$1.evaluate(ParentRunner.java:173)
at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:28)
at org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:31)
at org.junit.runners.ParentRunner.run(ParentRunner.java:220)
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:46)
at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)
Caused by: java.net.MalformedURLException: C:\Workspaces\MyEclipse%208.5\day07\WebRoot\WEB-INF\classes\users.xml (找不到路径)
at org.dom4j.io.SAXReader.read(SAXReader.java:221)
at cn.itcast.Utils.XmlUtils.getDocument(XmlUtils.java:26)
at cn.itcast.dao.impl.UserDaoImpl.add(UserDaoImpl.java:19)
... 25 more
----------------------------------------------------------------------------------------------
望高手解答!!!!
------解决方案--------------------
应该是路径有问题。MyEclipse%208.5这个是什么。。。
  相关解决方案