목차
원인
대상
코드 프레임워크
디자인 아이디어
코드 디자인
프로젝트 구조
구성 파일 예시
실행 명령 예시
시연예" >시연예
Java java지도 시간 Java 웹 템플릿 코드 생성기의 설계 및 구현에 대한 자세한 설명

Java 웹 템플릿 코드 생성기의 설계 및 구현에 대한 자세한 설명

Mar 18, 2017 am 10:32 AM

원인

프로젝트에서 메타, 다오, 서비스 코드 중 상당수는 데이터베이스 테이블을 기반으로 작성해야 하는데, 그 중 상당수가 반복적이고 번거롭다. 따라서 템플릿 코드에 대한 생성기가 있다면 어느 정도 개발 효율성을 높일 수 있습니다.

대상

Java 웹 프로젝트에서 Dao, Meta 및 서비스 레이어 템플릿 코드를 생성하도록 구성 가능한 생성기입니다.

코드 프레임워크

mvn archetype:generate 
-DgroupId=com.zju 
-DartifactId=JavaWebCodeGenerator 
-DarchetypeArtifactId=maven-archetype-webapp 
-DinteractiveMode=false 
-DarchetypeCatalog=internal
로그인 후 복사

디자인 아이디어

이 프로젝트는 Mybatis 생성기를 사용하여 코드를 생성하는 프로세스를 의미하며 구체적인 단계는 다음 5단계로 구분됩니다.

논리 단계

  1. 명령줄 구문 분석

  2. 구성 파일 구문 분석

  3. 데이터 테이블 정보 가져오기

  4. 구성 정보 생성

  5. 파일 생성

코드 디자인

명령 구문 분석 클래스 ShellRunner

이 클래스는 명령줄 명령 구문 분석, 구성 파일 구문 분석 및 필수 항목 캡슐화를 담당합니다. 데이터를 코드 생성 클래스로 보냅니다.

분석 가능한 명령은 -config<a href="http://www.php.cn/wiki/1313.html" target="_blank">file<code>-config<a href="http://www.php.cn/wiki/1313.html" target="_blank">file</a>입니다. : 구성 파일이 있는 경로를 지정하고 -overwrite: 대상 파일을 다시 쓸지 여부를 지정합니다.

구성 파일의 구성 항목은 다음과 같습니다.

//Java SQL 驱动所在路径(暂未使用)
private static final String CLASS_PATH_ENTRY = "class.path.entry";
//Java 驱动类型(暂未使用)
private static final String DRIVER_CLASS = "driver.class";
//数据库地址
private static final String CONNECTION_URL = "connection.url";
//数据库用户名
private static final String USER_ID = "user.id";
//数据库密码
private static final String USER_PASSWORD = "user.password";
//模型生成地址
private static final String JAVA_MODEL_PACKAGE = "java.model.package";
//SQL生成地址
private static final String SQL_MAPPING_PACKAGE = "sql.mapping.package";
//项目地址
private static final String PROJECT = "project";
//数据表名
private static final String TABLE_NAME = "table.name";
//模型名称
private static final String DOMAIN_OBJECT_NAME = "domain.object.name";
로그인 후 복사

코드 생성 클래스 CodeGenerator

이 클래스는 데이터베이스에 연결하고 데이터 테이블의 테이블 정보와 SQL 유형을 Java 유형에 매핑하고 필요한 데이터를 파일 생성 클래스에 캡슐화합니다.

Class.forName(configuration.getDriverClass());
//获取数据库连接
Connection connection = DriverManager.getConnection(configuration.getConnectionURL(), 
configuration.getUserId(), 
configuration.getPassword());
DatabaseMetaData databaseMetaData = connection.getMetaData();
//获取表结构信息
ResultSet rs = databaseMetaData.getColumns("", "", configuration.getTableName(), "%");
로그인 후 복사

위의 코드를 통해 rs 변수에 대상 데이터 테이블의 테이블 정보를 가져왔습니다.

databaseMetaData.getColumns 메서드의 핵심은 SELECT * FROM information_schema.COLUMNS WHERE TABLE_NAME="tableName" 문을 실행하는 것입니다.

결과 집합에서 후속 처리에는 일반적으로 다음 테이블 정보 열이 필요합니다.

< td>NULLABLE< / table>

