1、dwr配置篇之web.xmljavascript
1、最小配置 html
<servlet> <servlet-name>dwr-invoker</servlet-name> <servlet-class>uk.ltd.getahead.dwr.DWRServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>dwr-invoker</servlet-name> <url-pattern>/dwr/*</url-pattern> </servlet-mapping>
二、當咱們想看DWR自動生成的測試頁(Using debug/test mode)時,可在servlet配置中加上java
<init-param> <param-name>debug</param-name> <param-value>true</param-value> </init-param>
這個參數DWR默認是false。若是選擇true,咱們能夠經過http://localhost:port/app/dwr看到你部署的每一個DWR class。而且能夠測試java代碼的每一個方法是否運行正常。爲了安全考慮,在正式環境下你必定把這個參數設爲false。web
三、多個dwr.xml文件的配置可能有幾種狀況,咱們一一列舉。一個servlet,多個dwr.xml配置文件;多個servlet,每一個servlet對應一個或多個dwr.xml配置文件。 spring
3.一、一個servlet,多個dwr.xml配置 數組
<servlet> <servlet-name>dwr-invoker</servlet-name> <servlet-class>uk.ltd.getahead.dwr.DWRServlet</servlet-class> <init-param> <param-name>config-1</param-name> <param-value>WEB-INF/dwr1.xml</param-value> </init-param> <init-param> <param-name>config-2</param-name> <param-value>WEB-INF/dwr2.xml</param-value> </init-param> </servlet>
在這種配置下,param-name的值必須以config開頭。param-name能夠有>=0個。安全
若是沒有param-name,那麼將會讀 取WEB-INF/dwr.xml。若是有大於零個param-name,那麼WEB-INF/dwr.xml文件將不會被讀取。 服務器
3.二、多個servlet,每一個servlet對應一個或多個dwr.xml app
<servlet> <servlet-name>dwr-invoker</servlet-name> <servlet-class>uk.ltd.getahead.dwr.DWRServlet</servlet-class> </servlet> <servlet> <servlet-name>dwr-invoker1</servlet-name> <servlet-class>uk.ltd.getahead.dwr.DWRServlet</servlet-class> <init-param> <param-name>config-admin</param-name> <param-value>WEB-INF/dwr1.xml</param-value> </init-param> <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> <servlet-mapping> <servlet-name>dwr-invoker1</servlet-name> <url-pattern>/dwr1/*</url-pattern> </servlet-mapping>
在這種狀況下,咱們能夠根據J2EE security來控制權限,針對不一樣url,加不一樣的角色。 函數
2、dwr使用篇
1、調用沒有返回值和參數的JAVA方法
1.一、dwr.xml的配置
<dwr> <allow> <create creator="new" javascript="testClass" > <param name="class" value="com.dwr.TestClass" /> <include method="testMethod1"/> </create> </allow> </dwr> <allow>
標籤中包括能夠暴露給javascript訪問的東西。 <create>標籤中指定javascript中能夠訪問的java類,並定義DWR應當如何得到要進行遠程的類的實例。creator= "new"屬性指定java類實例的生成方式,new意味着DWR應當調用類的默認構造函數來得到實例,其餘的還有spring方式,經過與IOC容器 Spring進行集成來得到實例等等。javascript=" testClass "屬性指定javascript代碼訪問對象時使用的名稱。 <param>標籤指定要公開給javascript的java類名。 <include>標籤指定要公開給javascript的方法。不指定的話就公開全部方法。 <exclude>標籤指定要防止被訪問的方法。
1.二、javascript中調用
首先,引入javascript腳本
<script src="dwr/interface/testClass.js" src="dwr/interface/ testClass.js"></script> <script src="dwr/engine.js" src="dwr/engine.js"></script> <script src="dwr/util.js" src="dwr/util.js"></script>
其中TestClass.js是dwr根據配置文件自動生成的,engine.js和util.js是dwr自帶的腳本文件。
其次,編寫調用java方法的javascript函數 Function callTestMethod1(){ testClass.testMethod1(); }
2、調用有簡單返回值的java方法
2.一、dwr.xml的配置配置同1.1
<dwr> <allow> <create creator="new" javascript="testClass" > <param name="class" value="com.dwr.TestClass" /> <include method="testMethod2"/> </create> </allow> </dwr>
2.二、javascript中調用
首先,引入javascript腳本
其次,編寫調用java方法的javascript函數和接收返回值的回調函數
Function callTestMethod2(){
testClass.testMethod2(callBackFortestMethod2);
}
Function callBackFortestMethod2(data){
//其中date接收方法的返回值
//能夠在這裏對返回值進行處理和顯示等等 alert("the return value is " + data);
}
其中callBackFortestMethod2是接收返回值的回調函數
3、調用有簡單參數的java方法
3.一、dwr.xml的配置配置同1.1
<dwr> <allow> <create creator="new" javascript="testClass" > <param name="class" value="com.dwr.TestClass" /> <include method="testMethod3"/> </create> </allow> </dwr>
3.二、javascript中調用
首先,引入javascript腳本
其次,編寫調用java方法的javascript函數
Function callTestMethod3(){
//定義要傳到java方法中的參數
var data;
//構造參數
data = 「test String」;
testClass.testMethod3(data);
}
4、調用返回JavaBean的java方法
4.一、dwr.xml的配置
<dwr> <allow> <create creator="new" javascript="testClass" > <param name="class" value="com.dwr.TestClass" /> <include method="testMethod4"/> </create> <convert converter="bean" match=""com.dwr.TestBean"> <param name="include" value="username,password" /> </convert> </allow> </dwr> <creator>
標籤負責公開用於Web遠程的類和類的方法,<convertor>標籤則負責這些方法的參數和返回類型。
convert元素的做用是告訴DWR在服務器端Java 對象表示和序列化的JavaScript之間如何轉換數據類型。
DWR自動地在Java和JavaScript表示之間調整簡單數據類型。
這些類型包括Java原生類型和它們各自的封裝類表示,還有String、Date、數組和集合類型。
DWR也能把JavaBean轉換成JavaScript 表示,可是出於安全性的緣由,要求顯式的配置,<convertor>標籤就是完成此功能的。
Converter="bean"屬性指定轉換的方式採用JavaBean命名規範,match=""com.dwr.TestBean"屬性指定要轉換的javabean名稱,<param>標籤指定要轉換的JavaBean屬性。
4.二、javascript中調用
首先,引入javascript腳本
其次,編寫調用java方法的javascript函數和接收返回值的回調函數
Function callTestMethod4(){ testClass.testMethod4(callBackFortestMethod4); } Function callBackFortestMethod4(data){ //其中date接收方法的返回值 //對於JavaBean返回值,有兩種方式處理 //不知道屬性名稱時,使用以下方法 for(var property in data){ alert("property:"+property); alert(property+":"+data[property]); } //知道屬性名稱時,使用以下方法 alert(data.username); alert(data.password); }
其中callBackFortestMethod4是接收返回值的回調函數
5、調用有JavaBean參數的java方法
5.一、dwr.xml的配置配置同4.1
<dwr> <allow> <create creator="new" javascript="testClass" > <param name="class" value="com.dwr.TestClass" /> <include method="testMethod5"/> </create> <convert converter="bean" match="com.dwr.TestBean"> <param name="include" value="username,password" /> </convert> </allow> </dwr>
5.二、javascript中調用
首先,引入javascript腳本
其次,編寫調用java方法的javascript函數
Function callTestMethod5(){
//定義要傳到java方法中的參數
var data;
//構造參數,date其實是一個object
data = { username:"user", password:"password" }
testClass.testMethod5(data);
}
6、調用返回List、Set或者Map的java方法
6.一、dwr.xml的配置配置同4.1
<dwr> <allow> <create creator="new" javascript="testClass" > <param name="class" value="com.dwr.TestClass" /> <include method="testMethod6"/> </create> <convert converter="bean" match="com.dwr.TestBean"> <param name="include" value="username,password" /> </convert> </allow> </dwr>
注意:若是List、Set或者Map中的元素均爲簡單類型(包括其封裝類)或String、Date、數組和集合類型,則不須要<convert>標籤。
6.二、javascript中調用(以返回List爲例,List的元素爲TestBean)
首先,引入javascript腳本
其次,編寫調用java方法的javascript函數和接收返回值的回調函數
Function callTestMethod6(){ testClass.testMethod6(callBackFortestMethod6); } Function callBackFortestMethod6(data){ //其中date接收方法的返回值 //對於JavaBean返回值,有兩種方式處理 //不知道屬性名稱時,使用以下方法 for(var i=0;i<data.length;i++){ for(var property in data){ alert("property:"+property); alert(property+":"+data[property]); } } //知道屬性名稱時,使用以下方法 for(var i=0;i<data.length;i++){ alert(data.username); alert(data[i].username);//this is ok alert(data.password);//error } }
7、調用有List、Set或者Map參數的java方法 7
7.一、dwr.xml的配置
<dwr> <allow> <create creator="new" javascript="testClass" > <param name="class" value="com.dwr.TestClass" /> <include method="testMethod7"/> </create> <convert converter="bean" match="com.dwr.TestBean"> <param name="include" value="username,password" /> </convert> </allow> <signatures> <!--[CDATA[ import java.util.List; import com.dwr.TestClass; import com.dwr.TestBean; TestClass.testMethod7(List<TestBean>); ]]--> </signatures> </dwr>
<signatures>標籤是用來聲明java方法中List、Set或者Map參數所包含的確切類,以便java代碼做出判斷。
7.2javascript中調用(以返回List爲例,List的元素爲TestBean) 首先,引入javascript腳本其次,編寫調用java方法的javascript函數
Function callTestMethod7(){ //定義要傳到java方法中的參數 var data; //構造參數,date其實是一個object數組,即數組的每一個元素均爲 object data = [ { username:"user1", password:"password2" }, { username:"user2", password:" password2" } ]; testClass.testMethod7(data); }
注意:
1、對於第6種狀況,若是java方法的返回值爲Map,則在接收該返回值的javascript回調函數中以下處理:
function callBackFortestMethod(data){
//其中date接收方法的返回值
for(var property in data){
var bean = data[property];
alert(bean.username);
alert(bean.password);
}
}
2、對於第7種狀況,若是java的方法的參數爲Map(假設其key爲String,value爲TestBean),則在調用該方法的javascript函數中用以下方法構造要傳遞的參數:
function callTestMethod (){
//定義要傳到java方法中的參數
var data;
//構造參數,date其實是一個object,其屬性名爲Map的key,屬性值爲Map的value
data = {
"key1":{
username:"user1",
password:"password2"
},
"key2":{
username:"user2",
password:" password2"
}
};
testClass.testMethod(data);
}
而且在dwr.xml中增長以下的配置段
<signatures>
<![CDATA[ import java.util.List;
import com.dwr.TestClass;
import com.dwr.TestBean;
TestClass.testMethod7(Map<String,TestBean>);
]]>
</signatures>
3、由以上能夠發現,對於java方法的返回值爲List(Set)的狀況,DWR將其轉化爲Object數組,傳遞個javascript;對於 java方法的返回值爲Map的狀況,DWR將其轉化爲一個Object,其中Object的屬性爲原Map的key值,屬性值爲原Map相應的 value值。
4、若是java方法的參數爲List(Set)和Map的狀況,javascript中也要根據3種所說,構造相應的javascript數據來傳遞到java中。
8.前臺經過Form傳值:
8.1 前臺填寫方法:
function formSubmit(){ var formData = DWRUtil.getValues("表單名"); javascript類.方法(formData,loginResut); } function loginResut(data){//回調函數 //data用來接受後臺傳回的數據 //若是是List類型 data[i]; //若是是Map類型 data["params"]; }
8.2後臺接受form參數方法:
/** * 店鋪管理員登錄的時候檢查用戶名、密碼、驗證碼 * @param userForm * @return */ public String checkMerchantMngLogin(Map merchantForm) throws Exception{ //接受後要轉換的類型 LoginForm loginForm = new LoginForm(); //前臺信息轉換 BeanUtils.populate(loginForm, merchantForm); //經過方法就可得到數據 loginForm.getUserName(); }