1. 개요
ANT는 주로 Java 환경에서 소프트웨어 개발을 위해 소프트웨어 컴파일, 테스트, 배포 및 기타 자동화 단계를 연결하는 도구입니다. 실제 소프트웨어 개발에는 개미를 사용할 곳이 많이 있습니다.
개발 환경 :
다음과 같이 코드 코드를 복사하십시오.
시스템 : Windows
JDK : 1.6+
IDE : 일식
개미 : 1.9.1
둘째, 장점
Ant는 Apache Software Foundation의 Jakarta 디렉토리에서 하위 프로젝트입니다.
1. Cross -Platform : Ant는 순수한 Java 언어로 작성되었으므로 Cross -Platform이 좋습니다.
2. 간단한 작동 : ANT는 구축 된 작업과 선택적인 작업으로 구성됩니다. 개미는 XML 파일 (빌드 파일)이 필요합니다. Ant는 대상 트리를 호출하여 다양한 작업을 실행할 수 있습니다. 각 작업은 특정 인터페이스 객체를 구현합니다.
3. 간단한 유지 관리, 양호한 가독성 및 간단한 통합 : 개미 구축 파일이기 때문에 XML 형식 파일은 유지 관리 및 쓰기가 쉽고 구조가 매우 명확합니다. 개미는 개발 환경에 통합 할 수 있습니다. Ant의 교차 플랫폼 및 간단한 작동 특성이므로 일부 개발 환경에 쉽게 통합 할 수 있습니다.
셋째, 설치 및 구성
1. Ant, http://mirror.esocc.com/apache/ant/binaries/apache-nt-nt-9.1-bin.zip을 다운로드하십시오
2. 지퍼 압축 패키지를 압축하고 배치하려는 디렉토리를 배치하려는 압축 패키지를 배치하십시오. 여기에 d : /apache-at-1.9.1에 배치하면 디렉토리 구조는 다음과 같습니다.
BIN은 Ant_home으로 구성되지 않으면 BIN 디렉토리의 BAT 프로그램을 통해 빌드 작업을 실행할 수 있습니다.
예를 들어 : CMD에서 ANT.BAT를 실행하려면 현재 디렉토리에 Build.xml을 선택합니다 (Build.xml은 기본 ANT 실행 파일입니다. 물론 다른 파일을 지정할 수 있습니다).
모든 XSL 출력 템플릿은 ETC 디렉토리에 저장되어 다양한 작업의 향상된 내보내기 XML 출력을 만들어 구축 파일이 오래된 경고를 제거 할 수 있습니다.
LIB 디렉토리에 저장되는 것은 ANT 프로그램이 의존 해야하는 JAR 패키지입니다.
수동 디렉토리는 개미 프로그램의 도움말 문서입니다.
3. 내 컴퓨터에서> 마우스 오른쪽 버튼 클릭 속성> 고급 시스템 구성-> 환경 변수의 개미 구성
새로운 시스템 변수 ant_home = d : /apache-at-1.9.1
이러한 방식으로 환경 변수가 구성되지만 JDK의 환경 변수를 구성 해야하는 전제입니다. JDK의 환경 변수를 구성하지 않으면 먼저 JDK 변수를 구성하십시오. JDK 환경 구성 방법은 다음과 같습니다.
(1) 기본 디렉토리에 jdk를 설치하십시오. c :/program files/java/jdk1.5.0_05
C :/Program Files/Java/JDK1.5.0
역할 : 시스템 JVM에 JVM이 어디에 있는지 알려줍니다
(2) 오른쪽 -내 컴퓨터를 클릭하고, 속성, 고급 환경 변수를 선택하십시오.
(3) 시스템 변수 막대에 새로 구축 된 새로운 시스템 변수 대화 상자가 나타나고 Java_home은 변수 이름, 변수 값으로 채워집니다. c :/program files/java/jdk1.5.0_05
(4) 확인 후 시스템 변수에서 새로운 환경 변수 클래스 경로를 작성하십시오.
(5) 확인 후 시스템 변수 열의 경로로 변수로 옵션을 찾아 선택하십시오.
%java_home%/bin
경로 변수를 찾지 못하면 새로운 경로 변수를 직접 만드십시오!
실행할 때마다 클래스가 위치한 디렉토리로 실행하지 않으려면 Java 명령을 실행하려면 모든 클래스 파일을 Unified Directory 조직 아래에 넣은 다음이 디렉토리를 클래스 경로에 추가 할 수 있습니다.
테스트 코드는 다음과 같습니다.
다음과 같이 코드 코드를 복사하십시오.
공개 수업 테스트 {
public static void main (String [] args) {{
System.out.println ( "Hello World!");
}
}
메모장 편집기가 test.java (파일 이름 및 같은 이름) 파일로 편집 된 후 명령 줄 창을 엽니 다.
파일이있는 디렉토리로 CD :
다음과 같이 코드 코드를 복사하십시오.
javac test.java // compile 명령
Java Test // 실행 프로그램
출력이 : Hello World, 그렇지 않으면 다시 확인하십시오.
넷째, 시험 개미
그림과 같이 CMD를 실행하는 DOS 창에 개미를 입력하십시오.
이것이 나타나면 설치를 축하합니다! 그렇지 않으면 실패하고 이전 단계를 잘못 확인합니다. 위의 명령은 ANT 프로그램을 실행하며 ANT는 기본적으로 Build.xml에서 작업을 수행합니다.
설치가 실패하면 몇 가지 상황이 있는지 확인하십시오.
1. 구성 없음 Java_Home 또는 구성 오류가 없으며 Java_Home/bin/java.exe가 있습니다.
2. 구성 없음 Ant_Hoem 또는 구성 오류가없고 Ant_Home/bin/ant.bat가 존재합니다.
3. 환경 변수의 경로 변수를 확인하십시오. 목재 및 구성이 있습니다 ...;%ang_home%/bin;
%경로%= ... 아마도기구 ...;%ant_home%/bin ....
5. 개미의 작동
개미가 명령을 실행하면 때때로 일부 파크 항아리 라이브러리가 있습니다. 이 라이브러리는 각 개미 프로젝트에 존재하므로 현재이 JAR 패키지를 글로벌 라이브러리로서 Ant_home/Lib 디렉토리에 넣을 수 있습니다.
원래 ANT 프로그램을 "오염"하지 않으려면 현재 Windows 사용자 디렉토리에 JAR 패키지를 넣을 수 있습니다. 위 디렉토리가 없으면 수동으로 설정할 수 있습니다.
일시적으로 LIB를 추가하고 싶고 현재 개미 엔지니어링에 LIB를 추가하고 싶지 않은 경우. ANT 프로그램을 실행할 때 종속 LIB 매개 변수를 지정할 수 있습니다.
동시에, 현재 빌드 프로젝트의 클래스 경로 디렉토리에서 프로젝트를 JAR 패키지에 추가 할 수도 있습니다.
6. 개미 명령
문법 요소 설명은 다음과 같습니다.
-돕다
개미 명령 및 해당 옵션의 도움말 정보 표시
-projecthelp
이 디스플레이에는 건설 파일의 모든 사용자가 작성한 도움말 문서가 포함되어 있습니다. 즉, 각 <garget>의 설명 속성의 텍스트와 <cression> 요소에 포함 된 텍스트입니다. 설명 속성의 대상은 기본 대상 (기본 대상) 이며이 속성이없는 대상은 하위 타겟으로 나열됩니다.
-버전
버전 정보를 표시 한 다음 종료해야합니다.
-조용한
억제는 건설 파일에서 Echo 작업에 의해 생성 된 대부분의 뉴스가 아닙니다.
-말 수가 많은
시공 과정에서 각 작업의 자세한 메시지를 표시하십시오. 이 옵션은 -debug 옵션으로 만 선택할 수 있습니다.
-debug
ANT 및 작업 개발자가 이미 메시지를 디버그하는 메시지를 표시했습니다. 이 옵션은 -verbose로 그중 하나만 선택할 수 있습니다.
-자료
EMACS의 Shellmode가 쉽게 분석 할 수 있도록 로그 메시지를 형식화하십시오.
-logfile filename
로그 출력을 지정된 파일로 재설정하십시오.
-Logger ClassName
개미 로그를 처리 할 클래스를 지정하십시오. 지정된 클래스는 org.apache.tools.ant.buildlogger 인터페이스를 구현해야합니다.
-Listener ClassName
모니터링 클래스를 선언하고 리스너 목록으로 늘리십시오. 이 옵션은 ANT 및 IDE 또는 기타 Java 프로그램이 통합 될 때 매우 유용합니다. 6 장을 읽고 감독자에 대한 자세한 정보를 이해할 수 있습니다. 지정된 청취 클래스는 개미를 처리 할 수있는 시공 메시지의 처리로 작성해야합니다.
-BuildFile 파일 이름
처리해야 할 구성 파일을 지정하십시오. 기본 구성 파일은 build.xml입니다.
-dproperty = value
명령 줄에서 특성 이름 -Value 쌍을 정의하십시오.
-파인 이름
처리 해야하는 구성 파일을 지정하십시오. BuildFile 옵션과 달리 지정된 파일이 현재 디렉토리에없는 경우 -Find는 부모 디렉토리에서 검색해야합니다. 이 검색은 파일 시스템의 루트가 될 때까지 조상 디렉토리에서 계속 수행 될 것이며 파일이 발견되지 않으면 구조가 실패합니다.
-Tuoproxy JDK1.5 이상은 에이전트 설정을 사용할 수 있습니다
-nouserlib는 실행 중에 사용자 lib에서 Jar 패키지를 사용하지 않습니다.
-NICE 디자인 메인 스레드 우선 순위
-logfile은 지정된 로그 로그를 사용합니다
-NOONPUT는 대화식 입력을 허용하지 않습니다
-Keep -gream, -K 실행은 모든 목표에 의존하지 않습니다.
-propertyfil
다음과 같이 코드 코드를 복사하십시오.
<project default = "all">
<속성 이름 = "pro_a"value = "value" />
<속성 이름 = "pro_b"value = "b value" />
<path id = "rt.phth">
<pationement local = "$ {java.home} /jre/lib/rt.jar"/>
</path>
<대상 이름 = "all">
<javac srcdir = ".">
<classpath refid = "a.path" />
</javac>
</target>
</project>
알아채다:
● 모든 건설적인 파일에는 <project> 요소와 하나 이상의 <parget> 요소가 있어야합니다.
● <project> 요소의 기본 속성에 반드시 기본값이 필요하지는 않습니다.
● 건설 파일의 이름을 build.xml로 지정할 필요가 없습니다. 그러나 build.xml은 개미가 검색하려는 기본 파일 이름입니다.
● 각 건축 파일에는 <project> 요소가 하나만있을 수 있습니다.
CMD 창에 다음과 같이 현재 build.xml 디렉토리 복사 코드를 입력하십시오.
개미
기본 대상을 수행하려면 현재 디렉토리에서 Build.xml에서 Ant를 실행하십시오.
다음과 같이 코드 코드를 복사하십시오.
Ant -BuildFile 빌드 -test.xml
기본 대상을 실행하려면 현재 디렉토리에서 Build-Test.xml에서 Ant를 실행하십시오.
다음과 같이 코드 코드를 복사하십시오.
Ant -BuildFile Build -test.xml Clean
현재 디렉토리에서 Build-Test.xml에서 Ant를 실행하고 Clean이라는 대상을 실행하십시오.
다음과 같이 코드 코드를 복사하십시오.
Ant -BuildFile 빌드 -test.xml -dbuild = 빌드/클래스 청소
현재 디렉토리에서 Build-Test.xml에서 Ant를 실행하고 Clean이라는 대상을 실행하고 빌드 속성의 값을 빌드/클래스로 설정하십시오.
7. 개미 스크립트 : 노드, 요소 및 속성 사용, 명령 지침
1. 프로젝트 노드 요소
프로젝트 요소는 ANT 구성 요소 파일의 루트 요소입니다. ANT 구성 요소 파일에는 하나 이상의 프로젝트 요소가 포함되어야합니다. 각 프로젝트 요소에 여러 대상 요소가 포함될 수 있습니다. 다음은 독자에게 프로젝트 요소의 속성을 보여줍니다.
● 이름 속성 : 프로젝트 요소를 지정하기위한 이름입니다.
● 기본 속성 : 프로젝트가 기본적으로 실행될 때 Dearget의 대상 실행 이름.
● 기반 속성 : 기본 경로의 위치를 지정하는 데 사용됩니다. 이 속성이 지정되지 않으면 개미 구성 요소 파일의 첨부 파일이 벤치 마크 디렉토리로 사용됩니다.
다음과 같이 코드 코드를 복사하십시오.
<? xml 버전 = "1.0"?>
<project name = "ant-project"default = "print-dir"bases = ".">
<대상 이름 = "print-dir">
<echo message = "기본 직경은 : $ {basediir}" />입니다.
</target>
</project>
위의 예에서 기본 속성의 값이 여기에서 인쇄된다는 것을 알 수 있습니다. 또한, 기반 속성의 값은 현재 디렉토리를 입력 한 후에는 다음과 같습니다.
2. 대상 노드 요소
대상은 기본 실행 장치 또는 개미 작업으로 하나 이상의 특정 장치/작업을 포함 할 수 있습니다. 여러 대상은 상호 의존성을 가질 수 있습니다. 다음 속성이 있습니다.
● 이름 속성 : 프로젝트 요소에서 고유 한 대상 요소의 이름을 지정합니다. 대상 요소의 이름을 지정하여 대상을 지정할 수 있습니다.
● 속성에 따라 다릅니다. 대상 간의 종속성 관계를 설명하는 데 사용됩니다. ANT는 의존 속성의 대상 순서에 따라 각 대상을 실행하며 종속 대상이 먼저 실행됩니다.
● 속성 인 경우 : 지정된 속성이 존재하지 않는지 확인하는 데 사용됩니다.
● 속성이 아닌 경우이 속성의 기능은 IF 속성의 기능과 반대입니다.
● 설명 속성 :이 속성은 대상 함수에 대한 간단한 설명과 설명입니다.
예:
다음과 같이 코드 코드를 복사하십시오.
<? xml 버전 = "1.0"?>
<project name = "ant-timeget"default = "print">
<대상 이름 = "버전"if = "ant.java.version">
<echo message = "java 버전 : $ {ant.java.version}" />
</target>
<대상 이름 = "print"는 = "docs">이 아닌 한 "버전"에 따라 다릅니다.
<설명>
예제에 따라!
</description>
<echo message = "기본 직경은 : $ {basediir}" />입니다.
</target>
</project>
다음 결과에서 대상 대상이 대상 작업에 따라 다르기 때문에 버전이 먼저 실행됩니다. 1.6 ", 버전이 실행 된 후, 문서가 존재하지 않기 때문에 실행되고, 존재하지 않는 경우 속성이 아닌 경우에도 속성이 대상에 들어가는 경우 인쇄물이 실행, 출력 정보를 실행할 수 있음을 알 수 있습니다."[Echo] 기본 DIR IS : D : D :/WorkSpace/antexample/build ".
3. 속성 속성 노드 요소
속성 요소는 매개 변수 또는 매개 변수의 정의로 간주 될 수 있습니다. build.properties 파일과 같은 외부에 파일을 소개하려면 다음 내용으로 인용 할 수 있습니다.
<속성 파일 = "build.properties"/>/>
속성 요소는 작업의 속성 값으로 사용할 수 있습니다. 작업에서는 $ {attribute name} 사이에 속성 이름을 배치하고 작업 속성 값의 위치에 배치하여 달성됩니다.
ANT는 제작할 수있는 시스템 속성 목록을 제공합니다. 동시에 ANT는 다음과 같이 자체 제작 된 속성을 제공합니다.
기반 : 프로젝트 기본 목록의 절대 경로;
Ant.file : 위의 예에서는 Ant.file 값이 d :/workspace/antexample/build입니다.
Ant.version : 개미 버전 정보,이 기사는 1.8.1입니다.
Ant.Project.Name : 현재 지정된 프로젝트의 이름, 즉 앞에서 언급 한 프로젝트의 이름 속성 값;
Ant.java.version : ANT에서 감지 한 JDK 버전,이 기사는 1.6입니다.
예를 들어 다음과 같이 :
다음과 같이 코드 코드를 복사하십시오.
<project name = "ant-project"default = "example">
<속성 이름 = "name"value = "jojo" />
<속성 이름 = "age"value = "25" />
<대상 이름 = "example">
<echo message = "name : $ {name}, age : $ {age}" />
</target>
</project>
위의 예에서는 사용자가 이름과 나이라는 두 가지 속성을 설정 한 후 각각 $ {name} 및 $ {age}를 통해이 두 속성 값을 얻을 수 있습니다.
4. 사본 명령
사본은 주로 파일과 디렉토리를 복사하는 데 사용됩니다. 예를 들어 다음과 같이 :
● 단일 파일 복사 :
다음과 같이 코드 코드를 복사하십시오.
<copy file = "old.txt"tofile = "new.txt"/>
● 파일 디렉토리 복사 :
다음과 같이 코드 코드를 복사하십시오.
<오늘 복사 = "../ dest_dir">
<fileset dir = "src_dir"/>
</copy>
● 파일을 다른 디렉토리로 복사하십시오.
다음과 같이 코드 코드를 복사하십시오.
<copy file = "src.txt"todir = "c :/base"/>
5. 명령을 삭제합니다
다음과 같이 파일 또는 디렉토리를 삭제하십시오.
● 파일 삭제 :
다음과 같이 코드 코드를 복사하십시오.
<delete file = "/res/images/cat.jpg"/>
● 디렉토리 삭제 :
다음과 같이 코드 코드를 복사하십시오.
<delete dir = "/res/image"/>
● 모든 JAR 파일 또는 빈 디렉토리 삭제 :
다음과 같이 코드 코드를 복사하십시오.
<삭제 includEmptyDirs = "true">
<fileset dir = "." "**/*. jar"
</삭제>
6. mkdir 명령
디렉토리를 만듭니다.
다음과 같이 코드 코드를 복사하십시오.
<mkdir dir = "/home/philander/build/class"/>/>
7. 명령을 이동하십시오
다음과 같이 파일 또는 디렉토리 이동 :
● 단일 파일 이동 :
다음과 같이 코드 코드를 복사하십시오.
<mak file = "source"tofile = "destfile"/>/>
● 단일 파일을 다른 디렉토리로 이동하십시오.
다음과 같이 코드 코드를 복사하십시오.
<mak file = "source"todir = "movenir"/>/>
● 디렉토리를 다른 디렉토리로 이동하십시오.
다음과 같이 코드 코드를 복사하십시오.
<오늘 이동 = "Newdir">
<fileset dir = "Olddir"/>
</mak>
8. 에코 명령
이 작업의 역할은 로그 또는 모니터 수준을 기반으로 정보를 출력하는 것입니다. 메시지, 파일, Apend 및 레벨의 네 가지 속성이 포함됩니다.
<echo message = "ant message"file = "/logs/ant.log"부록 = "true">
9. JAR 태그 노드 요소
이 태그는 JAR 파일을 생성하는 데 사용됩니다.
● DestFile은 JAR 파일의 이름을 나타냅니다.
● Basedir는 보관 된 파일 이름을 나타냅니다.
● 포함되지 않은 파일 모드를 표시합니다.
● 교환은 제외 파일 모드를 나타냅니다.
● 압축은 압축 여부를 나타냅니다.
예:
다음과 같이 코드 코드를 복사하십시오.
<jar destfile = "$ {webroot}/$ {ash_jar}"level = "9"compression = "true"encoding = "utf-8"basedir = "$ {dest}">
<매니페스트>
<속성 이름 = "구현-값 ="버전 : 2.2 "/>
</manifest>
</jar>
위의 메인 페스트는 JAR 패키지의 Meat-Inf에서 Manifest.mf의 파일 내용의 내용입니다.
동일한 포장 작업은 전쟁, TGZ 및 감압 작업 UZIP입니다.
다음과 같이 코드 코드를 복사하십시오.
<!-zip->를 작성하십시오
<zip baseness = "$ {basediir}/class"zipfile = "temp/output.zip"/>/>
<!-tgz->를 작성하십시오
<gzip src = "classses/**/*. 클래스"zipfile = "output.class.gz"/>
<!--Coltage Zip->
<unzip src = "output.class.gz"dest = "ExtractDir"/>
<!-전쟁 패키지 만들기->
<war destfile = "$ {webroot} /ash.war"basedir = "$ {basedir} /web"web "webxml ="$ {basedir} /web/web.xml ">>
<제외 이름 = "web-inf/classs/**"/>
<제외 이름 = "web-inf/lib/**"/>
<제외 이름 = "web-inf/work/_jsp/**"/>
<lib dir = "$ {lib.dir}"포함 = "**/*. jar, **/*. 그래서 **/*. dll">
<제외 이름 = "$ {webroot}/$ {helloorld_jar}"/>
</lib>
<lib file = "$ {webroot}/$ {helloword_jar}"/>
<classs dir = "$ {dest}"포함 = "**/*. xml, **/*. 적절성, **/*. xsd"> </classses>
</war>
10. Javac 태그 노드 요소
레이블은 하나 또는 하나의 Java 파일 그룹을 컴파일하는 데 사용되며 속성은 다음과 같습니다.
● SRCDIR은 소스 프로그램의 디렉토리를 나타냅니다.
● Destdir는 클래스 파일의 출력 디렉토리를 나타냅니다.
● 컴파일 된 파일의 패턴을 나타냅니다.
● 제외는 제외 된 파일의 패턴을 나타냅니다.
● ClassPath는 사용 된 클래스 경로를 나타냅니다.
● 디버그는 디버깅 정보를 나타냅니다.
● 최적화 최적화 여부를 나타냅니다.
● Verbose는 상세한 출력 정보를 나타냅니다.
● FileOnerRor는 오류가 발생했을 때 자동으로 중지되었다고 말했습니다.
예제 사본 코드 코드는 다음과 같습니다.
<javac srcdir = "$ {src}"destdir = "$ {dest}"/>
<!- JVM 메모리를 설정하십시오
<javac srcdir = "src"fork = "true"/>
<javac srcdir = "src"fork = "true"exeblable = "d :/sdk141/bin/javac"
MemoryMaxumSize = "128m"/>
->
11. Java 태그 노드 요소
이 레이블은 컴파일 된 .class 파일을 실행하는 데 사용되며 속성은 다음과 같습니다.
● ClassName은 실행 이름을 나타냅니다.
● JAR 은이 클래스를 포함하는 JAR 파일의 이름을 의미합니다.
● ClassPath는 사용 된 클래스 경로를 표현했습니다.
● 포크는 새로운 가상 머신 에서이 클래스를 실행하는 것을 의미합니다.
● 오류가 발생했을 때 FailOnerror는 자동으로 중지되었다고 말했습니다.
● 출력은 출력 파일을 나타냅니다.
● APEND는 기본 파일을 추가하거나 커버합니다.
예제 사본 코드 코드는 다음과 같습니다.
<java classname = "com.hoo.test.helloworm"classpath = "$ {hello_jar}"/>
12. Arg 데이터 매개 변수 요소
ANT에 의해 호출되는 프로그램은 <RG> 요소를 통해 <RG> 요소를 통해 명령 행 매개 변수를 전달할 수 있으며, 예 : 중첩 <RG> 요소로 수락 할 수있는 적용, exec 및 Java 작업과 같은 각 프로세스에 지정된 매개 변수를 지정할 수 있습니다. . 다음은 <arg>의 모든 속성입니다.
● 값은 명령 매개 변수입니다. 매개 변수에 공간이 있지만 단일 값으로 사용하려면이 속성을 사용하십시오.
● 파일은 매개 변수의 파일 이름을 나타냅니다. 파일을 구성 할 때이 파일의 이름은 현재 작업 디렉토리와 관련이 있습니다.
● 선은 공간으로 분리 된 공간의 여러 매개 변수를 나타냅니다.
● 단일 명령 줄 변수로 사용되는 경로와 같은 문자열을 표현하십시오.
● PathRef 참조 경로 (경로 요소 노드 정의 경로 사용) ID
● 접두사 접두사 ● 접미사 접미사
예제 사본 코드 코드는 다음과 같습니다.
<arg value = "-la -a"/>
공간을 포함하는 단일 명령 줄 변수입니다.
다음과 같이 코드 코드를 복사하십시오.
<arg line = "-la -a"/>
두 개의 공간으로 분리 된 명령 줄 변수입니다.
다음과 같이 코드 코드를 복사하십시오.
<arg path = "/dir;/dir2 :/dir3"/>
그것은 명령 줄 변수이며, 그 값은 dos 시스템에서/dir;/dir2;/dir3;/dir :/dir2 :/dir3입니다.
13. Ericonment 유형
ant가 호출하는 파일이라고 불리는 외부 명령 또는 프로그램은 <env> 요소가 다음 속성을 수용 할 수있는 시스템 명령에 전달 해야하는 환경 변수를 공식화합니다.
● 파일은 주변 값 값의 파일 이름을 나타냅니다. 이 파일의 이름은 변환해야 할 절대 경로입니다.
● 경로는 환경 변수의 경로를 나타냅니다. 개미는이를 지역 계약으로 전환합니다.
● 값은 환경 변수의 직접 변수를 나타냅니다.
● 키는 환경 변수 이름을 의미합니다.
파일 경로 만 가져갈 수있는 파일 경로 또는 값에주의하십시오.
14. FilElist 파일 수집 목록
FilElist는 이름 지정 파일 목록을 지원하는 데이터 유형입니다. 다음은 모든 속성입니다.
● DIR은 절대 파일 이름을 계산하기위한 디렉토리입니다.
● 파일은 쉼표로 구분 된 파일 목록입니다.
● refid는 특정 장소에서 정의 된 <filelist>에 대한 참조입니다.
이 경우에 지정되지 않으면 DIR 및 파일을 사용할 수 없다면 DIR 및 파일이 필요합니다).
예제 사본 코드 코드는 다음과 같습니다.
<filElist id = "docfiles"dir = "$ {doc.src}"files = "foo.xml, bar.xml"/>
파일 수집 $ {doc.src} /foo.xml 및 $ {doc.src} /bar.xml은 여전히 존재하지 않을 수 있습니다.
<filElist id = "docfiles"dir = "$ {doc.src}"files = "foo.xml bar.xml"/>
<filElist refid = "docfiles"/>
<filElist id = "docfiles"dir = "$ {doc.src}">
<file name = "foo.xml"/>
<file name = "bar.xml"/>
</filelist>
15. 파일 세트 파일 유형
파일 세트 데이터 유형은 파일 세트를 정의하며 일반적으로 <fileset> 요소로 표현됩니다. 그러나 많은 개미 작업이 숨겨진 파일 세트를 만들었으며, 이는 모든 파일 세트 속성과 중첩 요소를 지원한다는 것을 보여줍니다. 다음은 파일 세트의 속성 목록입니다.
● DIR은 FilesET의 기본 디렉토리를 나타냅니다.
● 사례의 값이 False 인 경우 파일 이름과 일치하면 파일 세트가 경우와 구별되지 않으며 기본값은 참입니다.
● DefaultexCludes는 기본 제외 모드를 사용할지 여부를 결정하는 데 사용되며 기본값은 참입니다.
● 제외는 쉼표 분리와 함께 전송 해야하는 파일 패턴 목록입니다.
● 제외 파일은 한 줄 당 제외 모드를 포함하는 파일의 파일 이름을 나타냅니다.
● 포함은 쉼표로 구분되며 포함 해야하는 파일 패턴 목록이 포함됩니다.
● 포함 파일은 각 행에 모드가 포함 된 파일 이름이 포함되어 있음을 의미합니다.
예제 사본 코드 코드는 다음과 같습니다.
<fileset id = "lib.runtime"dir = "$ {lib.path}/runtime">
<include name = "**/*. jar"/>
<include name = "**/*. 그래서"/>
<include name = "**/*. dll"/>
</fileset>
<fileset id = "lib.container"dir = "$ {lib.path}/컨테이너">
<include name = "**/*. jar"/>
</fileset>
<fileset id = "lib.extras"dir = "$ {lib.path}">
<nown name = "test/**/*. jar"/>
</fileset>
16. PatternSet 유형
파일 세트는 파일 패킷이며 패턴은 패턴으로 가득 차 있습니다.
<patternset>은 4 가지 속성을 지원합니다 : 포함, inxcexx, includexfile, file set과 동일합니다.
PatternSet은 또한 다음 중첩 요소를 허용합니다. 포함, 제외, 포함 및 제외 및 제외.
예제 사본 코드 코드는 다음과 같습니다.
<!-흑백 목록->
<patternset id = "non.test.sources">
<include name = "**/*. java"/>
<!-파일 이름에는 test->의 제외가 포함되어 있습니다
<제외 이름 = "**/*test*"/>
</patternset>
<patternset id = "소스">
<include name = "std/**/*. java"/>
<!-소개 할 지지기가 있다는 조건을 판단합니다.
<포함 이름 = "prof/**/*. java"if = "professional"/>/>
<제외 이름 = "**/*test*"/>
</patternset>
<!-파일 세트->
<patternset includefile = "some-file"/>
<패턴 세트>
<continludfile name = "some-free"/>
<PatternSet/>
<패턴 세트>
<continludfile name = "some-free"/>
<inclo임시 파일 이름 = "$ {some-meher-file}"if = "some-mean-free"/>
<PatternSet/>
17. 필터셋 유형
FilterSet은 파일이 움직이거나 사본이 이동할 때 파일의 텍스트를 교체하는 필터 세트를 정의합니다.
주요 속성은 다음과 같습니다.
● BegIntoken은 중첩 필터로 검색 된 마크를 표시하며, 이는이를 식별하는 문자열입니다.
● EndToken은 중첩 필터로 검색 된 마크가 끝을 식별하는 문자열임을 나타냅니다.
● ID는 필터의 유일한 로고입니다.
● REFID는 시공 파일 어딘가에 필터에 대한 참조입니다.
예제 사본 코드 코드는 다음과 같습니다.
<!-@date@는 대상 파일의 version.txt 파일 내용에서 오늘의 현재 날짜로@date@로 대체됩니다.
<copy file = "$ {build.dir} /version.txt"tofile = "$ {dist.dir} /version.txt">
<filterset>
<filter token = "date"value = "$ {Today}"/>
</필터 세트>
</copy>
<!-사용자 정의 변수 형식->
<copy file = "$ {build.dir} /version.txt"tofile = "$ {dist.dir} /version.txt">
<!-version.txt의%위치에서*위치 끝까지 검색하고 교체 내용의@date@를 오늘의 현재 날짜 값으로 바꾸십시오.
<filterset begintoken = "%"endtoken = "*">
<filter token = "date"value = "$ {Today}"/>
</필터 세트>
</copy>
<!-외부 필터 정의 파일->를 사용하십시오
<오늘 복사 = "$ {dist.dir}/docs">
<fileset dir = "$ {build.dir}/docs">
<include name = "**/*. html">
</fileset>
<filterset begintoken = "%"endtoken = "*">
<!-파일의 속성과 값은 외부에서 소개됩니다.
<filtersfile file = "$ {user.dir} /dist.properties" />
</필터 세트>
</copy>
<!-참조 방법을 사용하여 필터 세트를 반복적으로 사용하십시오
<filterset id = "myFilterset"begintoken = "%"endToken = "*">
<filter token = "date"value = "$ {Today}"/>
</필터 세트>
<copy file = "$ {build.dir} /version.txt"tofile = "$ {dist.dir} /version.txt">
<filterset refid = "myfilterset"/>
</copy>
18. 경로 유형
경로 요소는 클래스를 나타내는 데 사용되지만 다른 경로를 나타내는 데 사용될 수도 있습니다. 몇 가지 속성으로 사용되면 도로 경전의 다양한 점수 또는 콜론이 분리됩니다. 구성 할 때이 분리기는 현재 플랫폼의 모든 경로 분리기를 대체하며 그 속성은 다음과 같습니다.
● 위치는 파일 또는 디렉토리를 나타냅니다. 개미는 이것을 내부적으로 절대 경로로 확장합니다.
● refid는 현재 건설 파일에 정의 된 경로에 대한 참조입니다.
● 경로는 파일 또는 경로 목록을 나타냅니다.
예제 사본 코드 코드는 다음과 같습니다.
<path id = "buildpath">
<fileset refid = "lib.runtime"/>
<fileset refid = "lib.container"/>
<fileset refid = "lib.extras"/>
</path>
<path id = "src.paths">
<fileset id = "srcs"dir = ".">
<포함 이름 = "src/**/*. java"/>
</fileset>
</path>
8. 포장 및 실행 엔지니어링 컴파일의 코드 코드는 다음과 같습니다.
<? xml 버전 = "1.0"encoding = "utf-8"?>
<!-이름은 현재 프로젝트의 기본 작업입니다.
<project name = "helloorld"default = "run"basedir = ".">
<!-속성은 프로그램의 간단한 변수와 유사합니다.
<propoperty name = "src"value = "src"/>
<속성 이름 = "dest"value = "class"/>
<property name = "hello_jar"value = "helloworld.jar"/>
<!-
Target은 이벤트, 이벤트, 작업, 이름은 현재의 이름이 마지막 또는 여러 가지에 의존하지 않으면 의존성을 먼저 실행 한 다음 현재를 실행합니다.
->
<!-초기화->
<대상 이름 = "init">
<!-클래스 디렉토리->
<mkdir dir = "$ {dest}"/>
<mkdir dir = "temp"/>
<mkdir dir = "temp2"/>
</target>
<!-컴파일->
<target name = "compile"종속 = "init">
<javac srcdir = "$ {src}"destdir = "$ {dest}"/>
<!- JVM 메모리를 설정하십시오
<javac srcdir = "src"fork = "true"/>
<javac srcdir = "src"fork = "true"exeblable = "d :/sdk141/bin/javac"
MemoryMaxumSize = "128m"/>
->
</target>
<!-<< <->
<target name = "build"depends = "compile">
<!-
<jar jarfile = "$ {hello_jar}"basedir = "$ {dest}"/>
package.jar 파일의 이름을 만듭니다
<jar destfile = "package.jar"basedir = "classe"/>
->
<jar destfile = "$ {hello_jar}"basedir = "classses">
<!-JAR 패키지의 기본 파일에 컨텐츠 추가->
<매니페스트>
<속성 이름 = "build-by"value = "$ {user.name}"/>
<속성 이름 = "main-class"value = "package.main"/>/>
</manifest>
</jar>
<!-JAR 파일을 복사하십시오. TODIR = "디렉토리에 복사"->
<copy file = "$ {hello_jar}"tofile = "$ {dest} /temp.jar" />
<copy todir = "test">
<!-defaultexcludes = ""->
<fileset dir = "src">
<include name = "**/*. java"/>
</fileset>
</copy>
<copy todir = "temp2">
<fileset dir = "src">
<and>
<텍스트 포함 = "main"/>
<size value = "1"way = "more"/>
</and>
</fileset>
</copy>
<!-모바일 JAR 파일->
<mak file = "$ {dest} /temp.jar"tofile = "temp/move-temp.jar"/>
<!-zip->를 작성하십시오
<zip baseness = "$ {basediir}/class"zipfile = "temp/output.zip"/>/>
<!-tgz->를 작성하십시오
<gzip src = "classses/**/*. 클래스"zipfile = "output.class.gz"/>
<!--Coltage Zip->
<unzip src = "output.class.gz"dest = "ExtractDir"/>
<! --- input.txt 컨텐츠의 내용을 새로 교체하십시오.
<file = "input.txt"token = "Old"value = "new"/>
->
</target>
<! --- run->
<target name = "run"종속 = "build">
<java classname = "com.hoo.test.helloworm"classpath = "$ {hello_jar}"/>
</target>
<!-클리어->
<대상 이름 = "Clear">
<!-생성 된 파일을 삭제했습니다
<delete dir = "$ {dest}"/>
<delete file = "$ {hello_jar}"/>
</target>
<tstamp>
<형식 속성 = "오프셋 _time"
Pattern = "HH : MM : SS"
오프셋 = "10"init = "minute"/>
</tstamp>
<!-재시작->
<target name = "raun"은 = "clean, run"에 따라 다릅니다
<echo message = "### $ {tstamp}#$ {today}#$ {dstamp} ###"/>
<좋아하는 대상 = "깨끗한"/>
<좋아하는 대상 = "run"/>
</target>
</project>
기본적으로 할 말이 너무 많습니다. ANT는 어렵지 않습니다. Docs 콘솔에서 명령 줄을 입력하는 데 사용하지만 ANT는 명령 줄을 XML로 변환하는 스크립트 정보입니다. 특정 상황에서 효율성과 반복 작업이 개선되었습니다.