यूनिकोड समर्थन
जैस्परपोर्ट में, ग्रंथों के साथ काम करने के लिए चरित्र निरूपण और पाठ प्रारूपण दोनों गुणों को संसाधित करने के लिए कुछ समर्पित उपकरणों की आवश्यकता होती है। किसी भी पाठ को एक विशेष प्रतिनिधित्व संरचना के साथ एक चरित्र अनुक्रम माना जा सकता है। पाठ उपस्थिति में लेआउट (और पैराग्राफ) और फ़ॉन्ट सेटिंग्स दोनों शामिल हैं। लेकिन ज्यादातर मामलों में, पाठ लेआउट अपरिवर्तनीय रहता है, विभिन्न स्थानों में रिपोर्ट चलाते समय फ़ॉन्ट सेटिंग्स बदल सकती हैं।
हम जानते हैं कि अलग-अलग भाषाओं को विशिष्ट वर्ण प्रतिनिधित्व के संबंध में अलग-अलग चरित्र सेट की आवश्यकता होती है। इसलिए, ग्रंथों के साथ काम करने का मतलब है फोंट के साथ काम करना। हालांकि, जैस्परपरपोर्ट्स में फोंट का उपयोग करने के बारे में एक विस्तृत चर्चा अध्याय रिपोर्ट फ़ॉन्ट्स में उपलब्ध है ।
दी गई रिपोर्ट में पाठ सामग्री के विषय में मुख्य विशेषताओं में से एक इसे अंतर्राष्ट्रीयकरण करने की संभावना है। इसका मतलब है, हम विभिन्न स्थानीय वातावरण में रिपोर्ट चला सकते हैं, विभिन्न भाषाओं और अन्य स्थानीयकरण सेटिंग्स का उपयोग करके बिना किसी हार्डकोड के संशोधन कर सकते हैं। जब किसी रिपोर्ट का अंतर्राष्ट्रीयकरण करने का इरादा हो तो कैरेक्टर एन्कोडिंग एक महत्वपूर्ण विशेषता है।
अक्षरों को सांकेतिक अक्षरों में बदलना
एक वर्ण लेखन की सबसे छोटी इकाई है जो एक सार्थक जानकारी देती है। यह एक अमूर्त अवधारणा है, एक चरित्र में एक दृश्य उपस्थिति नहीं है। "अपरकेस लैटिन ए" "लोअरकेस लैटिन" और "अपरकेस सिरिलिक ए" और "अपरकेस ग्रीक अल्फा" से एक अलग चरित्र है।
एक चरित्र का एक दृश्य प्रतिनिधित्व एक के रूप में जाना जाता है glyph। ग्लिफ़ के एक निश्चित सेट को कहा जाता हैfont। "अपरकेस लैटिन ए", "अपरकेस सिरिलिक ए" और "अपरकेस ग्रीक अल्फा" में समान ग्लिफ़ हो सकते हैं, लेकिन वे अलग-अलग वर्ण हैं। उसी समय, "अपरकेस लैटिन ए" के लिए ग्लिफ़ टाइम्स न्यू रोमन, गिल संस और पोइटिका चांसरी इटैलिक में बहुत अलग दिख सकते हैं, लेकिन वे अभी भी एक ही चरित्र का प्रतिनिधित्व करते हैं।
उपलब्ध वर्णों के समुच्चय को वर्ण प्रतिरूप कहा जाता है । एक प्रदर्शनों के भीतर किसी दिए गए चरित्र का स्थान (सूचकांक) उसके कोड स्थिति, या कोड बिंदु के रूप में जाना जाता है। किसी दिए गए प्रदर्शनों की सूची के भीतर अंक का प्रतिनिधित्व करने की विधि को कहा जाता हैcharacter encoding।
आम तौर पर एनकोडिंग को ओकटेट्स के संदर्भ में व्यक्त किया जाता है। एक ऑक्टेट आठ बाइनरी अंकों का एक समूह है, अर्थात, आठ वाले और शून्य। एक ओकटेट 0 और 255 के बीच या 0x00 और 0xFF के बीच एक संख्यात्मक सीमा व्यक्त कर सकता है, हेक्साडेसिमल नोटेशन का उपयोग करने के लिए।
यूनिकोड
एक यूनिकोड एक चरित्र प्रदर्शनों की सूची है जिसमें दुनिया की भाषाओं में प्रयुक्त अधिकांश वर्ण शामिल हैं। यह लाखों पात्रों को समायोजित कर सकता है, और पहले से ही सैकड़ों हजारों शामिल हैं। यूनिकोड को 64K वर्णों के "विमानों" में विभाजित किया गया है। अधिकांश परिस्थितियों में उपयोग किया जाने वाला एकमात्र विमान पहला विमान है, जिसे मूल बहुभाषी विमान या बीएमपी के रूप में जाना जाता है।
UTF-8 अनुशंसित एन्कोडिंग है। यह विभिन्न वर्णों का प्रतिनिधित्व करने के लिए ऑक्टेट की एक चर संख्या का उपयोग करता है।
JRXML फ़ाइल में, शीर्ष लेख में एन्कोडिंग विशेषता निर्दिष्ट होती है। XML सामग्री को डीकोड करने के लिए रिपोर्ट संकलन समय पर इसका उपयोग किया जाता है। उदाहरण के लिए, यदि रिपोर्ट में केवल फ्रेंच शब्द और ç, é, â जैसे अक्षर हैं, तो ISO-8859-1 (उर्फ लैटिन -1) एन्कोडिंग पर्याप्त है -
<?xml version = "1.0" encoding = "ISO-8859-1"?>
जैसा कि ऊपर देखा गया है, आदर्श रूप से हम एन्कोडिंग को न्यूनतम वर्ण सेट में फिट कर सकते हैं, जो दस्तावेज़ में सभी वर्णों का सही प्रतिनिधित्व कर सकता है। लेकिन बहुभाषी दस्तावेजों (यानी कई भाषाओं में लिखे गए शब्दों वाले दस्तावेज़) के मामले में, किसी को न्यूनतम वर्ण सेट के लिए अनुकूलित एन्कोडिंग का चयन करना चाहिए, दस्तावेज़ में सभी वर्णों का सही ढंग से प्रतिनिधित्व करने में सक्षम, भले ही वे विभिन्न भाषाओं के हों। बहुभाषी दस्तावेजों को संभालने में सक्षम चरित्र एन्कोडिंग में से एक हैUTF-8, जैस्परपरपोर्ट्स द्वारा डिफ़ॉल्ट एन्कोडिंग मान के रूप में उपयोग किया जाता है।
ग्रंथों को आमतौर पर अंतर्राष्ट्रीयकरण के दौरान दस्तावेज़ के बजाय संसाधन बंडल फ़ाइलों में रखा जाता है। तो, ऐसे मामले हैं जहां जेआरएक्सएमएल स्वयं पूरी तरह से एएससीआईआई-संगत दिखता है, लेकिन रनटाइम पर उत्पन्न रिपोर्ट में एएससीआईआई के साथ अपठनीय ग्रंथ होते हैं। परिणामस्वरूप, एक निश्चित प्रकार के दस्तावेज़ निर्यात स्वरूपों (जैसे CSV, HTML, XHTML, XML और पाठ) के लिए जनरेट किए गए दस्तावेज़ के लिए एन्कोडिंग को भी जानना पड़ता है। विभिन्न भाषाओं को अलग-अलग चरित्र एन्कोडिंग द्वारा समर्थित किया जाता है। इसलिए हर बार, हमें एक स्थानीय वातावरण में एक रिपोर्ट चलाने की आवश्यकता है। इसके अलावा, हमें यह जानना होगा कि उत्पन्न दस्तावेज़ भाषा के लिए सबसे उपयुक्त वर्ण एन्कोडिंग है। इस स्थिति में, JRXML फ़ाइल में परिभाषित एन्कोडिंग गुण स्वयं अधिक उपयोगी नहीं हो सकता है।
इस तरह के मुद्दों को हल करने के लिए हम net.sf.jasperreports.export.character.encoding नाम से निर्यात ग्राहक संपत्ति का उपयोग कर सकते हैं । यह निर्यात कस्टम संपत्ति UTF-8 के लिए डिफ़ॉल्ट है और यह जैस्पररिपोर्ट में मौजूद है।
यह डिफ़ॉल्ट मान default.jasperreports.properties फ़ाइल में सेट किया गया है । निर्यात समय पर अधिक विशिष्ट विकल्पों के लिए, CHARACTER_ENCODING निर्यात पैरामीटर भी उपलब्ध है।
उदाहरण
जैस्परपोर्ट में यूनिकोड समर्थन का उपयोग करने के लिए, आइए नई रिपोर्ट टेम्पलेट (jasper_report_template.jrxml) लिखें। Save it to C:\tools\jasperreports-5.0.1\testनिर्देशिका। यहां, हम यूनिकोड वर्णों (\ uXXXX) का उपयोग करके विभिन्न भाषाओं में एक पाठ प्रदर्शित करेंगे। UTF-8 के साथ एन्कोड किए गए किसी भी वर्ण को केवल 4 अंकों के हेक्साडेसिमल कोड का उपयोग करके दर्शाया जा सकता है। उदाहरण के लिए, ग्रीक अक्षर letter को \ u0393 लिखा जा सकता है। जब इस तरह के अंकन का सामना किया जाता है, तो इंजन वर्ण सेट में उचित चरित्र प्रतिनिधित्व के लिए कहता है, और केवल उस विशेष चरित्र को प्रिंट किया जाएगा। जेआरएक्सएमएल की सामग्री इस प्रकार है -
<?xml version = "1.0" encoding = "UTF-8"?>
<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">
<parameter name = "GreekText" class = "java.lang.String" isForPrompting = "false">
<defaultValueExpression><![CDATA["\u0394\u03B5\u03BD "+
"\u03BA\u03B1\u03C4\u03B1\u03BB\u03B1\u03B2\u03B1\u03AF"+
"\u03BD\u03C9 \u0395\u03BB\u03BB\u03B7\u03BD\u03B9\u03BA\u03AC"]]>
</defaultValueExpression>
</parameter>
<parameter name = "CyrillicText" class = "java.lang.String" isForPrompting = "false">
<defaultValueExpression><![CDATA["\u042F \u043D\u0435 "+
"\u043C\u043E\u0433\u0443 \u043F\u043E\u043D\u044F\u0442\u044C "+
"\u0433\u0440\u0435\u0447\u0435\u0441\u043A\u0438\u0439"]]>
</defaultValueExpression>
</parameter>
<parameter name = "ArabicText" class = "java.lang.String" isForPrompting = "false">
<defaultValueExpression><![CDATA["\u0627\u0646\u0646\u0649 \u0644\u0627 "+
"\u0627\u0641\u0647\u0645 \u0627\u0644\u0644\u063A\u0629 "+
"\u0627\u0644\u0639\u0631\u0628\u064A\u0629"]]>
</defaultValueExpression>
</parameter>
<parameter name = "HebrewText" class = "java.lang.String" isForPrompting = "false">
<defaultValueExpression><![CDATA["\u05D0\u05E0\u05D9 \u05DC\u05D0 "+
"\u05DE\u05D1\u05D9\u05DF \u05E2\u05D1\u05E8\u05D9\u05EA"]]>
</defaultValueExpression>
</parameter>
<title>
<band height = "782">
<textField>
<reportElement x = "0" y = "50" width = "200" height = "60"/>
<textElement>
<font fontName = "DejaVu Sans" size = "14"/>
</textElement>
<textFieldExpression class = "java.lang.String">
<![CDATA[$P{GreekText} + "\n" + $P{CyrillicText}]]>
</textFieldExpression>
</textField>
<staticText>
<reportElement x = "210" y = "50" width = "340" height = "60"/>
<textElement/>
<text>
<![CDATA["GreekText and CyrillicText"]]>
</text>
</staticText>
<textField>
<reportElement x = "0" y = "120" width = "200" height = "60"/>
<textElement>
<font fontName = "DejaVu Sans" size = "14" isBold = "true"/>
</textElement>
<textFieldExpression class = "java.lang.String">
<![CDATA[$P{GreekText} + "\n" + $P{CyrillicText}]]>
</textFieldExpression>
</textField>
<staticText>
<reportElement x = "210" y = "120" width = "340" height = "60"/>
<textElement/>
<text><![CDATA["GreekText and CyrillicText"]]></text>
</staticText>
<textField>
<reportElement x = "0" y = "190" width = "200" height = "60"/>
<textElement>
<font fontName = "DejaVu Sans" size = "14" isItalic = "true"
isUnderline = "true"/>
</textElement>
<textFieldExpression class = "java.lang.String">
<![CDATA[$P{GreekText} + "\n" + $P{CyrillicText}]]>
</textFieldExpression>
</textField>
<staticText>
<reportElement x = "210" y = "190" width = "340" height = "60"/>
<textElement/>
<text><![CDATA["GreekText and CyrillicText"]]></text>
</staticText>
<textField>
<reportElement x = "0" y = "260" width = "200" height = "60"/>
<textElement>
<font fontName = "DejaVu Sans" size = "14" isBold = "true"
isItalic = "true" isUnderline = "true"/>
</textElement>
<textFieldExpression class = "java.lang.String">
<![CDATA[$P{GreekText} + "\n" + $P{CyrillicText}]]>
</textFieldExpression>
</textField>
<staticText>
<reportElement x = "210" y = "260" width = "340" height = "60"/>
<textElement/>
<text><![CDATA["GreekText and CyrillicText"]]></text>
</staticText>
<textField>
<reportElement x = "0" y = "330" width = "200" height = "60"/>
<textElement textAlignment = "Right">
<font fontName="DejaVu Sans" size = "22"/>
</textElement>
<textFieldExpression class = "java.lang.String">
<![CDATA[$P{ArabicText}]]>
</textFieldExpression>
</textField>
<textField>
<reportElement x = "210" y = "330" width = "340" height = "60"/>
<textElement textAlignment = "Right">
<font fontName = "DejaVu Sans" size = "22"/>
</textElement>
<textFieldExpression class = "java.lang.String">
<![CDATA[$P{HebrewText}]]>
</textFieldExpression>
</textField>
</band>
</title>
</jasperReport>
उपरोक्त फ़ाइल में, हम UTF-8 एन्कोडिंग की उपस्थिति देख सकते हैं। साथ ही पाठ के स्थानीयकृत यूनिकोड टुकड़े दस्तावेज़ मापदंडों में संग्रहीत हैं।
रिपोर्ट भरने और उत्पन्न करने के लिए जावा कोड नीचे दिया गया है। आइए इस फाइल को सेव करेंJasperUnicodeReportFill.java C: \ tools \ jasperreports-5.0.1 \ test \ src \ com \ tutorialspoint निर्देशिका।
package com.tutorialspoint;
import net.sf.jasperreports.engine.JREmptyDataSource;
import net.sf.jasperreports.engine.JRException;
import net.sf.jasperreports.engine.JasperFillManager;
public class JasperUnicodeReportFill {
public static void main(String[] args) {
String sourceFileName ="C://tools/jasperreports-5.0.1/test/" +
"jasper_report_template.jasper";
try {
JasperFillManager.fillReportToFile(sourceFileName, null,
new JREmptyDataSource());
} catch (JRException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
यहाँ हम JREmptyDataSource के एक उदाहरण का उपयोग करते हैं, जब इसमें एक रिकॉर्ड के साथ एक डेटा स्रोत का अनुकरण करने के लिए रिपोर्ट भरते हैं, लेकिन इस एकल रिकॉर्ड में सभी फ़ील्ड शून्य हैं ।
रिपोर्ट पीढ़ी
हम अपनी नियमित 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.JasperUnicodeReportFill (viewFullReport डिफ़ॉल्ट लक्ष्य है) निम्नानुसार है -
C:\tools\jasperreports-5.0.1\test>ant -Dmain-class=com.tutorialspoint.JasperUnicodeReportFill
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 t
[javac] Compiling 1 source file to C:\tools\jasperreports-5.0.1\test\classes
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.JasperUnicodeReportFill
[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: 4 minutes 1 second
उपरोक्त संकलन के परिणामस्वरूप, जैस्परव्यूअर विंडो खुलती है जैसा कि नीचे दी गई स्क्रीन में दिखाया गया है -
यहां, हम देख सकते हैं कि प्रदर्शित किया जा रहा पाठ विभिन्न भाषाओं में है। इसके अलावा, हम देखते हैं कि भाषाओं को एक ही पृष्ठ पर एक साथ समूहीकृत किया जाता है और एक ही पाठ तत्व में मिलाया जाता है।