題外話:
webservice技術已經有好幾年的歷史了,關于基礎的理論知識,此處省去,不說了。最近被炒了的ajax技術也被濫用的很是嚴重,至于細節,不是我說的重點。
ajax技術的入門比較低,javascript和xml的一點利用,個人以為沒啥含量,不能在根本上解決企業的需求或者問題,在安全性,線路傳輸的低級等方面都有致命的問題.
為什么要把webservice和ajax放一起,原因很簡單, 兩者的共同點準確的來說是經常按照同一數據協議--------xml.
本文全部源碼:userapp.rar
本文既不說明ajax的弱,也不說webservice的強大,只是通過一個例子說明了如何使用webservice技術和ajax技術.
我通過實例“用戶登陸”展示how.
在本地建立一個虛擬目錄userapp。
先創建一個webservice:
namespace cjjer{
using system;
using system.web.services;
[webservice (name="webscjjer",description="一個驗證用戶登陸的web服務",namespace="http://www.cjjer.com/webs/")]
public class userservice{
[webmethod (description ="輸入用戶名和密,返回權限int值,0表示失敗",messagename="login")]
public int login(string username,string userpassword){
return user.check(username,userpassword);
}
};
}
我們暫時不看細節,注意這是這個class有頭webservice,標記了這是一個web服務.
csc編譯掉,放入bin目錄,然后login.asmx文件:
<%@webservice class="cjjer.userservice"%>
我先不說驗證的細節,我們先假設user.check()返回的是用戶級別,0表示驗證失敗.
現在在url中輸入地址,訪問:如圖
點擊login:
輸入正確的用戶名和密碼,然后點擊調用:
如果不是正確的用戶名和密碼,將int節點值是0.
我們本地的調用是在soap操作.
還有很多方式:
soap(最低級的)
soap的這里不說,以后會詳細說,我這里注意看的是get和post方式:
http get
面是一個 http get 請求和響應示例。所顯示的占位符需要由實際值替換。
get /userapp/login.asmx/login?username=string&userpassword=string http/1.1
host: s
return:
http/1.1 200 ok
content-type: text/xml; charset=utf-8
content-length: length
<?xml version="1.0" encoding="utf-8"?>
<int xmlns="http://www.cjjer.com/webs/">int</int>
http post
下面是一個 http post 請求和響應示例。所顯示的占位符需要由實際值替換。
post /userapp/login.asmx/login http/1.1
host: s
content-type: application/x-www-form-urlencoded
content-length: length
username=string&userpassword=string
return:
http/1.1 200 ok
content-type: text/xml; charset=utf-8
content-length: length
<?xml version="1.0" encoding="utf-8"?>
<int xmlns="http://www.cjjer.com/webs/">int</int>
我們可以輸入url的地址,或者post的action,就可以訪問和提交獲取結果了.
此處可以選擇的操作其實也很多,使用屏幕清理技術,還可以用xml的處理框架提交信息的結果,也可以用其他技術,不說了,反正都是貌似需要幾十行或者比我下面多一些處理。
我說的是使用sdk的工具wsdl工具處理代理的web服務.
wsdl /l:cs /out:webscjjer.cs /namespace:webs /urlkey:websuser /nologo http://s:81/userapp/login.asmx?wsdl
得到webscjjer.cs源文件。
注意:/urlkey:websuser表示是url可以是從web.config文件的websuser獲取,這樣做是避免硬編碼,看看webscjjer.cs
.......
public webscjjer() {
string urlsetting = system.configuration.configurationsettings.appsettings["websuser"];
if ((urlsetting != null)) {
this.url = urlsetting;
}
else {
this.url = "http://s:81/userapp/login.asmx";
}
}
.......
為了能被其他的人訪問,需要加入如下代碼到web.config:
<system.web>
<webservices>
<protocols>
<add name="httppost"/>
<add name="httpget"/>
</protocols>
</webservices>
就是代理許可.
編譯了這個類,到bin,使用的時候如下:
void onlogin(object s,eventargs e){
webs.webscjjer ws_app = new webs.webscjjer();
returnint.text = ws_app.login(myusername.text,mypassword.text).tostring();
}
這樣,直接能返回結果,不需要我們自己正則或者xml處理,不需要知道驗證的細節。
新聞熱點
疑難解答
圖片精選