百度百科对DWR的介绍:DWR(Direct Web Remoting)是一个用于改善web页面与Java类交互的远程服务器端Ajax开源框架,可以帮助开发人员开发包含AJAX技术的网站。它可以允许在浏览器里的代码使用运行在WEB服务器上的JAVA方法,就像它就在浏览器里一样。
一脸蒙蔽的接触DWR,使用中才发现原来还可以这样神奇的调用java代码(原谅小白的无知,见识太少了)…..不说废话了,直接进入主题:
这里只是我使用dwr的案例,详细的介绍请看阿里云教程
第一:创建项目后引入jar包主要有
1.dwr.jar 链接: https://pan.baidu.com/s/16bU3ybjLDkMU-0kOQ_lzew 密码: gdwf
2.commons-logging.jar 链接: https://pan.baidu.com/s/15BedNlXqLpWy4qdJ8tNZHA 密码: kya9
第二:配置web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> <display-name></display-name>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
<!-- 配置DWR -->
<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-app>
第三:配置dwr.xml,注意这里的dwr名称是不能改变的,与web.xml目录同级
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 1.0//EN" "http://www.getahead.ltd.uk/dwr/dwr10.dtd">
<dwr>
<allow>
<create creator="new" javascript="TestDwr"><!-- 类名 -->
<param name="class" value="com.ws2018.TestDwr"/><!-- 类路径 -->
<include method="add"/> <!-- 方法名 -->
<include method="diff"/>
<include method="getss"/>
</create>
</allow>
</dwr>
第四:在src中创建TestDwr类,路径就是dwr中param配置的value路径下
package com.ws2018;
public class TestDwr {
public TestDwr () {}
//这是我随便写的测试方法
public String add(String str1, String str2){
System.out.println(str1+str2);
String str3 = str1 + str2;
return str3;
}
public String diff(String str1, String str2){
System.out.println(str1+str2);
String str3 = str1 + str2;
return str3;
}
public String getss(String str1, String str2){
System.out.println(str1+str2);
String str3 = str1 + str2;
return str3;
}
}
第五:写前段代码(可以是html,jsp)特别注意三个关键点路径都不用改,而且你会发现你更找不到路径,以及路径下的文件,我们只需要改关键1中的TestDwr名称为自己写的java类名称
<script type='text/javascript' src='/dwr/interface/TestDwr.js'></script>//关键1
<script type='text/javascript' src='/dwr/engine.js'></script>//关键2
<script type='text/javascript' src='/dwr/util.js'></script>//关键3
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />//编码不然可能乱码
<script type="text/javascript" src="/js/select/script/jquery-1.8.3.min_wev8.js"></script>//这个文件是是为了使用jQuery
<script>
function fncallback(o) {
$("#testmsg").val(o);
return ;
}
function fnTestDwr() {
TestDwr.add("小白","成长记",{callback: function(o){ $("#testmsg").val(o);}});
}
</script>
</head>
<body>
<div>test my dwr</div>
<div><input type="button" onclick="fnTestDwr()" name="test" value ="test"/></br>msg<input type="text" id="testmsg"/></div>
</body>
</html>
效果图:
到这里我的测试就结束了,下面就是我的一个采坑问题
浏览器后台请求结果显示:allowScriptTagRemoting is false 允许脚本标签远程 是 false我们就配置一个param允许远程,在web.xml标签中
<servlet>
<servlet-name>dwr-invoker</servlet-name>
<servlet-class>uk.ltd.getahead.dwr.DWRServlet</servlet-class>
<init-param>
<param-name>allowScriptTagRemoting</param-name >
<param-value>true </param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
使用DWR有时候会弹出session error,解决方式是继续配置web.xml标签,添加crossDomainSessionSecurity配置(不过听说不安全,待测试中….)
<servlet>
<servlet-name>dwr-invoker</servlet-name>
<servlet-class>uk.ltd.getahead.dwr.DWRServlet</servlet-class>
<init-param>
<param-name>crossDomainSessionSecurity</param-name>
<param-value>false</param-value>
</init-param>
<init-param>
<param-name>allowScriptTagRemoting</param-name >
<param-value>true </param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
以上是小白今天初次使用dwr以及遇到的问题,很多说法不专业,希望大家多多指正。