DWR基本环境配置,回调函数不执行问题

本文介绍了DWR基本环境配置的过程,并针对回调函数不执行的问题进行了详细排查。通过修改dwr.xml和web.xml文件的配置参数,解决了跨域安全性和脚本标签远程调用的限制,成功实现了回调函数的执行。
摘要由CSDN通过智能技术生成

利用一个传入的姓名,然后给该姓名说“你好,XXX”的程序来测试基本环境的搭建。

1、下载DWR.zip后将其解压。

2、在eclipse的WebContent下的WEB-INF下的lib文件夹下拷入dwr.jar(该jar文件在解压后的DWR根目录下)。

3、在eclipse的WebContent下建立一个js文件夹,然后从解压后的DWR根文件夹下的java\org\directwebremoting下的util.js和engine.js两个文件拷贝到该js文件夹下。

4、下载在项目的src目录下建立一个类:

public class SayHello {

 public SayHello() {
  
 }
 
 public String say(String name) {
  return "Hello," + name;
 }
}

5、在WEB-INF目录下与web.xml文件同级目录下创建一个dwr.xml(该文件从解压后的DWR根文件夹下的web\WEB-INF文件夹下拷贝dwr.xml文件到此处后进行修改)。

修改后为:

<dwr>
  <allow>
 <create javascript="sayHello" creator="new">
  <param name="class" value="dwr01.service.SayHello"></param>
 </create>
  </allow>
</dwr>

6、在WebContent文件夹下创建一个index.jsp。

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
<script type="text/javascript" src="js/dwr/util.js"></script>
<script type="text/javascript" src="js/dwr/engine.js"></script>

//此处必须是dwr/interface开头,sayHello.js的文件名必须和dwr.xml文件中配置的create标签的javascript属性名字相同
<script type="text/javascript" src="dwr/interface/sayHello.js"></script>
<script type="text/javascript" src="js/service/sayHello/sayHello_say.js"></script>
</head>
<body>

 <input type="text" name="userName" id="userName" />
 <input type="button" value="点击我吧......" id="sayButton" />
</body>
</html>

最后引入的sayHello_say.js是自己创建的一个调用第4步SayHello类中say()方法的一个js文件。

内容为:

$(document).ready(function() {
 var $sayButton = $("#sayButton");
 $sayButton.click(function() {
  say($("#userName").val());
 });
});

function say(userName) {
 sayHello.say(userName,callBackSay);//调用SayHello类中say()方法
}

//调用完say()方法后执行的回调函数传入参数data为该方法返回的值
function callBackSay(data) {
 alert(data);
}

7、现在来配置关键的web.xml文件。

在其中配置一个Servlet,虚拟路径为dwr/*。

内容为:

<servlet>
    <servlet-name>dwr-invoker</servlet-name>
    <servlet-class>org.directwebremoting.servlet.DwrServlet</servlet-class>

 <init-param>
    <param-name>debug</param-name>
    <param-value>true</param-value>
 </init-param>
 <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>

  <servlet-mapping>
    <servlet-name>dwr-invoker</servlet-name>
    <url-pattern>/dwr/*</url-pattern>
  </servlet-mapping>

参数crossDomainSessionSecurity默认值为true,在默认时同时参数allowScriptTagRemoting未设置是,在调用完类的方法后回调函数不会执行,日志会打出:

org.directwebremoting.util.CommonsLoggingOutput error
严重: A request has been denied as a potential CSRF attack.

解决这个问题的办法是:将参数crossDomainSessionSecurity设为false。表示其能够从其他域进行请求,需要注意的是这样做可能会出现安全性的问题。

当将参数crossDomainSessionSecurity设为false后再次调用类方法会发下,虽然日志打出:

org.directwebremoting.util.CommonsLoggingOutput info
信息: Exec: sayHello.say()

提示执行SayHello类的say()方法成功,但是任然没有执行回调函数。解决的办法是设定另外一个参数的值来解决次问题。

将参数allowScriptTagRemoting的值设为true,意思为允许脚本标签远程调用。

再来试试程序,点击页面上的名为“点我吧......”的按钮,发现程序运行成功,在调用了SayHello类的say()方法后,成功返回了打招呼的语句。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值