权限管理 (三)DWR实现异步通信

前端之家收集整理的这篇文章主要介绍了权限管理 (三)DWR实现异步通信前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
  • dwr用途

DWR(Direct Web Remoting)是一个用于改善web页面与Java类交互的远程服务器端Ajax开源框架,可以帮助开发人员开发包含AJAX技术的网站。在.NET中已经有很多类似的框架,例如Jquery、javascript等。

  • 小例子

以一个经典的HelloWorld()来实现以下异步提交,首先需要引入dwr.jar包,然后,在web.xml里面配置DWR信息,如下

<?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">
  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>
  <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>
  </servlet>
  <servlet-mapping>
    <servlet-name>dwr-invoker</servlet-name>
    <url-pattern>/dwr/*</url-pattern>
  </servlet-mapping>   
</web-app>


服务器端的java类,包含需要调用方法

public class test1 {
	public String hello(){
		return "hello world!";
	}
}


在dwr.xml里面需要配置以下界面中接口对应的java类

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 2.0//EN" "http://getahead.org/dwr/dwr20.dtd">
<dwr>
  <allow>
    <create creator="new" javascript="T1">
      <param name="class" value="com.bjsxt.oa.dwrtest.test1"/>
    </create>
  </allow>
</dwr>


在界面中引入如下js文件,即可调用

<script type="text/javascript" src="dwr/engine.js"></script>
<script type="text/javascript" src="dwr/util.js"></script>
<script type="text/javascript" src="dwr/interface/T1.js"></script>
<script type="text/javascript">
function test1(){
	T1.hello(
		function(data){
			alert(data);
		}
	);
}

</script>


效果

猜你在找的Ajax相关文章