参考:http://www.directwebremoting.org/dwr/introduction/getting-started.html http://blog.csdn.net/lxn39830435731415926/article/details/45799467 dwr很老的东西,官网的demo是09年的,本来想直接集成springmvc用注解那种,但是看官方的例子知道spring3.x版本,实际我们使用的是4.0的,就放弃了,用dwr单独管理那种方法带配置文件的那种 1.引入dwr <dependency> <groupId>org.directwebremoting</groupId> <artifactId>dwr</artifactId> <version>3.0</version> </dependency> 2.web.xml加入 <!--dwr配置开始 --> <servlet> <description>Direct Web Remoter Servlet</description> <display-name>DWR Servlet</display-name> <servlet-name>dwr-invoker</servlet-name> <servlet-class>org.directwebremoting.servlet.DwrServlet</servlet-class> <!-- This should NEVER be present in live --> <init-param> <param-name>debug</param-name> <param-value>true</param-value> </init-param> <!-- Remove this unless you want to use active reverse ajax --> <init-param> <param-name>activeReverseAjaxEnabled</param-name> <param-value>true</param-value> </init-param> <!-- By default DWR creates application scope objects when they are first used. This creates them when the app-server is started --> <init-param> <param-name>initApplicationScopeCreatorsAtStartup</param-name> <param-value>true</param-value> </init-param> <load-on-startup>2</load-on-startup> </servlet> <servlet-mapping> <servlet-name>dwr-invoker</servlet-name> <url-pattern>/dwr/*</url-pattern> </servlet-mapping> <!--dwr配置结束 --> 3.增加dwr.xml,和web.xml同级。这里注意用的是creator="spring",让spring自动管理。因为service层以前是自动管理的,所以对应的类,我加到了service层,对应使用value就是spring管理的bean的名称。如果creator="new" 那么就不是spring管理,name就应该是"class" 对应的value填写对应类的全路径 <?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> <!-- 修改信息相关 --> <create creator="spring" javascript="alterInfoMessager"> <param name="beanName" value="alterInfoMessagerService"/> </create> <convert converter="bean" match="com.xxx.vo.DwrMessageVO"/> </allow> </dwr> 4.service层增加对应的类,保证service在配置中能被扫描到,能自动注入。 package com.xxx.dwr.service; import com.xxxx.vo.DwrMessageVO; 接口 /** * * 修改信息消息管理者 * @author xxx * * @date 2017年6月14日 下午7:11:19 */ public interface AlterInfoMessagerService { /** * 推送修改消息 * @param vo * @author xxxx * @date 2017年6月15日 上午11:13:40 */ public void pushAlterMsg(DwrMessageVO vo); } 实现类 package com.xxxx.dwr.service.impl; import org.directwebremoting.browser; import org.directwebremoting.ScriptSession; import org.directwebremoting.ScriptSessionFilter; import org.directwebremoting.ScriptSessions; import org.directwebremoting.WebContextFactory; import org.springframework.stereotype.Service; import com.xxxx.dwr.service.AlterInfoMessagerService; import com.xxxx.vo.DwrMessageVO; /** * 修改信息消息管理者 * @author xxx * * @date 2017年6月14日 下午7:13:20 */ @Service("alterInfoMessagerService") public class AlterInfoMessagerServiceImpl implements AlterInfoMessagerService{ //过滤的属性 private final static String SCRIPT_SESSION_SHIXIANG_GUID = "SCRIPT_SESSION_SHIXIANG_GUID"; private DwrMessageVO currentVo; @Override public void pushAlterMsg(DwrMessageVO vo) { currentVo = vo; ScriptSessionFilter attributeFilter= new AttributeScriptSessionFilter(SCRIPT_SESSION_SHIXIANG_GUID); browser.withCurrentPageFiltered(attributeFilter,new Runnable() { public void run() { //回调 ScriptSessions.addFunctionCall("receiveAlterMsg",currentVo); currentVo=null; } }); } public void addAttributetoScriptSession(DwrMessageVO vo) { ScriptSession scriptSession = WebContextFactory.get().getScriptSession(); scriptSession.setAttribute(SCRIPT_SESSION_SHIXIANG_GUID,vo.getShiXiangGuid()); } public void removeAttributetoScriptSession() { ScriptSession scriptSession = WebContextFactory.get().getScriptSession(); scriptSession.removeAttribute(SCRIPT_SESSION_SHIXIANG_GUID); } /** * * @author xxxx * * @date 2017年6月14日 下午7:47:35 */ protected class AttributeScriptSessionFilter implements ScriptSessionFilter { public AttributeScriptSessionFilter(String attributeName) { this.attributeName = attributeName; } /* (non-Javadoc) * @see org.directwebremoting.ScriptSessionFilter#match(org.directwebremoting.ScriptSession) */ public boolean match(ScriptSession session) { Object check = session.getAttribute(attributeName); if(check==null){ return false; } if(attributeName.equals(SCRIPT_SESSION_SHIXIANG_GUID)){ return check.equals(currentVo.getShiXiangGuid()); } return false; } private final String attributeName; } } 5. 增加了一个消息传递的vo类,目前只有一个属性,后面根据需要对应的自己增加属性 package com.xxxx.vo; /** * 消息传输类 * @author xxxx * * @date 2016年5月24日 下午12:21:10 */ public class DwrMessageVO { /** * 事项guid,根据业务不同,是不同业务的主键 * shiXiangGuid */ private String shiXiangGuid; public DwrMessageVO() { } public String getShiXiangGuid() { return shiXiangGuid; } public void setShiXiangGuid(String shiXiangGuid) { this.shiXiangGuid = shiXiangGuid; } } 6.引入js,js都是自动生成的。 <script type="text/javascript" src="${base}/dwr/engine.js"></script> <script type="text/javascript" src="${base}/dwr/util.js"></script> <!--根据业务不同,调用不同的业务js--> <script type="text/javascript" src="${base}/dwr/interface/alterInfoMessager.js"></script> $(function() { initEngine();//初始化dwr引擎 }); //初始化dwr引擎 function initEngine(){ dwr.engine.setActiveReverseAjax(true);//开启服务器推 dwr.engine.setErrorHandler(errorHandler);//设置错误处理函数 var obj={"shiXiangGuid":xxxx};//事项guid 事情的主键,根据业务不同,传递不同,区分不同业务 alterInfoMessager.addAttributetoScriptSession(obj);//加入修改信息消息管理 } //错误处理 function errorHandler(message,ex) { alert(message); } //dwr接受修改消息回调方法 function receiveAlterMsg(messages) { 对应处理自己的事 } //对应要发消息的地方调用如下 var obj={"shiXiangGuid":xxxxx}; alterInfoMessager.pushAlterMsg(obj);