JavaTypeResolver의 타입 매핑(Map<Integer, JdbcTypeInformation> typeMap)과 StringUtils의 카멜 케이스 네이밍 변환(getCamelCaseString)을 통해 최종적으로 SQL 정보를 Java 정보로 변환한다.

파일 생성 클래스 FileGenerator

이 클래스는 FreeMarker템플릿 엔진을 통해 데이터를 대상 코드 파일로 결합합니다.

주요 논리는 다음과 같습니다.

/**
* @param configuration 封装的配置信息
* @param columns       封装的数据表列信息
* @throws IOException
* @throws TemplateException
*/
public static void writeFile(Configuration configuration, List<TableColumn> columns) throws IOException, 
TemplateException {
    File r=new File("");
    //测试环境获取项目根目录路径
    //String path=Class.class.getClass().getResource("/").getPath();
    //Jar包获取根目录路径
    String path=r.getAbsolutePath();
    //System.out.println("path:"+path);
    Configuration cfg = new Configuration();
    cfg.setDirectoryForTemplateLoading(new File(path + "/ftl")); //需要文件夹绝对路径
    cfg.setDefaultEncoding("UTF-8");
    cfg.setTemplateExceptionHandler(TemplateExceptionHandler.RETHROW_HANDLER);
    Map root = new HashMap();
    root.put("configuration", configuration);
    root.put("columnList", columns);
    writeSingleFile(cfg, root, "DaoImpl.ftl", 
    configuration.getProjectPath(), 
    configuration.getSqlMappingPackage().replace(".", "/"), 
    configuration.getDomainObjectName(), "DaoImpl.java",configuration.getOverwrite());
    writeSingleFile(cfg, root, "Dao.ftl", 
    configuration.getProjectPath(), 
    configuration.getSqlMappingPackage().replace(".", "/"), 
    configuration.getDomainObjectName(), "Dao.java",configuration.getOverwrite());
    writeSingleFile(cfg, root, "Meta.ftl", 
    configuration.getProjectPath(), 
    configuration.getJavaModelPackage().replace(".", "/"), 
    configuration.getDomainObjectName(), ".java",configuration.getOverwrite());
}
로그인 후 복사

참고

테스트에서는 Class.class.getClass().getResource("/").getPath();이 방법으로 프로젝트 루트 디렉터리를 가져올 수 있지만 테스트에서 생성된 Jar 패키지를 사용하는 경우 이 방법은 시기적절합니다. 따라서 Jar 패키지를 생성하기 전에 이 줄을 new File("").getAbsolutePath();으로 수정하여 생성 경로를 얻어야 합니다.

프로젝트 구조

Java 웹 템플릿 코드 생성기의 설계 및 구현에 대한 자세한 설명

구성 파일 예시

generatorConfig.properties

class.path.entry=src/test/resources/mysql-connector-java-5.1.38.jar
driver.class=com.mysql.jdbc.Driver
connection.url=jdbc:mysql://localhost:3307/work
user.id=
user.password=
java.model.package=com.model
sql.mapping.package=com.dao
project=src
table.name=holiday
domain.object.name=Holiday
로그인 후 복사

실행 명령 예시

java -jar JavaWebCodeGenerator.jar -configfile generatorConfig.properties -overwrite
로그인 후 복사

시연예

Java 웹 템플릿 코드 생성기의 설계 및 구현에 대한 자세한 설명

위 내용은 Java 웹 템플릿 코드 생성기의 설계 및 구현에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

AI 신분증 사진 생성기: 실제 테스트에서 AI 소프트웨어가 독특하고 강력한 성능을 입증했습니다. AI 신분증 사진 생성기: 실제 테스트에서 AI 소프트웨어가 독특하고 강력한 성능을 입증했습니다. Aug 09, 2023 pm 07:33 PM

