我知道在java中有两种打包一个应用程序的方法。一种方法是提取其所有依赖项的类,并将它们与您的类打包到一个大jar中。另一种方法是将其所有依赖项复制到lib文件夹,并将它们与您自己的类打包到一个大型jar中。这两种包装方法有什么区别?
由于
答案 0 :(得分:1)
我不同意其中任何一种都是标准方法。标准方法是根据需要在任何目录结构中分发尽可能多的.JAR文件。
答案 1 :(得分:0)
实际上,打包可执行jar的官方Java方法是将所有其他jar依赖项放在它之外,然后在一个文件夹中声明为在类路径中(在可执行jar的清单中,或者作为运行可执行jar时的命令行参数。)
有些工具试图“填充”jar文件中的类路径依赖项。他们通过解压缩所有jar文件(实际上是具有不同扩展名的zip文件)然后在一个巨型jar中重新打包所有内容来完成此操作。或者他们将依赖关系jar原样添加到可执行jar的内部。 Maven有一个插件可以完成这两件事,Eclipse也可以随时执行它们(当你将项目导出为可运行的jar时)。
我更喜欢在罐子里打包实际罐子的版本。首先,当文件组织进行时更合适,其次,您不会冒两个具有相同完全限定名称的类的风险,这些类最初放置在不同的罐中,现在正处于冲突状态(实际上会覆盖另一个)。更重要的是,从类路径的角度来看,在类路径中有多个jar文件,每个文件都有自己的类文件,并且所有这些类都直接放在类路径中,所以将可执行jar中的资源添加为jar(而不是作为类文件)更倾向于复制它。
答案 2 :(得分:0)
book.xml
<book>
<person>
<first>Kiran</first>
<last>Pai</last>
<age>22</age>
</person>
<person>
<first>Bill</first>
<last>Gates</last>
<age>46</age>
</person>
<person>
<first>Steve</first>
<last>Jobs</last>
<age>40</age>
</person>
<person>
<first>kunal</first>
<last>kumar</last>
<age>25</age>
</person>
</book>
create a xml file book.xml
made a jar file book.xml.jar and
palce it in war/web-inf/lib folder of your project..
then it will work..
解析java中相同包中的xml文件的代码
import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import javax.servlet.http.*;
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;
import org.xml.sax.SAXParseException;
@SuppressWarnings("serial")
public class XMLParser extends HttpServlet {
InputStream istream =getClass().getResourceAsStream("/book.xml");
public void doGet(HttpServletRequest req, HttpServletResponse resp)throws IOException
{
DocumentBuilderFactory docBuilderFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder docBuilder = null;
try {
docBuilder = docBuilderFactory.newDocumentBuilder();
} catch (ParserConfigurationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
Document doc = null;
try {
doc = docBuilder.parse (istream);
} catch (SAXException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
// normalize text representation
doc.getDocumentElement ().normalize ();
System.out.println ("Root element of the doc is " +
doc.getDocumentElement().getNodeName());
NodeList listOfPersons = doc.getElementsByTagName("person");
int totalPersons = listOfPersons.getLength();
System.out.println("Total no of people : " + totalPersons);
for(int s=0; s<listOfPersons.getLength() ; s++){
Node firstPersonNode = listOfPersons.item(s);
if(firstPersonNode.getNodeType() == Node.ELEMENT_NODE){
Element firstPersonElement = (Element)firstPersonNode;
//-------
NodeList firstNameList = firstPersonElement.getElementsByTagName("first");
Element firstNameElement = (Element)firstNameList.item(0);
NodeList textFNList = firstNameElement.getChildNodes();
System.out.println("First Name : " +
((Node)textFNList.item(0)).getNodeValue().trim());
//-------
NodeList lastNameList = firstPersonElement.getElementsByTagName("last");
Element lastNameElement = (Element)lastNameList.item(0);
NodeList textLNList = lastNameElement.getChildNodes();
System.out.println("Last Name : " +
((Node)textLNList.item(0)).getNodeValue().trim());
//----
NodeList ageList = firstPersonElement.getElementsByTagName("age");
Element ageElement = (Element)ageList.item(0);
NodeList textAgeList = ageElement.getChildNodes();
System.out.println("Age : " +
((Node)textAgeList.item(0)).getNodeValue().trim());
//------
}//end of if clause
}//end of for loop with s var
//System.exit (0);
}//end of main
}