DWR框架简单实例 (http://my.oschina.net/u/1790925/blog/366346)
文章转自《http://my.oschina.net/u/1790925/blog/366346》,感谢大牛分享!
DWR框架简单实例
1、从DWR官网下载最新版本的jar包,地址:http://directwebremoting.org/dwr/downloads/index.html
2、将jar包放入WEB-INF的lib文件夹下。同时,dwr依赖于commons-logging.jar这个包,所以必须将这个jar包也放入到WEB-INF的lib文件夹下。
3、配置dwr的环境:
a)配置web.xml文件.
servlet
servlet-name dwr-invoker /servlet-name
servlet-class uk.ltd.getahead.dwr.DWRServlet /servlet-class
init-param
param-name debug /param-name
param-value true /param-value
/init-param
/servlet
servlet-mapping
servlet-name dwr-invoker /servlet-name
url-pattern /dwr/* /url-pattern
/servlet-mapping
web.xml中其他配置不影响,正常配置即可
b)配置dwr
?xml version="1.0" encoding="UTF-8"?
!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 2.0//EN"
"http://www.getahead.ltd.uk/dwr/dwr20.dtd"
!-- 关键配置 --
dwr
allow
create creator="new" javascript="Chat"
param name="class" value="com.epri.xts.wxqyh.app.chatroom.module.Chat"/
/create
convert converter="bean" match="com.epri.xts.wxqyh.app.chatroom.bean.Message"/
/allow
/dwr
!--
!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 1.0//EN" "http://www.getahead.ltd.uk/dwr/dwr10.dtd"
!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 2.0//EN" "http://www.getahead.ltd.uk/dwr/dwr20.dtd"
--
dwr.xml是dwr的核心配置文件,主要的标签有: converter 、 convert 、 create 这三个标签。
create 标签是dwr中重要的标签,用来描述 java(服务器端) 与 javascript (客户端)的交互方式。其基本格式如下:
allow create creator="..." javascript="..." scope="..." param name="..." value="..."/ auth method="..." role="..."/ exclude method="..."/ include method="..."/ /create ... /allow
其中,creator和javascript是必须属性,其他可以忽略。creator包含有以下几个值:
new:Java用“new”关键字创造对象
none:它不创建对象 (v1.1+)
scripted:通过BSF使用脚本语言创建对象,例如BeanShell或Groovy
spring:通过Spring框架访问Bean
struts:使用Struts的FormBean (v1.1+)
jsf:使用JSF的Bean (v1.1+)
pageflow:访问Weblogic或Beehive的PageFlow (v1.1+)
ejb3:使用EJB3 session bean (v2.0+)
这里初学,实用java new创建对象。
4、页面配置
页面需要引入3个JS
script src=" %=ctxPath% /dwr/interface/Chat.js" type="text/javascript" /script script src=" %=ctxPath% /dwr/engine.js" type="text/javascript" /script script src=" %=ctxPath% /dwr/util.js" type="text/javascript" /script
其中engine.js必须要,如果需要用到dwr提供的一些方便的工具要引用util.js ,然后是dwr自动生成的js文件,名字必须和dwr.xml中create标签的javascript属性值一样,且必须是dwr/interface开头的目录
(千万不要这样干:曾经反编译别人代码学习时将这三个js反编译后放到本地。。结果无法执行。ps:必须要自己生成)
5、javascript代码:
// 发送消息 function sendMessage() { var text = DWRUtil.getValue("message"); if("" != text){ DWRUtil.setValue("message", ""); Chat.addMessage(text, name, taskId, gotMessages); function gotMessages(messages) { var chatlog = ""; for ( var data in messages) { chatlog = " div li " + messages[data].text + " /li /div DWRUtil.setValue("chatlog", chatlog); setTimeout("queryMessage()", 2000); function queryMessage() { Chat.getMessages(taskId, gotMessages); }
html代码
%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"% !DOCTYPE html String ctxPath = request.getContextPath(); html head title 聊天组 /title meta charset="utf-8" meta name="viewport" content="width=device-width, initial-scale=1" link rel="stylesheet" href="../css/jquery.mobile-1.4.5.min.css" link rel="stylesheet" type="text/css" href="../css/bootstrap.min.css" link rel="stylesheet" href="../css/add.css" script src="../js/jquery-1.8.3.min.js" /script script src="../js/jquery.mobile-1.4.5.min.js" /script /head body onload="queryMessage()" div data-role="page" id="pageone" !-- 聊天内容显示区域 -- div data-role="content" role="main" ul id="chatlog" /ul /div !-- 下方输入框 -- div data-position="fixed" data-role="footer" ul li span form action=" %=request.getContextPath()% /chat" method="post" enctype="multipart/form-data" data-ajax="false" name="form" id="form" target="relnews" input type="hidden" name="name" id="name" value="" / input type="hidden" name="taskId" id="taskId" value="" / input type="file" name="image" id="image" onchange="sendImage(this)" / /form /span /li li input type="text" name="fname" id="message" /li li a href="" data-role="button" id="submitInfo" onclick=sendMessage(); 发送 /a /li /ul /div /div !-- 隐藏域作为表单提交后页面不跳转使用 -- iframe align="center" frameborder="0" marginheight="0" marginwidth="0" name="relnews" id="hiddenIframe" scrolling="no" /iframe /body script src=" %=ctxPath% /dwr/interface/Chat.js" type="text/javascript" /script script src=" %=ctxPath% /dwr/engine.js" type="text/javascript" /script script src=" %=ctxPath% /dwr/util.js" type="text/javascript" /script script type="text/javascript" src="../js/chat.js" /script /html
6、其他
dwr可以设置是否采用异步方式访问java代码:
dwr.engine.setAsync(false); //false为同步,true(默认)为异步
以及dwr对于异常的处理,这里标注一个简单的全局异常,细分的后续学习补充:
dwr.engine.setErrorHandler(errh); function errh(errorString, exception) { errorFlag = true; alert("操作失败!"); }
相关文章
- IIS配置Asp.net时,出现“未能加载文件或程序集“System.Web.Extensions.Design, Version=1.0.61025.0”
- .NET插件系统之二——不实例化获取插件信息和可视化方法
- Asp.Net Mvc3.0(MEF依赖注入实例)
- asp.net sql无限极分类实例程序
- asp.net中C#获取字符串中汉字的个数实例
- asp.net输出重写压缩页面文件实例
- .net core 登入全局验证过滤器
- ASP.NET Core 6框架揭秘实例演示[35]:利用Session保留语境
- ASP.NET Core 6框架揭秘实例演示[34]:缓存整个响应内容
- ASP.NET Core 6框架揭秘实例演示[32]:错误页面的N种呈现方式
- ASP.NET Core 6框架揭秘实例演示[29]:搭建文件服务器
- 《ASP.NET Core 6框架揭秘》实例演示列表
- ASP.NET Core 6框架揭秘实例演示[28]:自定义一个服务器
- ASP.NET Core 6框架揭秘实例演示[27]:ASP.NET Core 6 Minimal API的模拟实现
- ASP.NET Core 6框架揭秘实例演示[21]:如何承载你的后台服务
- ASP.NET Core 6框架揭秘实例演示[14]:日志的进阶用法
- ASP.NET Core 6框架揭秘实例演示[05]:依赖注入基本编程模式
- ASP.NET Web API自身对CORS的支持:从实例开始
- COVID-Net工程源码详解(五) - data.py解析