실제 테스트 결과, AI ID 사진 생성기는 좋은 성능을 발휘했으며 그 강력한 기능은 정말 놀랍습니다. 더 이상 사진 촬영에 대해 걱정할 필요가 없습니다! 이 문장은 다음과 같이 재작성됩니다. Chuzhan AI 소프트웨어 사용(저작권 및 해석 권한은 Chuzhan AI에 속하며 생성된 효과를 표시하는 데에만 사용됩니다) 스케치 모드: 일상적인 작업이든 비즈니스 사무실 상황이든 전문적인 이미지가 중요합니다. 아름다운 증명사진은 전문적인 이미지를 더욱 돋보이게 할 수 있습니다. AI가 생성한 신분증 사진은 전통적인 사진 표준을 충족할 뿐만 아니라 개인의 독특한 얼굴 특징을 복원할 수도 있습니다. AI 기술은 얼굴 윤곽, 피부색, 조명 등 다양한 세부 사항을 지능적으로 식별하고 가장 적합한 증명사진을 생성할 수 있습니다. 외모나 기질에 관계없이 완벽하게 디스플레이되어 사람들에게 깊은 첫인상을 남길 수 있습니다. AI는 한 번의 클릭으로 신분증 사진을 생성합니다.

Java를 사용하여 간단한 학생 성과 보고서 생성기를 작성하는 방법은 무엇입니까? Java를 사용하여 간단한 학생 성과 보고서 생성기를 작성하는 방법은 무엇입니까? Nov 03, 2023 pm 02:57 PM

Java를 사용하여 간단한 학생 성과 보고서 생성기를 작성하는 방법은 무엇입니까? 학생 성과 보고서 생성기는 교사나 교육자가 학생 성과 보고서를 신속하게 생성하는 데 도움이 되는 도구입니다. 이 기사에서는 Java를 사용하여 간단한 학생 성과 보고서 생성기를 작성하는 방법을 소개합니다. 먼저 학생 개체와 학생 성적 개체를 정의해야 합니다. 학생 객체에는 학생의 이름, 학번 등의 기본 정보가 포함되고, 학생 점수 객체에는 학생의 과목 점수, 평균 성적 등의 정보가 포함됩니다. 다음은 간단한 학생 개체의 정의입니다.

최고의 무료 AI 애니메이션 아트 생성기 최고의 무료 AI 애니메이션 아트 생성기 Feb 19, 2024 pm 10:50 PM

최고의 무료 AI 애니메이션 아트 생성기를 찾고 싶다면 검색을 종료할 수 있습니다. 애니메이션 예술의 세계는 독특한 캐릭터 디자인, 매혹적인 색상, 매혹적인 줄거리로 수십 년 동안 관객을 사로잡았습니다. 그러나 애니메이션 아트를 만드는 데는 재능과 기술, 그리고 많은 시간이 필요합니다. 그러나 인공 지능(AI)의 지속적인 발전으로 이제 최고의 무료 AI 애니메이션 아트 생성기의 도움으로 복잡한 기술을 탐구할 필요 없이 애니메이션 아트의 세계를 탐험할 수 있습니다. 이것은 당신의 창의력을 발휘할 수 있는 새로운 가능성을 열어줄 것입니다. AI 애니메이션 아트 생성기란 무엇입니까? AI 애니메이션 아트 생성기는 정교한 알고리즘과 기계 학습 기술을 활용하여 광범위한 애니메이션 작품 데이터베이스를 분석합니다. 이러한 알고리즘을 통해 시스템은 다양한 애니메이션 스타일을 학습하고 식별합니다.

PHP7의 생성기: 대규모 데이터를 효율적으로 처리하고 메모리를 절약하는 방법은 무엇입니까? PHP7의 생성기: 대규모 데이터를 효율적으로 처리하고 메모리를 절약하는 방법은 무엇입니까? Oct 20, 2023 pm 04:42 PM

PHP7의 생성기: 대규모 데이터를 효율적으로 처리하고 메모리를 절약하는 방법은 무엇입니까? 개요: PHP7은 대규모 데이터 처리 및 메모리 절약 측면에서 강력한 도구로 생성기를 도입합니다. 생성기는 PHP 언어의 특수한 유형의 함수입니다. 일반 함수와 달리 생성기는 모든 결과를 한 번에 반환하는 대신 실행을 일시 중지하고 중간 결과를 반환할 수 있습니다. 따라서 생성기는 대량의 데이터를 처리하고, 메모리 사용량을 줄이고, 처리 효율성을 높이는 데 이상적입니다. 이 기사에서는 학생들을 소개합니다.

