DWR框架简单实例 (http://my.oschina.net/u/1790925/blog/366346)

前端之家收集整理的这篇文章主要介绍了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

@H_403_17@

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">

<!-- 关键配置 -->
<@H_502_200@dwr>

<@H_502_200@allow>

<@H_502_200@create creator="new" javascript="Chat">
<@H_502_200@param name="class" value="com.epri.xts.wxqyh.app.chatroom.module.Chat"/>
</@H_502_200@create>
<@H_502_200@convert converter="bean" match="com.epri.xts.wxqyh.app.chatroom.bean.Message"/>
</@H_502_200@allow>
</@H_502_200@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 (客户端)的交互方式。其基本格式如下:

<@H_502_200@allow> <@H_502_200@createcreator="..."javascript="..."scope="..."> <@H_502_200@paramname="..."value="..."/> <@H_502_200@authmethod="..."role="..."/> <@H_502_200@excludemethod="..."/> <@H_502_200@includemethod="..."/> </@H_502_200@create> ... </@H_502_200@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

<@H_502_200@scriptsrc="<%=ctxPath%>/dwr/interface/Chat.js"type="text/javascript"></@H_502_200@script> <@H_502_200@scriptsrc="<%=ctxPath%>/dwr/engine.js"type="text/javascript"></@H_502_200@script> <@H_502_200@scriptsrc="<%=ctxPath%>/dwr/util.js"type="text/javascript"></@H_502_200@script>


其中engine.js必须要,如果需要用到dwr提供的一些方便的工具要引用util.js,然后是dwr自动生成的js文件,名字必须和dwr.xml中create标签的javascript属性值一样,且必须是dwr/interface开头的目录

(千万不要这样干:曾经反编译别人代码学习时将这三个js反编译后放到本地。。结果无法执行。ps:必须要自己生成)

5、javascript代码

//发送消息 functionsendMessage(){ vartext=DWRUtil.getValue("message"); if(""!=text){ DWRUtil.setValue("message",""); Chat.addMessage(text,name,taskId,gotMessages); } } functiongotMessages(messages){ varchatlog=""; for(vardatainmessages){ chatlog="<div><liclass='even'>"+messages[data].text+"</li></div } DWRUtil.setValue("chatlog",chatlog); setTimeout("queryMessage()",2000); } functionqueryMessage(){ Chat.getMessages(taskId,gotMessages); }

HTML代码

<@H_502_200@%@pagelanguage="java"contentType="text/html;charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPEhtml> <@H_502_200@% StringctxPath=request.getContextPath(); %> <@H_502_200@html> <@H_502_200@head> <@H_502_200@title>聊天组</@H_502_200@title> <@H_502_200@Metacharset="utf-8"> <@H_502_200@Metaname="viewport"content="width=device-width,initial-scale=1"> <@H_502_200@linkrel="stylesheet"href="../css/jquery.mobile-1.4.5.min.css"> <@H_502_200@linkrel="stylesheet"type="text/css"href="../css/bootstrap.min.css"> <@H_502_200@linkrel="stylesheet"href="../css/add.css"> <@H_502_200@scriptsrc="../js/jquery-1.8.3.min.js"></@H_502_200@script> <@H_502_200@scriptsrc="../js/jquery.mobile-1.4.5.min.js"></@H_502_200@script> </@H_502_200@head> <@H_502_200@bodyclass="bgc"onload="queryMessage()"> <@H_502_200@divdata-role="page"id="pageone"> <!--聊天内容显示区域--> <@H_502_200@divdata-role="content"class="container"role="main"> <@H_502_200@ulclass="content-reply-Boxmg10"id="chatlog"> </@H_502_200@ul> </@H_502_200@div> <!--下方输入框--> <@H_502_200@divdata-position="fixed"data-role="footer"> <@H_502_200@ulclass="footer"> <@H_502_200@liclass="col-xs-3"> <@H_502_200@spanclass="b_pic"> <@H_502_200@formaction="<%=request.getContextPath()%>/chat"method="post" enctype="multipart/form-data"data-ajax="false"name="form" id="form"target="relnews"> <@H_502_200@inputtype="hidden"name="name"id="name"value=""/> <@H_502_200@inputtype="hidden"name="taskId"id="taskId"value=""/> <@H_502_200@inputtype="file"name="image"id="image"class="photo"onchange="sendImage(this)"/> </@H_502_200@form> </@H_502_200@span> </@H_502_200@li> <@H_502_200@liclass="col-xs-6"><@H_502_200@inputtype="text"name="fname"id="message"></@H_502_200@li> <@H_502_200@liclass="col-xs-4"><@H_502_200@ahref=""data-role="button" class="b_submit"id="submitInfo"onclick='sendMessage();'>发送</@H_502_200@a></@H_502_200@li> </@H_502_200@ul> </@H_502_200@div> </@H_502_200@div> <!--隐藏域作为表单提交后页面跳转使用--> <@H_502_200@iframealign="center"frameborder="0"marginheight="0"marginwidth="0" name="relnews"id="hiddenIframe"scrolling="no" style="width:100%;height:100%;display:none"></@H_502_200@iframe> </@H_502_200@body> <@H_502_200@scriptsrc="<%=ctxPath%>/dwr/interface/Chat.js"type="text/javascript"></@H_502_200@script> <@H_502_200@scriptsrc="<%=ctxPath%>/dwr/engine.js"type="text/javascript"></@H_502_200@script> <@H_502_200@scriptsrc="<%=ctxPath%>/dwr/util.js"type="text/javascript"></@H_502_200@script> <@H_502_200@scripttype="text/javascript"src="../js/chat.js"></@H_502_200@script> </@H_502_200@html>

6、其他

dwr可以设置是否采用异步方式访问java代码

dwr.engine.setAsync(false);//false为同步,true(默认)为异步

以及dwr对于异常的处理,这里标注一个简单的全局异常,细分的后续学习补充:

 dwr.engine.setErrorHandler(errh); functionerrh(errorString,exception){ errorFlag=true; alert("操作失败!"); }

猜你在找的Ajax相关文章