在报表中给session赋值实现报表间参数共享

编辑
文档创建者:文档助手1 (67727 )     浏览次数:3624次     编辑次数:9次     最近更新:jiangsr 于 2018-08-22     

目录:

1. 描述编辑

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

2. 思路编辑

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

3. 操作步骤编辑

3.1 Ajax传值设置
随便打开一张带参数的模版,如打开模版:%FR_HOME%\webapps\webroot\WEB-INF\reportlets\doc\Primary\Parameter\Parameter.cpt
点击参数界面,将控件设置为文本域控件,给文本域控件增加编辑后事件,具体的js如下:
var str=this.getValue(); //获取当前控件的值 FR.ajax({ url: "servlet/session?id="+FR.cjkEncode(str)  //将值传递给session这个servlet中 });
注:如果想要预览报表的同时将数据也写入到session中,而不需要异步加载,可以再ajax下面加上async:false。
3.2 获取值并保存至Session
新建一个名为session的类,具体的代码如下:
package com.fr.data; import javax.servlet.http.HttpSession; import java.io.IOException; import java.io.PrintWriter; import java.util.ResourceBundle; import java.lang.String; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import com.fr.stable.CodeUtils; import com.fr.web.utils.WebUtils; public class session extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException { response.setContentType("text/html; charset=gb2312"); PrintWriter out = response.getWriter(); out.println("<html>"); out.println("<body>"); String urlid=request.getParameter("id"); //获取url通过ajax传递的值 HttpSession session=request.getSession(true); if(urlid==""||urlid==null){ out.print("<form action=\""); out.print("session\" "); out.println("method=POST>"); out.println("set session:<input type=text name=sessionvalue>"); out.println("<input type=submit name=bbb value=tijiao>"); out.println("</form>"); if(request.getParameter("sessionvalue")!=null&&request.getParameter("sessionvalue")!=""){ session.setAttribute("sessionname", request.getParameter("sessionvalue")); } } else{ urlid = CodeUtils.decodeText(urlid); session.setAttribute("sessionname",urlid); //将值赋值给sessionname这个session中 out.println("<script language='javascript'>window.close();</script>"); } out.println("</body>"); out.println("</html>"); } public void doPost(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException { doGet(request, response); } }
编译session.java类,将编译好的session.class放置在%FR _HOME%\webapps\webroot\WEB-INF\classes目录下。
3.3 获取session值
在另外一个参数模版如%FR_HOME%\webapps\webroot\WEB-INF\reportlets\doc\Primary\Parameter\Parameter1.cpt将数据集中地区参数的默认值华北删除,并且参数控件的控件值中选择公式并输入$sessionname(servlet中session的名字),如下图:
222
注:sessionname是指java类中的sessionname。
3.5 效果查看
分页预览parameter.cpt,在文本框中输入中国后,再预览parameter1.cpt,可以看到文本框中显示的是中国了,如下图:
222


附件列表


主题: 专题总结
如果您认为本文档还有待完善,请编辑

文档内容仅供参考,如果你需要获取更多帮助,付费/准付费客户请咨询帆软技术支持
关于技术问题,您还可以前往帆软社区,点击顶部搜索框旁边的提问按钮
若您还有其他非技术类问题,可以联系帆软传说哥(qq:1745114201

此页面有帮助吗? [ 去社区提问 ]