PHP를 통해 간단한 QR 코드 생성기를 작성하는 방법 PHP를 통해 간단한 QR 코드 생성기를 작성하는 방법 Sep 24, 2023 am 08:49 AM

PHP를 통해 간단한 QR 코드 생성기를 작성하는 방법 QR 코드는 현대 사회에서 매우 보편화되었으며 정보를 빠르게 전송하고 사용자 경험을 향상시킬 수 있습니다. 이 기사에서는 PHP를 사용하여 간단한 QR 코드 생성기를 작성하는 방법을 소개하겠습니다. 1. 필요한 도구와 라이브러리 설치 시작하기 전에 다음 도구와 라이브러리가 설치되어 있는지 확인해야 합니다. PHP: 최신 버전의 PHP가 설치되어 있는지 확인하세요. php를 실행하여 현재 PHP 버전을 확인할 수 있습니다. -v 명령. 작곡:C

PHP7의 생성기: 대용량 데이터와 지연 로딩을 효율적으로 처리하는 방법은 무엇입니까? PHP7의 생성기: 대용량 데이터와 지연 로딩을 효율적으로 처리하는 방법은 무엇입니까? Oct 27, 2023 pm 07:31 PM

생성기(Generator) 개념은 PHP7에서 도입되었으며, 대용량 데이터와 지연 로딩을 효율적으로 처리할 수 있는 방법을 제공합니다. 이 기사는 특정 코드 예제와 결합된 개념과 원리로 시작하여 PHP7에서 생성기의 사용법과 장점을 소개합니다. 생성기는 모든 데이터를 한 번에 반환하는 대신 요청 시 데이터를 생성하는 특수 함수입니다. 함수가 Yield 문을 실행하면 현재 생성된 값이 반환되고 함수의 상태가 저장됩니다. 다음에 생성기 함수가 호출되면 함수는

ChatGPT를 사용하여 몇 초 만에 대규모 모델을 구축하세요! OpenAI의 새로운 플러그인은 놀랍습니다. 코드 해석기에 연결하고 한 번의 클릭으로 얻을 수 있습니다 ChatGPT를 사용하여 몇 초 만에 대규모 모델을 구축하세요! OpenAI의 새로운 플러그인은 놀랍습니다. 코드 해석기에 연결하고 한 번의 클릭으로 얻을 수 있습니다 Apr 04, 2023 am 11:30 AM

ChatGPT가 인터넷에 연결되면 OpenAI는 이 플러그인의 지원을 통해 자체 기계 학습 모델도 생성할 수 있는 코드 생성기를 신속하게 도입했습니다. 지난 금요일, OpenAI는 ChatGPT가 인터넷에 연결되고 타사 플러그인에 연결할 수 있다는 충격적인 소식을 발표했습니다! 타사 플러그인 외에도 OpenAI는 자체 플러그인 "Code Interpreter"를 도입하고 몇 가지 특수 사용 사례를 제공했습니다. 또한 Greg Brockman은 ChatGPT가 업로드된 비디오 파일도 처리할 수 있음을 보여주었습니다. 그리고 Andrew Mayne이라는 베스트셀러 작가도 있습니다.

Python에서 반복자와 생성자의 차이점은 무엇입니까? Python에서 반복자와 생성자의 차이점은 무엇입니까? Oct 20, 2023 pm 07:10 PM

Python에서 반복자와 생성자의 차이점은 무엇입니까? Python 프로그래밍에서 반복자와 생성기는 반복 가능한 객체를 처리하는 데 사용되는 도구입니다. 둘 다 데이터를 탐색하는 데 사용할 수 있지만 구현에는 약간의 차이가 있습니다. 반복자는 반복자 프로토콜을 구현하는 객체입니다. 반복자 객체에는 __iter__() 및 __next__()라는 두 가지 메서드가 포함되어야 합니다. 저것

See all articles
필드설명
DATA_TYPE데이터 유형
字段描述
DATA_TYPE数据类型
COLUMN_SIZE数据长度
COLUMN_NANE列名
NULLABLE是否允许非空
DECIMAL_DIGITS小数位数
REMARKS备注
COLUMN_DEF默认值
COLUMN_SIZE데이터 길이
COLUMN_NANE열 이름
null이 아닌 값이 허용되는지 여부
DECIMAL_DIGITS십진수
설명설명
COLUMN_DEF기본값