dwr 使用的更多相关文章

  1. HTML5 WebSocket实现点对点聊天的示例代码

    这篇文章主要介绍了HTML5 WebSocket实现点对点聊天的示例代码的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  2. 浅谈ajax在jquery中的请求和servlet中的响应

    下面小编就为大家分享一篇浅谈ajax在jquery中的请求和servlet中的响应,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

  3. SpringBoot如何切换成其它的嵌入式Servlet容器(Jetty和Undertow)

    这篇文章主要介绍了SpringBoot如何切换成其它的嵌入式Servlet容器(Jetty和Undertow),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  4. JSP+Servlet实现文件上传到服务器功能

    这篇文章主要为大家详细介绍了JSP+Servlet实现文件上传到服务器功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  5. 关于Ajax技术中servlet末尾的输出流

    这篇文章主要介绍了关于Ajax技术中servlet末尾的输出流的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下

  6. javascript请求servlet实现ajax示例(分享)

    下面小编就为大家带来一篇javascript请求servlet实现ajax示例(分享)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  7. Javaweb动态开发最重要的Servlet详解

    动态web的核心是Servlet,由tomcat解析并执行,本质是Java中的一个类(面向对象)这个类的功能十分强大几乎可以完成全部功能,在Java规范中只有Servlet实现类实例化的对象才能被浏览器访问,所以掌握Servlet具有重要意义

  8. Java Servlet生成JSON格式数据并用jQuery显示的方法

    这篇文章主要介绍了Java Servlet生成JSON格式数据并用jQuery显示的方法,涉及jsp基于Servlet操作json数据及使用jQuery显示的相关技巧,需要的朋友可以参考下

  9. JavaWeb Servlet生命周期细枝末节处深究

    Servlet指在服务器端执行的一段Java代码,可以接收用户的请求和返回给用户响应结果,下面这篇文章主要给大家介绍了关于JavaWeb.servlet生命周期的相关资料,需要的朋友可以参考下

  10. JSP + Servlet实现生成登录验证码示例

    本篇文章主要介绍了JSP + Servlet实现登录验证码示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

