Posted on 2005-01-10 13:16
海天一鷗 閱讀(1757)
評論(6) 編輯 收藏 所屬分類:
報表專題
jasper變量的表達式的問題
jasper中的field字段的定義:
XML Syntax
<!ELEMENT field (fieldDescription?)>
<!ATTLIST field
name NMTOKEN #REQUIRED
class (java.lang.Object | java.lang.Boolean | java.lang.Byte |
java.util.Date | java.sql.Timestamp | java.lang.Double | java.lang.Float |
java.lang.Integer | java.io.InputStream | java.lang.Long | java.lang.Short |
java.math.BigDecimal | java.lang.String) "java.lang.String"
>
<!ELEMENT fieldDescription (#PCDATA)>
注意他們的實例都是對象,
對象不能用簡單的+的方式,
比如你想對兩個類型為java.lang.Double的field進行相加
那么就應該用如下表達式
($F{field1}.doubleValue()+$F{field2}.doubleValue())
而不是
($F{field1}+$F{field2})
設定某個類型為java.lang.Double的初始值是
應該用new java.lang.Double(3)
而不是3
其他類型的數據也一樣
iReport 0.3.0 不能啟動的問題
注意 iReport 0.3.0 需要JDK 1.4 的版本
還有用Oracle9的注意了,由于Oracle9自帶的是JDK1.3版本的
所以可能會導致iReport在啟動時用到Oracle中的JDK而導致無法啟動
如何讓顯示的數據自動折行顯示
可以選擇field,-> text filed ->有個框打勾
strech with overflow
關于此功能的具體應用,
大家可以參看JasperReport的samples -> stretch
jasperreport報表文件輸出到pdf的中文問題
1、 你確定一下你的classpath下是否有itext和itextasia。
2、 確定你的pdf font是否設置漢字字體如STsong_light和pdf encoding是否是漢字的encoding
這樣之后如果還有問題,就是你的數據傳送過來的亂碼問題。
初學者實例:在WEB客戶端直接打印JasperReport報表
當我不希望使用JasperReport生成pdf或html等報表顯示文件到客戶端后再通過相應打印功能打印,而想直接在客戶端打印生成的報表時候,我們可以使用JasperPrintManager類里的printReport方法來實現打印。這里我給出我的一個測試實例:
首先,我在服務器端的一個Servlet里調用報表格式文件、填充數據生成一個JasperPrint對象;然后將這個JasperPrint對象以對象流方式返回給客戶端:
public class JRPrintServlet extends HttpServlet {
public void service(
HttpServletRequest request,
HttpServletResponse response
) throws IOException, ServletException{
String fileName = reports/TestRpt.xml";//我的測試報表格式文件
JasperReport jrt = JasperCompileManager.compileReport(fileName);//編譯報表格式
java.sql.Connection conn = DBBean.getConnection(); //獲取數據庫連接
JasperPrint jpt = JasperFillManager.fillReport(jrt,hs,conn));//填充報表數據生成JasperPrint對象
response.setContentType("application/octet-stream");
ServletOutputStream ouputStream = response.getOutputStream();
ObjectOutputStream oos = new ObjectOutputStream(ouputStream);
oos.writeObject(jpt);//將JasperPrint對象寫入對象輸出流中
oos.flush();
oos.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
}
然后編寫一個客戶端Applet,通過對上面Servlet的請求獲得該JasperPrint對象,并調用JasperPrintManager方法進行打印:
public class JRPrinterApplet extends Applet {
private URL url = null;
public void init(){
String strUrl = getParameter("REPORT_URL");
if(strUrl!=null){
try{
System.out.println(getCodeBase());
url = new URL(getCodeBase(),strUrl);//從獲得html參數中獲得報表URL
System.out.println(url);
}catch(Exception e){
e.printStackTrace();
}
}else
JOptionPane.showMessageDialog(this, "Source URL not specified");
}
public void start(){
if(url!=null){
try{
JOptionPane.showMessageDialog(this, url);
Object obj = JRLoader.loadObject(url);//發送對象請求,獲得JasperPrint對象
System.out.println(obj);
JasperPrintManager.printReport((JasperPrint)obj, true);//調用方法打印所獲得的JasperPrint對象
}catch(Exception e){
e.printStackTrace();
}
}
}
}
另外簡單寫一個測試html來調用以上applet:
<!--JRPrintTest.html-->
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=GB2312">
<title>打印窗口</title>
</head>
<script language="javascript">
<!--
function openApp()
{
var url = "/JRPrintServlet";
document.write('<APPLET ID="JrPrt" CODE = "JRPrinterApplet.class" CODEBASE = "/reports" ARCHIVE = "jasper-api.jar" WIDTH = "0" HEIGHT = "0">');
document.write('<PARAM NAME = "type" VALUE="application/x-java-applet;version=1.2.2">');
document.write('<PARAM NAME = "scriptable" VALUE="false">');
document.write('<PARAM NAME = "REPORT_URL" VALUE ="'+url+'">');
document.write('</APPLET>');
}
-->
</script>
<body bgcolor="#FFFFFF">
<input type="button" value="測試打印" onclick="openApp();">
</body>
</html>
這樣,在客戶端訪問JRPrintTest.html頁面,點擊"測試打印"按鈕,就能夠直接在客戶端打印機上打印出所要的報表。
