91影院影视app
at com.bjtu.sd.nessus.security.NessusParser.getInfo(NessusParser.java:144),getInfo()方法144行对应的出错了。你读取XML呢是吧?xml要有内容,随便加个标签就行,只有头部没有内容会报错的喔~~~
91影院福利社入口
public java.util.List selectxml(String filename)
{
org.w3c.dom.Document dt = null;
javax.xml.parsers.DocumentBuilderFactory dbf = javax.xml.parsers.DocumentBuilderFactory
.newInstance();
try
{
javax.xml.parsers.DocumentBuilder db = dbf.newDocumentBuilder();
java.io.File file = new java.io.File(filename);
dt = db.parse(file);
} catch (ParserConfigurationException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SAXException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
org.w3c.dom.NodeList nl = dt.getDocumentElement().getElementsByTagName(
“student”);
java.util.ArrayList al = new java.util.ArrayList();
System.out.print(nl.getLength());
for (int i = 0; i nl.getLength(); i++)
{
org.w3c.dom.Element student = (org.w3c.dom.Element) nl.item(i);
Person person = new Person();
person.setName(student.getElementsByTagName(“name”).item(0)
.getFirstChild().getNodeValue().toLowerCase());
person.setAge(student.getElementsByTagName(“age”).item(0)
.getFirstChild().getNodeValue().toString());
person.setAddress(student.getElementsByTagName(“address”).item(0)
.getFirstChild().getNodeValue().toString());
person.setTelephone(student.getElementsByTagName(“telephone”).item(
0).getFirstChild().getNodeValue().toString());
al.add(person);
}
return al;
}
91约炮网址app下载安装
!ElEMENT title (#PCDATA) 应该是l小写了 应该!ELEMENT title (#PCDATA)
91影院
at anaXml.AnalyzeOfXml.main(AnalyzeOfXml.java:24)
在你的java类中的24行出错了,你看你24行是做了什么操作.
XML书写是有严格要求的,有始有终的,仔细找下看哪对不上的
91影院影视app
Exception in thread “main” java.io.FileNotFoundException: D:\MYECLIPSE工作夹\xml\src\book.xm
.parse(“D:\\MYECLIPSE工作夹\\xml\\src\\xml\\book.xml”);
哥们你仔细对一下这两个路径。
放在D盘下自己先测试吧
祝你成功
91约炮网址app下载安装
JAVA与XML文件,可以说是软件开发的“黄金搭档”,而如何使用JAVA完成对XML文件的读取,是我们首先要解决的问题。
一、XML文件
这个示例文件包括了用来打开ORACLE数据库的各种参数
?xml version=”1.0″ encoding=”UTF-8″?
dbmsg
dbinfo
drivernameoracle.jdbc.driver.OracleDriver/drivername
sConnStrjdbc:oracle:thin:@11.88.225.80:1521:VOUCHERDB/sConnStr
usernameSYS AS SYSDBA/username
passwordvoucherdb/password
/dbinfo
/dbmsg
二、编写类名为ReadXml的类,用于解析XML文件
我们要在应用程序中打开数据库,就必须完成对该文件中drivername、sConnStr、username、password的读取,通过查找有关资料,笔者编制了以下程序,用于读取文件名为filename的XML文件。
package voucher.basic;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;
public class ReadXml {
private String drivername;
private String sConnStr;
private String username;
private String password;
public String getDrivername() {
return drivername;
}
public String getSConnStr() {
return sConnStr;
}
public String getUsername() {
return username;
}
public String getPassword() {
return password;
}
public void setDrivername(String drivername) {
this.drivername = drivername;
}
public void setSConnStr(String connStr) {
sConnStr = connStr;
}
public void setUsername(String username) {
this.username = username;
}
public void setPassword(String password) {
this.password = password;
}
public ReadXml(String fileName){
DocumentBuilderFactory domfac=DocumentBuilderFactory.newInstance();
try {
DocumentBuilder dombuilder=domfac.newDocumentBuilder();
InputStream is=new FileInputStream(fileName);
Document doc=dombuilder.parse(is);
Element root=doc.getDocumentElement();
NodeList dbinfo=root.getChildNodes();
if(dbinfo!=null){
for(int i=0;idbinfo.getLength();i++){
Node db=dbinfo.item(i);
for(Node node=db.getFirstChild();node!=null;node=node.getNextSibling()){
if(node.getNodeType()==Node.ELEMENT_NODE){
if(node.getNodeName().equals(“drivername”)){
setDrivername(node.getFirstChild().getNodeValue());
}
if(node.getNodeName().equals(“sConnStr”)){
setSConnStr(node.getFirstChild().getNodeValue());
}
if(node.getNodeName().equals(“username”)){
setUsername(node.getFirstChild().getNodeValue());
}
if(node.getNodeName().equals(“password”)){
setPassword(node.getFirstChild().getNodeValue());
}
}
}
}
}
} catch (ParserConfigurationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SAXException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
这个以ReadXml命名的类,使用了参数为文件名的构造方法,用户只要将配置文件我名称传递给该方法,就可以完成对XML文件的解析,进而完成对相应参数数的读取。
三、如何获取XML文件全路径并读取配置参数
获取XML文件全路径的方法有两个,一是在servlet中获取,二是在单独的JAVA类中获取。
1.在servlet中获取XML文件的全路径并读取配置参数
程序片段String dirPath = getServletContext().getRealPath( “/WEB-INF”);
String fileName = dirPath + “/conn.xml”;
ReadXml xm = new ReadXml(fileName);
String DriverName = xm.getDrivername();
String connStr = xm.getSConnStr();
String user = xm.getUsername();
String pas = xm.getPassword();
将这段程序添加到servlet中dopost()之后即可完成参数的读取
2.在单独的JAVA类中获取全路径并读取配置参数
程序片段
String dirpath = System.getProperty(“user.dir”);
String xmlFile = dirpath + “/WebRoot/WEB-INF/conn.xml”;
ReadXml rdxml = new ReadXml(xmlFile);
String driverName = rdxml.getDrivername();
String sConnStr = rdxml.getSConnStr();
String userName = rdxml.getUsername();
String passWord = rdxml.getPassword();
注:配置文件conn.xml保存在webroot/WEB-INF目录中。