В чем разница между пакетом с jar и пакетом с классами? - PullRequest
1 голос
/ 19 октября 2011

Я знаю, что в Java есть два способа упаковки одного приложения.Один из способов - извлечь все классы его зависимостей и упаковать их вместе с вашими классами в большой jar.Другой способ - скопировать все его зависимости в папку lib и упаковать их со своими собственными классами в большую флягу.В чем разница между этими двумя методами упаковки?

Спасибо

Ответы [ 3 ]

1 голос
/ 19 октября 2011

Я не согласен, что любой из них является стандартным методом.Стандартный метод состоит в том, чтобы распространять столько файлов .JAR, сколько необходимо, в любой структуре каталогов.

0 голосов
/ 04 января 2013
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..

код для анализа XML-файла в том же пакете в Java

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


    }
0 голосов
/ 19 октября 2011

Ну, на самом деле официальный Java-способ упаковки исполняемого jar-файла заключается в размещении всех других зависимостей jar вне его, в папке, которая затем объявляется как находящаяся в пути к классам (либо в манифесте исполняемого jar-файла, либо какаргументы командной строки при запуске исполняемого файла jar).

Существуют инструменты, которые пытаются "вставить" ваши зависимости classpath в ваш файл jar.Они делают это либо распаковывая все jar-файлы (которые на самом деле являются zip-файлами с другим расширением), а затем перепаковывая все их содержимое в один jumbo jar.Или они добавляют jar зависимостей как есть во внутреннюю часть исполняемого jar.У Maven есть плагин, который делает обе эти вещи, и Eclipse может делать их тоже с ходу (когда вы экспортируете свой проект в качестве исполняемой фляги).

Я предпочитаю версию, в которой фактические фляги упакованы в вашембаночка.Во-первых, это более уместно при организации файлов, а во-вторых, вы не рискуете иметь два класса с одинаковым полностью определенным именем, которые изначально были помещены в разные банки, а теперь конфликтуют (по сути, один перезапишет другой).Более того, с точки зрения classpath, наличие нескольких jar-файлов в classpath, каждый из которых имеет свои собственные файлы классов, НЕ то же самое, что все эти классы помещаются непосредственно в classpath, поэтому добавление ресурсов в исполняемый jar-файл как jars (а не в виде файлов классов) это больше касается пересмотра этого.

...