1. 问题描述

在报表开发工具FineReport中,若有几张不同的报表,每张报表都有一个共同的项可以选择,比如日期时间。我们希望选择了第一张报表的时间之后,其他报表的默认时间都变为第一张报表选择的时间,此时要如何实现呢?

2. 实现思路

可以利用给session赋值来实现。给第一张报表的参数控件增加通过ajax的url将值传递给后台的servlet的编辑后事件,servlet获取ajax传递的值并将其保存到session中,后面的报表在参数的控件值处通获取session值即可。

3. 实现步骤

3.1 Ajax传值设置

随便打开一张带参数的模版,如打开模版:%FR_HOME%\WebReport\WEB-INF\reportlets\doc\Primary\Parameter\Parameter.cpt。

点击参数界面,将控件设置未文本框控件,给文本框控件增加编辑后事件,具体的js如下:

1.var str=this.getValue();    //获取当前控件的值  
2.FR.ajax({    
3.   url: "servlet/session?id="+FR.cjkEncode(str),   //将值传递给session这个servlet中  
});

注:如果想要预览报表的同时将数据也写入到session中,而不需要异步加载,可以再ajax下面加上async:false。

3.2 获取值并保存至Session

新建一个名为session的类,具体的代码如下:

1.import javax.servlet.http.HttpSession;      
2.import java.io.IOException;      
3.import java.io.PrintWriter;      
4.import java.util.ResourceBundle;      
5.import java.lang.String;      
6.import javax.servlet.ServletException;      
7.import javax.servlet.http.HttpServlet;      
8.import javax.servlet.http.HttpServletRequest;      
9.import javax.servlet.http.HttpServletResponse;      
10.  
11.import com.fr.stable.CodeUtils;  
12.import com.fr.web.utils.WebUtils;  
13.      
14.public class session extends HttpServlet {      
15.    public void doGet(HttpServletRequest request,      
16.                      HttpServletResponse response)      
17.        throws IOException, ServletException      
18.    {      
19.     response.setContentType("text/html; charset=gb2312");      
20.      
21.     PrintWriter out = response.getWriter();      
22.     out.println("<html>");      
23.     out.println("<body>");      
24.     String urlid=request.getParameter("id");  //获取url通过ajax传递的值      
25.     HttpSession session=request.getSession(true);      
26.     if(urlid==""||urlid==null){      
27.     out.print("<form action=\"");      
28.     out.print("session\" ");      
29.     out.println("method=POST>");      
30.     out.println("set session:<input type=text name=sessionvalue>");      
31.     out.println("<input type=submit name=bbb value=tijiao>");      
32.     out.println("</form>");         
33.     if(request.getParameter("sessionvalue")!=null&&request.getParameter("sessionvalue")!=""){      
34.     session.setAttribute("sessionname", request.getParameter("sessionvalue"));      
35.     }      
36.     }      
37.     else{      
38.         urlid = CodeUtils.decodeText(urlid);  
39.         session.setAttribute("sessionname",urlid);  //将值赋值给sessionname这个session中      
40.        out.println("<script language='javascript'>window.close();</script>");      
41.     }      
42.     out.println("</body>");      
43.     out.println("</html>");      
44.    }        
45.    public void doPost(HttpServletRequest request,      
46.                      HttpServletResponse response)      
47.        throws IOException, ServletException      
48.    {      
49.        doGet(request, response);      
50.    }              
51.}  

编译session.java类,将编译好的session.class放置在%FR _HOME%\WebReport\WEB-INF\classes目录下。

3.3 配置访问session赋值的Servlet

打开%FR _HOME%\WebReport\WEB-INF\下的web.xml,加入如下代码:

1.<servlet>  
2.    <servlet-name>session</servlet-name>  
3.    <servlet-class>session</servlet-class>  
4.  </servlet>    
5.    
6.  <servlet-mapping>  
7.    <servlet-name>session</servlet-name>  
8.    <url-pattern>/servlet/session</url-pattern>  
9.  </servlet-mapping>  

注:在编写java类文件的时候,如果是保存在某个具体的包下面,比如说com/fr/data下面,那么除了需要将class文件放置在对应位置下之外,web.xml文件中的servlet-class标签也需要修改,比如说修改为com.fr.data.session。

3.4 获取session值

在另外一个参数模版如%FR_HOME%\WebReport\WEB-INF\reportlets\doc\Primary\Parameter\Parameter1.cpt将数据集中地区参数的默认值华北删除,并且参数控件的控件值中选择公式并输入$sessionname(servlet中session的名字),如下图:

注:sessionname是指java类中的sessionname。

3.5 效果查看

分页预览parameter.cpt,在文本框中输入中国后,再预览parameter1.cpt,可以看到文本框中显示的是中国了,如下图:

在报表中给session赋值实现报表间参数共享的更多相关文章

  1. 在ActiveReports页面报表中显示Google地图

    有些报表需求中需要我们显示国家.城市等地址信息,在报表中添加地图信息会让报表给最终用户代码更多有效信息. 在报表中可以将地图作为图片添加进来,当一个图片显示在报表中时,该图片必须存放到本地计算机或者服 ...

  2. 在 ReportViewer 报表中使用表达式

    from:http://www.cnblogs.com/jobin/articles/1152213.html 有些表达式在报表中很常用.其中包括更改报表中的数据外观的表达式.计算总数的表达式和更改报 ...

  3. .ashx中使用Session

    在一般处理程序中给session赋值是报错:未将对象引用设置到对象的实例.

  4. 如何在报表权限中使用session

    1. 问题描述 权限中使用session,一般是用来存放用户名和密码,下面以报表开发工具FineReport为例,分两种情况介绍用户名和密码的保存: 2. 同一应用下session 由于session ...

  5. Oracle EBS的BIP报表中显示特殊字体

    http://oracleseeker.com/2009/08/25/font_mapping_setup_for_special_character_print_in_oracle_ebs_bip/ ...

  6. [AX2012 R3]在SSRS报表中使用QR二维码

    AX2012是自带生成QR二维码的类,可以很方便的用在SSRS报表中,下面演示如何在RDP的报表中使用二维码,首先从定义临时表开始: 字段URL是要用于二维码的字符串,QrCode是container ...

  7. 在VS2012后的版本中做数据报表时,提示尚未指定报表“Report1”的报表定义

    有一群的朋友在用VS2012做数据报表时,老是提示 本地报表处理期间出错. 尚未指定报表“Report1”的报表定义 未将对象引用设置到对象的实例. 我看了一下,步骤没错,我用VS2010做了一下,一 ...

  8. 报表中的Excel操作之Aspose.Cells(Excel模板)

    原文:报表中的Excel操作之Aspose.Cells(Excel模板) 本篇中将简单记录下Aspose.Cells这个强大的Excel操作组件.这个组件的强大之处,就不多说,对于我们的报表总是会有导 ...

  9. 在Cognos报表中使用钻取特性,参数传递

    转载至:http://blog.sina.com.cn/s/blog_6eda1c4e0100mu3t.html Cognos的钻取方式大致可以分为三种: 1.模型固有的->由CUBE和DMR支 ...

随机推荐

  1. 神奇的Bank系统之旅哦

        奋斗不能等待,我们不能等到垂暮之年再去“全力以赴”.让我们从现在开始,为理想而努力,为人生而拼搏.精诚所至,金石为开,相信奋斗会让我们的青春之花绽放得更加绚烂,让我们的人生之路走下来不留遗憾. ...

  2. Atitit.js javascript的rpc框架选型

    Atitit.js javascript的rpc框架选型 1. Dwr1 2. 使用AJAXRPC1 2.2. 数据类型映射表1 3. json-rpc轻量级远程调用协议介绍及使用2 3.1. 2.3 ...

  3. Tsql查询执行顺序(二)

    来源:http://www.cnblogs.com/gaiyang/archive/2011/04/13/2014356.html T-SQL查询处理这种逻辑处理顺序,是理论上的处理过程,实际情况还会 ...

  4. ajax的再次封装!(改进版) —— new与不 new 有啥区别?

    生命不息重构不止! 上一篇写了一下我对ajax的再次封装的方法,收到了很多有价值的回复,比如有童鞋建议用$.extend,一开始还以为要做成插件呢,后来才知道,原来这个东东还可以实现合并.省着自己再去 ...

  5. js 小数[非]四舍五入

    1.四舍五入 (2.678).toFixed(2) // 2.68 2.不需要四舍五入 (parseInt(2.678*100)/100.0).toFixed(2) // 2.67 3.字节单位转换 ...

  6. jquery多次上传同一张图片

    $().reset(); wrap():$('p').wrap('div');===><div><p></p></div>; .closest() ...

  7. Windows-mysql5.7安装

    下载 mysql 5.7.msi 安装 双击mysql.msi,按照提示安装. 安装之后需要注意的问题(重点) 设置mysql环境环境变量(让mysql在cmd中的任何路径下就可以被调用) 鼠标右击计 ...

  8. SharePoint 2013 搭建负载均衡(NLB)

    服务器架构(三台虚机:AD和Sql在一台,前端两台) DC.Sql Server,其中包括:AD.DNS.DHCP服务(非必须): SPWeb01,其中包括:IIS.SharePoint: SPWeb ...

  9. CSS 遗漏点

    link属性:链接的颜色(如果改成白色什么都看不见) alink属性:active点击之后的链接的颜色 vlink属性:visited点击之后的颜色 bgcolor属性:背景颜色 word-break ...

  10. Android 实现图片画画板

    本文主要讲述了Android 实现图片画画板 设计项目布局: <RelativeLayout xmlns:android="http://schemas.android.com/apk ...