인터넷상에서는 이 문제에 대해 다양한 의견이 있습니다. 개인적인 이해와 온라인 의견을 바탕으로 다른 분들의 편의를 위해 jar 패키지로 포장하였습니다. Java 프로그램을 실행하는 경우 실행할 기본 메서드가 포함된 클래스를 찾을 필요가 없습니다. 타사 jar 패키지를 사용하는 경우 여러 파일을 복사하는 대신 jar 패키지를 자신의 프로젝트로 직접 가져옵니다. 클래스 파일. war 패키지를 구축하는 것은 실제 프로덕션 환경에서 선택하는 웹 애플리케이션 배포 방법으로, 이 방법은 폴더를 직접 복사하는 것처럼 파일 손실이 발생하지 않으며 서버는 빈 폴더를 삭제하는 등 애플리케이션을 최적화한다고 합니다. 위의 내용은 정보용일 뿐입니다.
로컬 환경은 windows 10, jdk 1.8
jar 또는 war 패키지를 만드는 데 동일한 도구가 사용됩니다. jdk/bin/jar.exe
프로젝트 소개데이터베이스 테이블 구조와 테이블 생성문
CREATE TABLE `customer` ( `cust_id` int(11) NOT NULL AUTO_INCREMENT, `cust_name` char(50) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL, `cust_address` char(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL, `cust_city` char(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL, `cust_state` char(5) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL, `cust_zip` char(10) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL, `cust_country` char(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL, `cust_contact` char(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL, `cust_email` char(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL, PRIMARY KEY (`cust_id`) USING BTREE ) ENGINE = InnoDB AUTO_INCREMENT = 10006 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Compact; INSERT INTO `customer` VALUES (10001, 'Coyote Inc.', '200 Maple Lane', 'Detroit', 'MI', '44444', 'china', 'Y Lee', 'ylee@coyote.com'); INSERT INTO `customer` VALUES (10002, 'Mouse House', '333 Fromage Lane', 'Columbus', 'OH', '43333', '', 'Jerry Mouse', NULL); INSERT INTO `customer` VALUES (10003, 'Wascals', '1 Sunny Place', 'Muncie', 'IN', '42222', 'USA', 'Jim Jones', 'rabbit@wascally.com'); INSERT INTO `customer` VALUES (10004, 'Yosemite Place', '829 Riverside Drive', 'Phoenix', 'AZ', '88888', 'UK', 'Y Sam', 'sam@yosemite.com'); INSERT INTO `customer` VALUES (10005, 'gzn or 1=1', '4545 53rd Street', 'Chicago', 'IL', '54545', '', 'E Fudd', NULL);프로젝트 구조 app.java
package com.gzn.demo; import java.sql.*; import java.util.Scanner; /** * @author: gzn * @date: 2019/4/13 10:53 */ public class App { public static void main(String[] args) { int count = Integer.valueOf(args[0]); System.out.println("请输入要查询用户的条数?(0到5之间):"); Scanner sc = new Scanner(System.in); int count = sc.nextInt(); String driver = "com.mysql.jdbc.Driver"; String url = "jdbc:mysql://localhost:3306/corejava"; String username = "root"; String password = "root"; String sql = "select cust_id, cust_name, cust_address, cust_city from customer limit 0, ? "; try { Class.forName(driver); Connection conn = DriverManager.getConnection(url, username, password); PreparedStatement pstat = conn.prepareStatement(sql); pstat.setInt(1, count); ResultSet rs = pstat.executeQuery(); while(rs.next()) { System.out.println("cust_id:" + rs.getObject("cust_id").toString()); System.out.println("cust_name: " + rs.getObject("cust_name").toString()); System.out.println("cust_address: " + rs.getObject("cust_address").toString()); System.out.println("cust_city:" + rs.getObject("cust_city").toString()); System.out.println("----------------------" +"\n"); } } catch (ClassNotFoundException e) { e.printStackTrace(); } catch (SQLException e) { e.printStackTrace(); } } }|------- --------- --------------- --------- --------|1.1, jar를 사용하여 수동으로 패키징(1) cmd를 사용하여 프로젝트 컴파일 출력 경로 찾기 (2) 이 디렉터리에서 명령을 실행합니다
jar -cvf helloworld.jar .
-v(상세, 길이, 상세) 콘솔에 압축 세부 정보 인쇄
-f(파일 이름)는 압축된 파일을 지정합니다 파일 이름
helloworld.jar 파일 이름은 사용자 지정할 수 있습니다
. helloworld 디렉터리에 있는 모든 파일을 나타냅니다. 여기에 "."를 적어야 합니다. 그렇지 않으면 오류가 발생할 수 있습니다. (보충, *별표도 가능합니다.)
MANIFEST.MF 파일을 수정해야 합니다.
(3) 압축 해제 도구를 사용하여 helloword.jar을 열고 META-INF/MANIFEST.MF를 편집하여 속성을 추가합니다. MANIFEST.MF 초기 상태Manifest-Version: 1.0 Created-By: 1.8.0_161 (Oracle Corporation)속성 추가: (
콜론은 영어 콜론이고 콜론 뒤에 공백이 있습니다 )
Main-Class: 메인 메소드가 포함된 클래스
Class-Path: 종속 jar 패키지의 경로가 여러 jar 패키지에 종속되는 경우 공백을 사용하여 구분하세요. 경로: 상대 경로, jar 패키지는 helloworld.jar 파일의 경로 절대 경로, 운영 체제의 jar 패키지 경로
일반적으로 사용되는 상대 경로, 종속 jar 패키지와 자신의 jar 패키지를 넣습니다. 동일한 레벨 디렉토리에 있으므로 Class-Path는 종속 jar 패키지 이름을 직접 작성합니다.
속성 추가 후 상태:
Manifest-Version: 1.0 Created-By: 1.8.0_161 (Oracle Corporation) Class-Path: mysql-connector-java-5.1.18.jar Main-Class: com.gzn.demo.App
(4) 테스트 실행
helloworld.jar과 동일한 디렉터리에 종속성을 복사하고 java -jar helloworld.jar을 사용하여 프로그램을 실행합니다.jar 패키지가 다른 개발자 전용이고 실행할 필요가 없는 경우 (2)단계로 진행하세요.
1. 2. IDEA를 사용하여 패키징
Main Class: 대상 JAR로 추출합니다.
: 대상 jar를 추출합니다. 종속 jar 절대 경로를 구성합니다. 출력 디렉터리에 복사하고 매니페스트를 통해 연결
: 종속 jar를 프로젝트에서 패키지한 jar와 동일한 수준 디렉터리인 출력 디렉터리에 복사합니다. 이러한 방식으로 IDEA는 MENIFEST.MF의 Class-Path 속성에 대한 상대 경로를 직접 구성할 수 있습니다.
출력 디렉터리: 패키지된 출력 경로.
테스트 실행:
首先进入jar包输入路径C:\Users\gzn\Desktop\helloworld\out\artifacts\HelloWorld_jar;
运行 java -jar helloworld.jar;
comment是我的一个已将编译好的web项目,使用cmd进入comment目录下执行命令
jar -cvf comment.war .
注意在项目目录下执行命令, “.” 表示对项目目录下的所有文件进行打包,将打包好的项目复制到Tomcat/webapps目录下,启动Tomcat服务器,就可以进行测试了。
위 내용은 Java 또는 Java 웹 프로젝트를 JAR 패키지 또는 WAR 패키지로 패키징하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!