Saiku使用iframe嵌入页面使用时ip与端口配置化(二十八)--DWR的基本使用

DWR(Direct Web Remoting)是一个用于改善web页面与Java类交互的远程服务器端Ajax开源框架,可以帮助开发人员开发包含AJAX技术的网站。它可以允许在浏览器里的代码使用运行在WEB服务器上的JAVA方法,就像它就在浏览器里一样。

这里做的一个需求是 将saiku的访问url配置化,放到配置文件里,然后在jsp页面里就不直接写saiku的url了.

1.在配置文件 config.properties文件中添加配置信息

saiku.url=http://10.22.33.44:8080

2.在spring的配置文件 applicationContext.xml中添加读取配置文件的配置信息

 <!-- 参数设置配置文件 -->
<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<!-- <property name="order" value="2" /> -->
<property name="ignoreUnresolvablePlaceholders" value="true" />
<property name="locations">
<list>
<value>file:${user.home}/../../app/config/iModule-lifepro-web/config.properties</value>
</list>
</property>
</bean>

  

3.新建Controller / Action类(具体根据自己的框架而定),在类中通过注解获取配置文件的参数对应的参数值

GetSaikuUrlAction.java

@Value("${saiku.url}")
private String saikuUrl; /**
* 从配置文件config.properties中读取saiku的访问地址信息
* @return saikuUrl (访问saiku的IP与端口信息)
*/
public String getSaikuUrl(){
  return saikuUrl;
}

 

4.在配置文件中配置注入Controller/Action对象

<bean id="getSaikuUrlAction"  scope="prototype"  class="com.GetSaikuUrlAction" />

  

5.在 WEB-INF 目录下新建 并配置dwr.xml 文件

<create creator="spring" javascript="getSaikuUrlService">     //转换得到的JS对象名为 getSaikuUrlService,供前端调用方法时使用

<param name="beanName" value="getSaikuUrlAction" />  //指定相关的bean名称 

<include method="getSaikuUrl"/>  //Action里面定义的方法名,在js里面调用时也是使用   getSaikuUrlService.getSaikuUrl

页面可以通过引入js文件调用此方法    <script type="text/javascript" src="/项目名/dwr/interface/getSaikuUrlService.js"></script>   //这个只是这样写,实际上此 js 是运行期间服务器通过dwr动态生成的

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 3.0//EN" "http://getahead.org/dwr/dwr30.dtd">
<dwr> <allow>
<!--
<filter class="com.example.dwr.monitor.MonitoringAjaxFilter"/>
<filter class="org.directwebremoting.filter.ExtraLatencyAjaxFilter">
<param name="delay" value="200"/>
</filter>
-->
<filter class="org.directwebremoting.filter.AuditLogAjaxFilter"/> <create creator="spring" javascript="getSaikuUrlService"> <!--  转换得到的JS对象名为 getSaikuUrlService,供前端调用方法时使用 -->
<param name="beanName" value="getSaikuUrlAction" />
<include method="getSaikuUrl"/>
</create> </allow>
</dwr>

  

6 页面中使用示例

最最关键的一步:在WebRoot下,新建一个文件夹叫dwr,然后从dwr.jar中找到engine.js和util.js 放入dwr文件夹中。

(ps: 这里也可以不手动去下载 dwr.jar,新建dwr文件夹; 我们可以通过在pom.xml中引用dwr相关的jar包,然后就会自动被引用)

      <dependency>
<groupId>self.imodule</groupId>
<artifactId>dwr</artifactId>
<version>1</version>
</dependency>

demo.jsp  

<script type='text/javascript' src='${pageContext.request.contextPath}/dwr/interface/getSaikuUrlService.js'></script>
<script type='text/javascript' src='${pageContext.request.contextPath}/dwr/engine.js'></script>
<script type='text/javascript' src='${pageContext.request.contextPath}/dwr/util.js'></script> <script> var saikuUrl = null;//定义全局变量saikuUrl 访问saiku的地址 $(function() {// 初始化内容 //先获取saiku的访问地址,再做其他操作
getSaikuUrlService.getSaikuUrl({
//dwr正常调用时 返回结果数据 然后获取结果做以下操作 访问saiku
callback:function(data) {
 saikuUrl=data;

            var baseUrl=saikuUrl+"/?username=admin&password=123#query/open//demo/demo_1.saiku";  /*这是軿凑后完整的saiku某个文件的地址信息*/

          /*这里省略获取saiku地址后的处理逻辑信息........*/
      },
//dwr调用接口失败时
errorHandler:function(errorString, exception) {//执行异常时  
         alert("获取SaikuUrl地址失败,请检查DWR调用!"+errorString+":"+exception);  
 } 
});
</script>

  

