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

编辑
  • 文档创建者:文档助手1
  • 浏览次数:5047次
  • 编辑次数:11次
  • 最近更新:cherishdqy 于 2019-05-31
  • 1. 描述



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

    2. 思路

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

    3. 操作步骤

    3.1 AJAX 传值设置

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

    点击参数界面,将控件设置为文本控件,给文本控件增加编辑后事件,具体的 JavaScript 代码如下所示:

    var str=this.getValue();    //获取当前控件的值
    FR.ajax({  
       url: "/webroot/session/report?id="+encodeURIComponent(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\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 的名字),如下图:


    注:sessionname 是指 JAVA 类中的 sessionname。

    3.5 效果查看

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

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








    附件列表


    主题: 专题总结
    标签: 暂无标签 编辑/添加标签
    如果您认为本文档还有待完善,请编辑

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

    此页面有帮助吗?只是浏览 [ 去社区提问 ]