JasperReports-국제화
때로는 다른 언어로 된 보고서가 필요합니다. 각기 다른 언어에 대해 동일한 보고서를 작성하는 것은 많은 중복 작업을 의미합니다. 언어마다 다른 텍스트 조각 만 별도로 작성하고 로케일 설정에 따라 런타임에 텍스트 요소에로드해야합니다. 이것이 보고서 국제화의 목적입니다. 한 번 작성된 국제화 된 보고서는 모든 곳에서 실행할 수 있습니다.
다음 단계에서는 다른 언어로 보고서를 생성하는 방법과 보고서 국제화의 다른 기능을 나열했습니다.
리소스 번들 java.util.ResourceBundle 을 보고서 템플릿과 연결합니다. java.util.ResourceBundle 오브젝트를 보고서 템플리트와 연관시키는 두 가지 방법이 있습니다.
디자인 타임에 보고서 템플릿 개체 의 resourceBundle 속성을 대상 리소스 번들의 기본 이름으로 설정합니다.
보고서 작성 시간에 REPORT_RESOURCE_BUNDLE 매개 변수의 값으로 java.util.ResourceBundle 오브젝트를 제공하여 동적 / 런타임 연관을 작성할 수 있습니다 .
현재 보고서와 다른 로케일로 보고서를 생성해야하는 경우 기본 제공 REPORT_LOCALE 매개 변수를 사용하여 보고서를 채울 때 런타임 로케일을 지정할 수 있습니다.
보고서 국제화를 촉진하기 위해 특수 구문 $R{}보고서 와 관련된 java.util.ResourceBundle 객체 내에 배치 된 java.lang.String 리소스 를 참조하기 위해 보고서 표현식 내에서 사용할 수 있습니다 . 그만큼$R{} 문자 구문은 대괄호 사이에 넣어야하는 키를 기반으로 자원 번들에서 로케일 특정 자원을 추출합니다.
<textFieldExpression>
$R{report.title}
</textFieldExpression>
위의 텍스트 필드는 런타임 제공 로케일 및 report.title 키를 기반으로 보고서 템플리트와 연관된 자원 번들에서 문자열 값을 추출하여 보고서 제목을 표시합니다 .
보고서 로케일에 따라 다른 언어로 메시지 형식을 지정하면 보고서 net.sf.jasperreports.engine.fill.JRCalculator 내부에 내장 메소드가 있습니다 . 이 메소드는 java.text.MessageFormat 클래스 와 유사한 기능을 제공합니다 . 이 메소드 msg ()에는 메시지에서 최대 3 개의 메시지 매개 변수를 사용할 수있는 세 가지 편리한 서명이 있습니다.
내장 된 STR () 메소드 리포트 로케일에 기초하여 상기 리소스 번들 콘텐츠에 대한 액세스를 제공한다 (R은 $ 보고서 내부 식 {} 문법 상당).
날짜 및 시간 형식화의 경우 내장 REPORT_TIME_ZONE 매개 변수를 사용하여 적절한 시간 변환을 보장 할 수 있습니다.
생성 된 출력에서 라이브러리는 텍스트 실행 방향에 대한 정보를 유지하므로 오른쪽에서 왼쪽으로 쓰는 언어 (예 : 아랍어 및 히브리어)로 생성 된 문서가 제대로 렌더링 될 수 있습니다.
애플리케이션이 내장 된 Swing 뷰어를 사용하여 생성 된 보고서를 표시하는 경우 표시되는 도구 설명 또는 기타 텍스트 버튼을 조정하여 국제화해야합니다. 뷰어가 로케일 별 정보를 추출하기 위해 미리 정의 된 자원 번들에 의존하기 때문에 이것은 매우 쉽습니다. 이 자원 번들의 기본 이름은 net.sf.jasperreports.view.viewer입니다.
예
국제화를 설명하기 위해 새 보고서 템플릿 (jasper_report_template.jrxml)을 작성해 보겠습니다. JRXML의 내용은 다음과 같습니다. C : \ tools \ jasperreports-5.0.1 \ test 디렉토리에 저장하십시오.
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE jasperReport PUBLIC "//JasperReports//DTD Report Design//EN"
"http://jasperreports.sourceforge.net/dtds/jasperreport.dtd">
<jasperReport xmlns = "http://jasperreports.sourceforge.net/jasperreports"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://jasperreports.sourceforge.net/jasperreports
http://jasperreports.sourceforge.net/xsd/jasperreport.xsd"
name = "jasper_report_template" language = "groovy" pageWidth = "595"
pageHeight = "842" columnWidth = "555" leftMargin = "20" rightMargin = "20"
topMargin = "20" bottomMargin = "20" resourceBundle = "localizationdemo">
<title>
<band height = "552">
<textField>
<reportElement positionType = "Float" x = "150" y = "20"
width = "400" height = "50"/>
<textElement>
<font size = "24"/>
</textElement>
<textFieldExpression class = "java.lang.String">
<![CDATA[$P{REPORT_LOCALE}.getDisplayName ($P{REPORT_LOCALE})]]>
</textFieldExpression>
</textField>
<textField isStretchWithOverflow = "true" isBlankWhenNull = "true">
<reportElement positionType = "Float" x = "20" y = "125"
width = "530" height = "20"/>
<textElement textAlignment = "Justified">
<font size = "14"/>
</textElement>
<textFieldExpression class = "java.lang.String">
<![CDATA[$R{localization.text1}]]>
</textFieldExpression>
</textField>
</band>
</title>
</jasperReport>
위 파일 에서 <jasperReport> 요소 의 resourceBundle 속성은 JasperReports에게 보고서에 사용할 현지화 된 문자열을 가져올 위치를 알려줍니다. 속성 값과 일치하는 루트 이름으로 속성 파일을 만들어야합니다. 이 파일은 보고서를 채울 때 CLASSPATH에 있어야합니다. 이 예에서 속성 파일은localizationdemo.properties 디렉토리 아래에 저장됩니다 C:\tools\jasperreports-5.0.1\test. 이 파일의 내용은 다음과 같습니다.
localization.text1 = This is English text.
다른 로케일을 사용하려면 파일 이름이 localizationdemo [locale] .properties 여야합니다. 여기서는 스페인어 로케일 용 파일을 작성합니다. 이 파일을 다음으로 저장-C:\tools\jasperreports-5.0.1\test\localizationdemo_es.properties. 이 파일의 내용은 다음과 같습니다-
localization.text1 = Este texto es en Español.
resourceBundle 속성 값을 가져 오는 구문은 $ R {key}입니다.
JasperReports에게 우리가 사용하고자하는 로케일을 알리려면 내장 매개 변수에 값을 할당해야합니다. 이 매개 변수의 이름은 REPORT_LOCALE라는 상수로 정의되며이 상수는 net.sf.jasperreports.engine.JRParameter 클래스에 정의되어 있습니다. 상수 값은 java.util.Locale 의 인스턴스 여야합니다 . 이 로직은 보고서를 채우고 생성하기 위해 Java 코드에 통합됩니다. 이 파일을 저장합시다JasperReportFillI18.javaC : \ tools \ jasperreports-5.0.1 \ test \ src \ com \ tutorialspoint 디렉토리로 이동합니다. 파일의 내용은 다음과 같습니다-
package com.tutorialspoint;
import java.util.HashMap;
import java.util.Locale;
import net.sf.jasperreports.engine.JREmptyDataSource;
import net.sf.jasperreports.engine.JRException;
import net.sf.jasperreports.engine.JRParameter;
import net.sf.jasperreports.engine.JasperFillManager;
public class JasperReportFillI18 {
public static void main(String[] args) {
String sourceFileName = "C://tools/jasperreports-5.0.1/test/"
+ "jasper_report_template.jasper";
HashMap parameterMap = new HashMap();
if (args.length > 0) {
parameterMap.put(JRParameter.REPORT_LOCALE, new Locale(args[0]));
}
try {
JasperFillManager.fillReportToFile(sourceFileName, null,
new JREmptyDataSource());
} catch (JRException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
보고서 생성
일반 ANT 빌드 프로세스를 사용하여 위 파일을 컴파일하고 실행합니다. build.xml 파일 (C : \ tools \ jasperreports-5.0.1 \ test 디렉토리에 저장 됨)의 내용은 다음과 같습니다.
가져 오기 파일-baseBuild.xml은 환경 설정 장에서 선택 되며 build.xml과 동일한 디렉토리에 있어야합니다.
<?xml version = "1.0" encoding = "UTF-8"?>
<project name = "JasperReportTest" default = "viewFillReport" basedir = ".">
<import file = "baseBuild.xml" />
<target name = "viewFillReport" depends = "compile,compilereportdesing,run"
description = "Launches the report viewer to preview the report stored
in the .JRprint file.">
<java classname = "net.sf.jasperreports.view.JasperViewer" fork = "true">
<arg value = "-F${file.name}.JRprint" />
<classpath refid = "classpath" />
</java>
</target>
<target name = "compilereportdesing" description = "Compiles the JXML file and
produces the .jasper file.">
<taskdef name = "jrc" classname = "net.sf.jasperreports.ant.JRAntCompileTask">
<classpath refid="classpath" />
</taskdef>
<jrc destdir = ".">
<src>
<fileset dir = ".">
<include name = "*.jrxml" />
</fileset>
</src>
<classpath refid = "classpath" />
</jrc>
</target>
</project>
다음으로 명령 줄 창을 열고 build.xml이있는 디렉터리로 이동합니다. 마지막으로 명령을 실행하십시오.ant -Dmain-class=com.tutorialspoint.JasperReportFillI18 (viewFullReport는 기본 대상입니다) 다음과 같이-
C:\tools\jasperreports-5.0.1\test>ant -Dmain-class=com.tutorialspoint.JasperReportFillI18
Buildfile: C:\tools\jasperreports-5.0.1\test\build.xml
clean-sample:
[delete] Deleting directory C:\tools\jasperreports-5.0.1\test\classes
[delete] Deleting: C:\tools\jasperreports-5.0.1\test\jasper_report_template.jasper
[delete] Deleting: C:\tools\jasperreports-5.0.1\test\jasper_report_template.jrprint
compile:
[mkdir] Created dir: C:\tools\jasperreports-5.0.1\test\classes
[javac] C:\tools\jasperreports-5.0.1\test\baseBuild.xml:28:
warning: 'includeantruntime' was not set, defaulting to
[javac] Compiling 1 source file to C:\tools\jasperreports-5.0.1\test\classes
[javac] Note: C:\tools\jasperreports-5.0.1\test\src\com\tutorialspoint\
JasperReportFillI18.java
uses unchecked or u
[javac] Note: Recompile with -Xlint:unchecked for details.
compilereportdesing:
[jrc] Compiling 1 report design files.
[jrc] log4j:WARN No appenders could be found for logger
(net.sf.jasperreports.engine.xml.JRXmlDigesterFactory).
[jrc] log4j:WARN Please initialize the log4j system properly.
[jrc] log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig
for more info.
[jrc] File : C:\tools\jasperreports-5.0.1\test\jasper_report_template.jrxml ... OK.
run:
[echo] Runnin class : com.tutorialspoint.JasperReportFillI18
[java] log4j:WARN No appenders could be found for logger
(net.sf.jasperreports.extensions.ExtensionsEnvironment).
[java] log4j:WARN Please initialize the log4j system properly.
viewFillReport:
[java] log4j:WARN No appenders could be found for logger
(net.sf.jasperreports.extensions.ExtensionsEnvironment).
[java] log4j:WARN Please initialize the log4j system properly.
BUILD SUCCESSFUL
Total time: 3 minutes 28 seconds
위의 컴파일 결과 아래 주어진 화면과 같이 JasperViewer 창이 열립니다.