在报表中给session赋值实现报表间参数共享
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赋值实现报表间参数共享的更多相关文章
- 在ActiveReports页面报表中显示Google地图
有些报表需求中需要我们显示国家.城市等地址信息,在报表中添加地图信息会让报表给最终用户代码更多有效信息. 在报表中可以将地图作为图片添加进来,当一个图片显示在报表中时,该图片必须存放到本地计算机或者服 ...
- 在 ReportViewer 报表中使用表达式
from:http://www.cnblogs.com/jobin/articles/1152213.html 有些表达式在报表中很常用.其中包括更改报表中的数据外观的表达式.计算总数的表达式和更改报 ...
- .ashx中使用Session
在一般处理程序中给session赋值是报错:未将对象引用设置到对象的实例.
- 如何在报表权限中使用session
1. 问题描述 权限中使用session,一般是用来存放用户名和密码,下面以报表开发工具FineReport为例,分两种情况介绍用户名和密码的保存: 2. 同一应用下session 由于session ...
- Oracle EBS的BIP报表中显示特殊字体
http://oracleseeker.com/2009/08/25/font_mapping_setup_for_special_character_print_in_oracle_ebs_bip/ ...
- [AX2012 R3]在SSRS报表中使用QR二维码
AX2012是自带生成QR二维码的类,可以很方便的用在SSRS报表中,下面演示如何在RDP的报表中使用二维码,首先从定义临时表开始: 字段URL是要用于二维码的字符串,QrCode是container ...
- 在VS2012后的版本中做数据报表时,提示尚未指定报表“Report1”的报表定义
有一群的朋友在用VS2012做数据报表时,老是提示 本地报表处理期间出错. 尚未指定报表“Report1”的报表定义 未将对象引用设置到对象的实例. 我看了一下,步骤没错,我用VS2010做了一下,一 ...
- 报表中的Excel操作之Aspose.Cells(Excel模板)
原文:报表中的Excel操作之Aspose.Cells(Excel模板) 本篇中将简单记录下Aspose.Cells这个强大的Excel操作组件.这个组件的强大之处,就不多说,对于我们的报表总是会有导 ...
- 在Cognos报表中使用钻取特性,参数传递
转载至:http://blog.sina.com.cn/s/blog_6eda1c4e0100mu3t.html Cognos的钻取方式大致可以分为三种: 1.模型固有的->由CUBE和DMR支 ...
随机推荐
- xshell 通过ssh连接 ubuntu15_x64
参考: http://www.cnblogs.com/wuyuegb2312/archive/2013/03/28/2986963.html 中文乱码在客户端xshell解决:http://jingy ...
- CSS3中DIV水平垂直居中-2(3)
用到CSS3中display的新属性. HTML <div class="parent"> </div> CSS html,body{ width: 100 ...
- 苹果浏览器和uc浏览器在移动端的坑(日常积累,随时更新)
先mark 1 . 移动端uc浏览器不兼容css3 calc() 2 . ie8下a标签没有内容给宽高也不能触发点击跳转 3 . safari输入框加上readOnly="ture&qu ...
- mongodb 查询的用法
想要在C#中使用MongoDB,首先得要有个MongoDB支持的C#版的驱动.C#版的驱动貌似有很多种,如官方提供的samus. 实现思路大都类似.这里我们用官方提供的mongo-csharp-dri ...
- css中的background属性
第一次写博客,我就写写今天在编写网页的过程中,对background的两种运用,一是background中的线性渐变,对背景的渐变我其实是很少使用的,所以今天在写的时候我用css3的帮助手册,back ...
- SAP 调用RFC 的时候记录异常报错方式
DATA: lv_error TYPE char100. CALL FUNCTION 'ZRFC_WM_ZEL001' DESTINATION lv_desc EXPORTING process_fl ...
- HTML5攻防向量
From:HTML 5 Morden Day Attack And Defense Vectors Autor:Rafay Baloch 摘要 根据Powermapper出版的统计,他们分析的Web页 ...
- MySQL Performance tuning
1.表级锁状态 mysql> show status like 'table%'; +----------------------------+-----------+ | Variable_n ...
- C语言一级指针与二级指针
指针的概念 指针就是地址, 利用这个地址可以找到指定的数据 指针就是地址, 那么在使用的时候, 常常会简单的说 指针变量为指针 指针变量就是存储地址的变量 int *p1;// 申请了一个变量, 即在 ...
- 希尔排序(Shell)
希尔排序的实质就是分组插入排序,该方法又称缩小增量排序. 该方法的基本思想是:先将整个待排元素序列分割成若干个子序列(由相隔某个“增量”的元素组成的)分别进行直接插入排序,然后依次缩减增量再进行排序, ...