> Java > java지도 시간 > 본문

Java API 개발에서 웹 템플릿 엔진 처리를 위해 FreeMarker 사용

PHPz
풀어 주다: 2023-06-18 08:39:54
원래의
1616명이 탐색했습니다.

인터넷의 급속한 발전과 함께 웹 애플리케이션의 개발이 점점 더 보편화되었습니다. 웹 애플리케이션을 더 읽기 쉽고 유지 관리하기 쉽게 만들기 위해 개발자는 뷰 렌더링을 위해 웹 템플릿 엔진을 사용하는 경우가 많습니다. Java 개발에는 널리 사용되는 웹 템플릿 엔진이 많이 있으며 FreeMarker는 그 중 하나입니다.

이 기사에서는 FreeMarker 웹 템플릿 엔진과 핵심 기능, 구성 및 실제 전투에서의 적용을 포함하여 Java API 개발에서의 사용을 소개합니다.

1. FreeMarker란 무엇입니까

FreeMarker는 템플릿 기반 방법을 사용하여 정적 텍스트 또는 동적 웹 페이지를 생성하는 오픈 소스 Java 템플릿 엔진입니다. 그 특징은 템플릿과 프로그램 코드의 분리로, 성능과 로직 사이의 경계를 명확하게 하고, 페이지 렌더링과 비즈니스 로직을 분리하며, 코드의 가독성과 유지 관리성을 향상시킵니다. FreeMarker는 텍스트 템플릿, XML 템플릿, HTML 템플릿, JSP 태그 라이브러리 등과 같은 다양한 템플릿 유형을 지원하며 Struts2, Spring MVC 등과 같은 다양한 웹 프레임워크와 통합될 수 있습니다.

FreeMarker에는 다음과 같은 기능이 있습니다.

  1. 관점의 분리: 템플릿 파일은 내장된 비즈니스 로직 코드 없이 페이지의 표시 효과와 프런트엔드 사용자의 대화형 동작만 정의합니다.
  2. 강력한 유형 지원: JSP와 비교하여 FreeMarker는 강력한 유형 지원 기능을 갖추고 있어 컴파일 타임에 유형 오류를 확인하고 런타임 오류를 줄이는 데 도움이 됩니다.
  3. 다양한 템플릿 파일 형식: FreeMarker는 HTML, XML 및 JSON을 포함하되 이에 국한되지 않는 다양한 템플릿 파일 형식의 처리를 지원합니다.
  4. 호환성: FreeMarker는 다양한 웹 프레임워크에 통합될 수 있으며 SpringMVC, Struts2 및 기타 프레임워크에서 널리 사용됩니다.

2. FreeMarker API 사용

FreeMarker는 템플릿을 생성하는 데 사용할 수 있는 다양한 API를 제공합니다. 다음으로 FreeMarker API를 설정하고 사용하는 방법을 보여줍니다.

  1. FreeMarker의 종속성 패키지 소개

먼저 프로젝트의 pom에 FreeMarker의 종속성을 추가해야 합니다. 템플릿을 로드하려면 다음 코드 예제를 참조하세요.

    <dependency>
        <groupId>org.freemarker</groupId>
        <artifactId>freemarker</artifactId>
        <version>2.3.31</version>
    </dependency>
로그인 후 복사
    그 중 VERSION_2_3_28은 FreeMarker 버전 번호이고, setClassForTemplateLoading() 메소드는 FreeMarker가 템플릿을 로드할 경로를 설정합니다.
데이터 모델 설정

다음으로 템플릿의 입력 데이터를 설정해야 합니다. FreeMarker에서 이 배경은 지도이며 이 지도에는 템플릿에서 사용하려는 모든 데이터가 포함되어야 합니다. SimpleHash 유형을 사용하여 이 맵을 생성할 수 있습니다.

Configuration configuration = new Configuration(Configuration.VERSION_2_3_28);
configuration.setClassForTemplateLoading(YourClass.class, "templates");
로그인 후 복사
    이 예에서는 "title"을 키로, "FreeMarker example"을 값으로 입력에 추가했습니다.
템플릿 로드 및 렌더링

마지막으로 템플릿을 로드하고 입력 데이터를 템플릿에 렌더링해야 합니다. 다음 코드 예제를 참조하세요.

Map<String, Object> input = new HashMap<String, Object>();
input.put("title", "FreeMarker Example");
로그인 후 복사
    이 예제에서는 "example.ftl"이 템플릿입니다. 파일을 로드하는 데는configuration.getTemplate() 메서드를 사용하고, 입력의 데이터를 템플릿에 렌더링하는 데는 template.process() 메서드를 사용하고, 마지막으로 출력을 통해 출력합니다.
FreeMarker 템플릿 구문

FreeMarker 템플릿 구문은 템플릿 태그, 내장 형식 및 메서드를 정의합니다. 템플릿 마커는 ${} 또는 <% %> 태그 쌍의 FreeMarker 템플릿 코드로 구성된 템플릿의 지시문입니다.

    다음은 몇 가지 FreeMarker 마커입니다.
${...}: FreeMarker 표현식에는 합법적인 Java 표현식이 포함될 수 있습니다.

<% ... %>: 원본 템플릿 태그가 포함되어 있습니다.

<@...>..: 집계 템플릿 조각을 나타냅니다.
  1. #...#list..#할당...#recover...#stop: 템플릿 인스턴스의 원본 태그를 조작하고 제어합니다.
  2. <#macro...>...<#nested>: 재사용 가능한 템플릿 블록을 정의합니다.
  3. 3. FreeMarker의 적용 예
  4. 아래에서는 FreeMarker를 사용하여 Java API 개발에서 템플릿을 작성하는 방법을 보여줍니다.
템플릿 파일 작성

먼저 FreeMarker 템플릿 파일을 작성해야 합니다(예: test.ftl:

Template template = configuration.getTemplate("example.ftl");
Writer out = new OutputStreamWriter(System.out);
template.process(input, out);
out.flush();
로그인 후 복사
    이 예에서는 ${...} 태그를 사용하여 데이터를 참조합니다) 입력, <#list ...> 태그를 사용하여 사용자를 반복하고 각 사용자로부터 이름 및 이메일 속성을 얻습니다.
데이터 모델 설정 및 템플릿 로드

그런 다음 데이터 모델을 설정해야 합니다. 다음 코드 예제를 참조하세요.

<html>
<head>
<title>${title}</title>
</head>
<body>
<h1>${title}</h1>
<ul>
<#list users as user>
<li>${user.name} (${user.email})</li>
</#list>
</ul>
</body>
</html>
로그인 후 복사
    이 예제에서는 맵을 생성할 때 User라는 JavaBean 클래스를 생성했습니다. , userList를 키로 추가하고 List 참조를 입력 값으로 추가합니다.
  1. 3. 요약

이 글에서는 FreeMarker 웹 템플릿 엔진과 Java API 개발에서의 사용법을 소개합니다. FreeMarker는 코드 가독성과 유지 관리성을 향상시키면서 웹 애플리케이션 개발을 더 쉽게 만듭니다. FreeMarker의 핵심 기능과 구성, 실제 적용 사례를 설명함으로써 독자들이 FreeMarker를 더 잘 이해하고 적용할 수 있도록 돕기를 바랍니다.

위 내용은 Java API 개발에서 웹 템플릿 엔진 처리를 위해 FreeMarker 사용의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