最新历史版本 :给session赋值实现报表间参数共享 返回文档
编辑时间: 内容长度:图片数:目录数: 修改原因:

目录:

1. 概述编辑

1.1 问题描述

有几张不同的报表,希望某一张报表的日期控件选择好日期后,其他报表日期控件的参数都变成该日期,那么该如何实现呢?

1.2 实现思路

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

注:该方案不支持集群。

2. 操作步骤编辑

2.1 AJAX 传值设置

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

点击参数界面,将控件设置为文本控件,给文本控件增加编辑后事件,如下图所示:

222

JavaScript 代码如下:

var str=this.getValue();    //获取当前控件的值
FR.ajax({  
   url: "/webroot/session/report?id="+encodeURIComponent(str)  //将值传递给 Session 这个 Servlet 中
});

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

3.2 获取值并保存至 Session

新建一个名为 Session 的类,具体的代码详见:

https://git.fanruan.com/demo/example/src/release/10.0/src/main/java/com/fr/data/session.java

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

3.3 配置访问 Session 赋值的 Servlet

%FR _HOME%\webroot\WEB-INF\下的新建 web.xml,加入如下代码:

<?xml version="1.0" encoding="UTF-8"?>
<web-app
   xmlns="http://java.sun.com/xml/ns/j2ee"
   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
   version="2.4">
  <display-name>Template WebApp</display-name>
    <mime-mapping>
  <extension>msi</extension>
  <mime-type>application/x-msi</mime-type>
  </mime-mapping>
  <servlet>
    <servlet-name>session</servlet-name>
    <servlet-class>com.fr.data.session</servlet-class>
    <load-on-startup>2</load-on-startup>
  </servlet>
  <servlet-mapping>
    <servlet-name>session</servlet-name>
    <url-pattern>/session/*</url-pattern>
  </servlet-mapping>
</web-app>

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

3.4 获取 Session 值

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

222

注:sessionname 是指 Java 类中的 sessionname。

3.5 效果查看

由于内置的设计器的 Tomcat 现在不读 web.xml,因此需要将工程部署到外置 Tomcat 中。

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

222