ajax|重新整理|無重新整理
早就聽說Ajax技術了,傳說中是一種很牛的東西,號稱無重新整理,其實是在web上通過javascript,使用非同步xmlhttp請求,實現無重新整理的web介面。可惜一直沒有體驗過, 先後聽做PHP的朋友用過PHP的Ajax開發包,而且做了很多很酷的東西,使小生羨慕不已。
今天下了一個.net Ajax開發包,該開發包包括ASP2.0和目前ASP1.1版使用的Ajax,詳細地址參見http://ajax.schwarz-interactive.de/,接下來,開工。
1. 建立一個項目,在引用中添加引用Ajax.dll,Ajax.dll位於下載的壓縮包裡面。
2.建立HttpHandler,在web.config裡面加上 <configuration>
<system.web>
<httpHandlers>
<add verb="POST,GET" path="ajax/*.ashx" type="Ajax.PageHandlerFactory, Ajax" />
</httpHandlers>
...
<system.web>
</configuration>
3.建立一個類DemoMethods,這個類實現擷取用戶端MAC地址: using System;
using System.Web;
namespace AjaxSample
{
///
/// Summary description for Methods.
///
public class DemoMethods
{
[Ajax.AjaxMethod]
public string GetCustomerMac(string clientIP) //para IP is the client's IP
{
string mac = "";
System.Diagnostics.Process process = new System.Diagnostics.Process();
process.StartInfo.FileName = "nbtstat";
process.StartInfo.Arguments = "-a "+clientIP;
process.StartInfo.UseShellExecute = false;
process.StartInfo.CreateNoWindow = true;
process.StartInfo.RedirectStandardOutput = true;
process.Start();
string output = process.StandardOutput.ReadToEnd();
int length = output.IndexOf("MAC Address = ");
if(length>0)
{
mac = output.Substring(length+14, 17);
}
process.WaitForExit();
return mac.Replace("-", "").Trim();
}
}
}
4.寫javascript,建立一個名為default,js檔案如下:
function GetMac()
{
var clientIP="192.168.0.1";
document.getElementById("Mac").value=DemoMethods.GetCustomerMac(clientIP).value
alert(DemoMethods.GetCustomerMac(clientIP).value);
}
5.在某個Aspx頁面放上一個html 的button
在頁面上 中引用default.js :
在INPUT的onclick事件中加上
value="用戶端擷取IP" >
6.修改Global.asax的Application_Start事件,設定Ajax的HandlerPath :
protected void Application_Start(Object sender, EventArgs e)
{
Ajax.Utility.HandlerPath = "ajax";
}
運行看看效果。是不是沒有重新整理就在伺服器端取到用戶端的MAC地址??
需要注意的是:該版本的.net Ajax需要手工在中Global.asax加上Ajax.Utility.HandlerPath = "ajax"; 設定檔web.config必須加上HttpHandler的配置資訊!
該開發包的新版本還沒有來得及體驗,估計新版本中會方便一些,可能會去掉手動的設定Global.asax的Application_Start事件中加上Ajax.Utility.HandlerPath = "ajax";以及其他麻煩的設定!期待ing……