Saiku使用iframe嵌入页面访问地址配置化(二十八)--DWR的基本使用的更多相关文章

  1. Saiku通过iframe嵌入web页面(六)

    Saiku通过iframe嵌入系统页面 前提: Saiku已安装好,并且配置了数据源,熟练了saiku的基本使用. 一.将整个Saiku嵌入页面 在web项目中,新建index.jsp页面,内容如下: ...

  2. iframe嵌入页面不能全部展示

    在嵌入页面不能全部展示的问题中,可以通过js改变iframe的高度 html部分代码: <iframe src="#" name="i" id=" ...

  3. 手把手教你搭建LyncServer2013之部署及配置监控功能(十八)

    自弃用监控服务器角色以来,已对 Microsoft Lync Server 2013 监控基础结构进行了重大更改.不再采用不同的监控服务器角色(通常需要组织设置专用计算机来充当监控服务器),现在监控服 ...

  4. 通过JdbcTemplate编写数据访问(二十八)

    数据源配置 在我们访问数据库的时候,需要先配置一个数据源,下面分别介绍一下几种不同的数据库配置方式. 首先,为了连接数据库需要引入jdbc支持,在pom.xml中引入如下配置: 1 2 3 4 < ...

  5. Spring Boot教程(二十八)通过JdbcTemplate编写数据访问

    数据源配置 在我们访问数据库的时候,需要先配置一个数据源,下面分别介绍一下几种不同的数据库配置方式. 首先,为了连接数据库需要引入jdbc支持,在pom.xml中引入如下配置: <depende ...

  6. AngularJS进阶(二十八)解决AngualrJS页面刷新导致异常显示问题

    解决AngualrJS页面刷新导致异常显示问题 绪 俗话说,细节决定成败,编程亦是如此.编程过程中我们可能会不自觉的忽视一些细节问题,殊不知,这些细节正是导致页面显示出现问题的地方.今略举一例,与君共 ...

  7. 爪哇国新游记之二十八----从url指定的地址下载文件到本地

    package download; import java.io.File; import java.io.FileOutputStream; import java.io.InputStream; ...

  8. Oracle环境配置之山路十八弯

    Oracle数据库的安装 背景: 因为疫情原因,只能在家上网课,学习Oracle的时候需要安装数据库,但是!! 安装的时候出现了报错: 无法检查指定的位置是否位于 CFS 上. 出来这个基本无解,这个 ...

  9. Linux学习之CentOS(二十八)--RAID原理基础及Linux下软件RAID配置

    一.RAID的原理基础 在 讲解RAID的原理基础之前,我们首先来了解一下传统磁盘的劣势.我们知道一台PC机种都会包含CPU.内存.主板.硬盘.网卡等硬件,影响计算机性能的 组建包括:CPU.主板总线 ...

随机推荐

  1. mybatis基础 笔记

    Mybatis依赖<!--测试--> <dependency>      <groupId>junit</groupId>      <artif ...

  2. nginx 配置实例-反向代理

    反向代理实例一 虚拟机IP:192.168.116.129实现效果:使用 nginx 反向代理,访问 www.123.com 直接跳转到 虚拟机的192.168.116.129:8080  实验代码  ...

  3. s3c2440裸机-代码重定位(2.编程实现代码重定位)

    代码重定位(2.编程实现代码重定位) 1.引入链接脚本 我们上一节讲述了为什么要重定位代码,那么怎么去重定位代码呢? 上一节我们发现"arm-linux-ld -Ttext 0 -Tdata ...

  4. Linux系统学习 十七、VSFTP服务—本地用户访问—用户访问控制

    FTP相关文件中用户控制列表文件 /etc/vsftpd/ftpusers        #该文件永远都是黑名单(针对访问ftp服务,一般不做修改) /etc/vsftpd/user_list     ...

  5. 安装oracle11g客户端

    1.将压缩包instantclient_11_2 解压到数据库安装目录下(D:\app\hisoft\product\11.2.0),即与dbhome_1同级目录 2.添加环境变量 至此,oracle ...

  6. redis的embstr编码

    问题来了 今天在看书籍<Redis设计与实现>的时候,在8.2字符串对象里面写到 如果字符串对象保存的是一个字符串值, 并且这个字符串值的长度大于 39 字节, 那么字符串对象将使用一个简 ...

  7. Selenium(十三):验证码的处理、WebDriver原理

    1. 验证码的处理 对于Web应用来说,大部分的系统在用户登录时都要求用户输入验证码.验证码的类型很多,有字母数字的.有汉字的,甚至还需要用户输入一道算术题的答案的.对于系统来说,使用验证码可以有效地 ...

  8. Format a Property Value 设置属性值的格式

    In this lesson, you will learn how to set a display format and an edit mask to a business class prop ...

  9. vscode自动修复eslint规范的插件及配置

    在开发大型项目中,经常都是需要多人合作的.相信大家一定都非常头疼于修改别人的代码的吧,而合理的使用eslint规范可以让我们在代码review时变得轻松,也可以让我们在修改小伙伴们的代码的时候会更加清 ...

  10. js随机生成ID

    processID = () => { const uuid = 'xxxxxxxx-xxxx-xxxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function ...