随机推荐

  1. xe-ajax-mock 前端虚拟服务

    最新版本见Github,点击查看历史版本基于XEAjax扩展的Mock虚拟服务插件;对于前后端分离的开发模式,ajax+mock使前端不再依赖后端接口开发效率更高。CDN使用script方式安装,XEAjaxMock会定义为全局变量生产环境请使用xe-ajax-mock.min.js,更小的压缩版本,可以带来更快的速度体验。

  2. vue 使用 xe-ajax

    安装完成后自动挂载在vue实例this.$ajaxCDN安装使用script方式安装,VXEAjax会定义为全局变量生产环境请使用vxe-ajax.min.js,更小的压缩版本,可以带来更快的速度体验。cdnjs获取最新版本点击浏览已发布的所有npm包源码unpkg获取最新版本点击浏览已发布的所有npm包源码AMD安装require.js安装示例ES6Module安装通过Vue.use()来全局安装示例./Home.vue

  3. AJAX POST数据中文乱码解决

    前端使用encodeURI进行编码后台java.net.URLDecoder进行解码编解码工具

  4. Koa2框架利用CORS完成跨域ajax请求

    实现跨域ajax请求的方式有很多,其中一个是利用CORS,而这个方法关键是在服务器端进行配置。本文仅对能够完成正常跨域ajax响应的,最基本的配置进行说明。这样OPTIONS请求就能够通过了。至此为止,相当于仅仅完成了预检,还没发送真正的请求呢。

  5. form提交时,ajax上传文件并更新到&lt;input&gt;中的value字段

  6. ajax的cache作用

    filePath="+escape;},error:{alert;}});解决方案:1.加cache:false2.url加随机数正常代码:网上高人解读:cache的作用就是第一次请求完毕之后,如果再次去请求,可以直接从缓存里面读取而不是再到服务器端读取。

  7. 浅谈ajax上传文件属性contentType = false

    默认值为contentType="application/x-www-form-urlencoded".在默认情况下,内容编码类型满足大多数情况。在这里,我们主要谈谈contentType=false.在使用ajax上传文件时:在其中先封装了一个formData对象,然后使用post方法将文件传给服务器。说到这,我们发现在JQueryajax()方法中我们使contentType=false,这不是冲突了吗?这就是因为当我们在form标签中设置了enctype=“multipart/form-data”,

  8. 909422229_ajaxFileUpload上传文件

    ajaxFileUpload.js很多同名的,因为做出来一个很容易。我上github搜AjaxFileUpload出来很多类似js。ajaxFileUpload是一个异步上传文件的jQuery插件传一个不知道什么版本的上来,以后不用到处找了。语法:$.ajaxFileUploadoptions参数说明:1、url上传处理程序地址。2,fileElementId需要上传的文件域的ID,即的ID。3,secureuri是否启用安全提交,默认为false。4,dataType服务器返回的数据类型。6,error

  9. AJAX-Cache:一款好用的Ajax缓存插件

    原文链接AJAX-Cache是什么Ajax是前端开发必不可少的数据获取手段,在频繁的异步请求业务中,我们往往需要利用“缓存”提升界面响应速度,减少网络资源占用。AJAX-Cache是一款jQuery缓存插件,可以为$.ajax()方法扩展缓存功能。

  10. jsf – Ajax update/render在已渲染属性的组件上不起作用

    我试图ajax更新一个有条件渲染的组件。我可以确保#{user}实际上是可用的。这是怎么引起的,我该如何解决呢?必须始终在ajax可以重新呈现之前呈现组件。Ajax正在使用JavaScriptdocument.getElementById()来查找需要更新的组件。但是如果JSF没有将组件放在第一位,那么JavaScript找不到要更新的内容。解决方案是简单地引用总是渲染的父组件。

返回
顶部