1. 程式人生 > >Javascript通過dwr呼叫Java程式碼

Javascript通過dwr呼叫Java程式碼

1.首先,建立一個簡單的空的web工程 HelloWorld 工程結構 2.然後開始配置dwr的環境

DWR簡介 DWR全稱Direct Web Remoting,是一款非常優秀的遠端過程呼叫(Remote Procedure Call)框架,通過瀏覽器提供的Ajax引擎實現在前端頁面的JS程式碼中呼叫服務端Java程式碼。使用它我們可以非常方便的和服務端進行互動,輕鬆獲取服務端返回的資料。 下面是DWR官方網站地址: http://www.directwebremoting.org/dwr/introduction/index.html

DWR的使用

接下來我們看一下如何使用這款框架: 獲取DWR所需Jar包

下載完成後將兩個jar包拷貝到web工程的WEB-INF/lib目錄下。

加入之後工程架構如下

在這裡插入圖片描述

3.環境配置完成之後,開始配置檔案。 首先,我們來配置web.xml檔案,在WEB-INF目錄下建立web.xml檔案,配置資訊如下;

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
  <display-name>dwr_web</display-name>
  <welcome-file-list> 
    <welcome-file>index.jsp</welcome-file> 
  </welcome-file-list>
 
  <servlet>
    <servlet-name>dwr</servlet-name>
    <servlet-class>org.directwebremoting.servlet.DwrServlet</servlet-class>
    <init-param>
     <param-name>debug</param-name>
     <param-value>true</param-value>
    </init-param>
  </servlet>
  <servlet-mapping>
    <servlet-name>dwr</servlet-name>
    <url-pattern>/dwr/*</url-pattern>
  </servlet-mapping>
</web-app>

配置檔案中暫時不用改動,預設即可,配置完之後繼續配置dwr.xml配置檔案 在web.xml相同的目錄下建立一個dwr.xml檔案,配置資訊如下

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE dwr PUBLIC
    "-//GetAhead Limited//DTD Direct Web Remoting 3.0//EN"
    "http://getahead.org/dwr/dwr30.dtd">
 
<dwr> 
    <allow>
        <create creator="new" javascript="helloWorldService">
            <param name="class" value="com.shinion.test.HelloWorldService"></param>
        </create>
    </allow>
 </dwr>

helloWorldService 為需要建立的類的別名,我們在頁面中呼叫就使用這個類名,也可以起別的名字,當然,和類同名最好,value是類的路徑 如果以後需要新增類,那麼要在標籤中新增

4.下一步,我們來實現類 類的程式碼如下

package com.shinion.test;

public class HelloWorldService {
	
	public String getInfo(String msg) {
		
		return "Hello World ! "+ msg;
	}
}

注意包名要和dwr.xml配置檔案中的包名相同

在這裡插入圖片描述

能看到我們建立的類已經能顯示出來了 點選,然後出現下面的結果

在這裡插入圖片描述

在我們寫的getInfo()這個方法中隨便填寫資訊

在這裡插入圖片描述

證明我們的程式碼有效 5.頁面實現呼叫 最後一步,也是最重要的一步,頁面上的呼叫 我們在根目錄下,建立一個index.jsp頁面,位置如下圖 在這裡插入圖片描述 頁面程式碼如下:

<html>
<head>
<meta charset="UTF-8"/>
<title> index</title>
<script type='text/javascript' src='/HelloWorld/dwr/engine.js'></script>
  <script type='text/javascript' src='/HelloWorld/dwr/interface/helloWorldService.js'></script>

</head>


<body>

<p>hello</p>
<button onclick="getInfo()">test button</button>
<script type="text/javascript">

var getInfo = function(){
	return helloWorldService.getInfo("pidoo",callBack);
};

var callBack=function(data){
	alert(data);
};

</script>
</body>
</html>

注意引用的兩個js檔案 好了,結束,可以釋出測試了 在這裡插入圖片描述

大功告成!