初次体验.net Ajax无刷新技术
2007-10-20 20:41
597 查看
今天下了一个.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>
/// Summary description for Methods.
/// </summary>
public class DemoMethods
{
[Ajax.AjaxMethod]
public string GetCustomerMac(string clientIP) //这里输入客户端IP,这个函数知识测试用,你也可以写一个其
4000
他的简单一点的函数代替
{
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
在页面上<head>中引用default.js : <script language="javascript" src="default.js"></script>
在INPUT的onclick事件中加上onclick="javascript:GetMac()"
<INPUT style="Z-INDEX: 101; LEFT: 392px; POSITION: absolute; TOP: 176px" type="button"
value="客户端获取IP" onclick="javascript:GetMac();">
private void Page_Load(object sender, System.EventArgs e)
{
// 在此处放置用户代码以初始化页面
Ajax.Utility.RegisterTypeForAjax(typeof(AjaxSample.DemoMethods));
}
注意:typeof(AjaxSample.DemoMethods)中,AjaxSample是命名空间,DemoMethods是要包含要调用方法的类,即上面第3步.新建类DemoMethods
7.修改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……
function GetMac()
{
var clientIP="192.168.0.1";
document.getElementById("Mac").value=DemoMethods.GetCustomerMac(clientIP).value
alert(DemoMethods.GetCustomerMac(clientIP).value);
}
里边的这一行:document.getElementById("Mac")
"Mac"是什么东西的标示?
欧,大概懂了,应该是个label之类的冬冬。
不错不错
你这哪是取得客户端IP?明明是服务端的嘛,你测试了没?
default.js中是如何定位客户端IP的,你这里用var clientIP="192.168.0.1";
能行吗?能在外网使用吗?
to interMac
是一个input或TextBox,id是Mac,这里我已经注释掉了,可以不用
to 冰戈
这个函数知识测试Ajax用,IP你可以输入你自己的IP试试,
你还可以写一个简单一点的函数
[Ajax.AjaxMethod]
public string GetServerTime()
{
return System.DateTime.Now.ToString();
}
在default.js里面加上一个方法:
function JSGetServerTime()
{
alert(NetAjax.WebForm1.GetServerTime().value);
}
在客户端调用JSGetServerTime就可以了,
冰戈,这个怎么不是取得客户端的?他服务器端执行nbtstat -a XXX.XXX.XXX.XXX,而这个IP就是客户端的IP,所以取到的肯定是客户端的IP啊。再说这本来就只是一个例子而以,若要真是取客户端IP用这样来做嘛?
和使用javascript调用webservice有什么不同……
基本原理是使用异步的xmlhttp请求。
当然也可以用javascript调用webservice来实现!
呵呵,不好意思,我测试的时候没注意修改clientIP
function GetMac()
{
var clientIP="192.168.0.1";
//document.getElementById("Mac").value=DemoMethods.GetCustomerMac(clientIP).value;
alert(DemoMethods.GetCustomerMac(clientIP).value);
}
所以感觉是错的,后来发现问题所在了,赶紧过来看看,就遭到 風語者·疾風 的质疑,呵呵,不好意思……
谢谢各位的支持!
如果有好的建议请提出,或者有好的Ajax方面的资料请和我联系!
jrt324@126.com
我得到的结果是
undefined
是不是必须用.net 2.0?? 我是在1.1下做的测试
终于成了! 原来我把 value 写成了 Value
一个字符之差!!
看来javascript还需多下功夫学学呢!
to sunny
可以了吗?
问:
如果我在后台需要处理页面上一些控件比如:textbox里的数据,你还得从javascript的函数里穿到后台吧
如果直接在后台得,是得不到的
to 存在所以孤独
当然可以得到的!当你在在服务器端取到textbox的值如
[Ajax.AjaxMethod]
public string GetTextBoxValue()
{
return Text1.text;
}
在default.js里面加上一个方法:
function JSGetText()
{
alert(NetAjax.WebForm1.GetTextBoxValue().value);
}
很简单!
to:代码乱了,不知道该怎么办!
呵呵,我想你误会的意思了.我的意思是这样:
比如,我一开始用的是有刷新的:
<asp:button id="AddButton" Runat="server" Text="添 加"></asp:button>
.cs里的方法是:
private void Add_Click(object sender, System.EventArgs e)
{
try
{
string name = this.Nametxt.value;
string age = this.Agetxt.value
Model.PerpleInfo Info = new PerpleInfo (name,age);
BLL.Perple.insert(Info );
}
catch(Exception ex)
{
.......
}
}
==============================================
但是用了你的方法,就得这样了:
[Ajax.AjaxMethod()]
public void Add(string name,string age)
{
string name = name;//用string name = this.Name.value行么??
string age = age
.........
}
是不是这样的?你在.cs里想用页面的数据,就得用传递到后台了,对不?
[Ajax.AjaxMethod()]
public void Add(string name,string age)
{
string name = name;//用string name = this.Name.value行么??-
//用string name = this.Name.value行么??-可以的
string age = age
.........
}
但是我还没有明白你的意思!你想实现什么?能再说清楚一点吗?
to:代码乱了,不知道该怎么办!
你有msn么:偶的是 zklvy@hotmail.com 在这个上和你说吧
我的意思是,你想执行一个插入操作,当然插入的数据来自页面
你直接用
public void Add()
{
string name = this.Name.value;
//这步不能得到数据name是null
//你自己测试一下就知道了
}
我最近都没有用MSN
我的MSN:jrt324@126.com
QQ:54433048
为什么最后没有值呢?
length=-1
请楼主再告知一下,谢谢了
楼主麻烦你解释一下,这几句话的意思!
process.StartInfo.FileName = "nbtstat";
process.StartInfo.Arguments = "-a "+clientIP;
process.StartInfo.UseShellExecute = false;
process.StartInfo.CreateNoWindow = true;
process.StartInfo.RedirectStandardOutput = true;
谢谢了!!!
看不懂啊,楼主能不能加点注释,好方便我们这些入门者看。
nbtstat 好像只能查一个子网里的
你的demo能运行吗?????????????????
按你的步骤做能成功吗——失败???????????
document.getElementById("Mac").value=DemoMethods.GetCustomerMac(clientIP).value;
alert(DemoMethods.GetCustomerMac(clientIP).value);
是错误的代码啊 JS里怎么能调用CS里的代码呢
还请指教啊
只能获取局域网里的啊,放到服务器就得到的值就为null了
@冰凝
是的,我只是作一个演示而已
没有连接成功就会返回空.
6.在page页面的Page_Load事件中加上
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>
/// Summary description for Methods.
/// </summary>
public class DemoMethods
{
[Ajax.AjaxMethod]
public string GetCustomerMac(string clientIP) //这里输入客户端IP,这个函数知识测试用,你也可以写一个其
4000
他的简单一点的函数代替
{
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
在页面上<head>中引用default.js : <script language="javascript" src="default.js"></script>
在INPUT的onclick事件中加上onclick="javascript:GetMac()"
<INPUT style="Z-INDEX: 101; LEFT: 392px; POSITION: absolute; TOP: 176px" type="button"
value="客户端获取IP" onclick="javascript:GetMac();">
private void Page_Load(object sender, System.EventArgs e)
{
// 在此处放置用户代码以初始化页面
Ajax.Utility.RegisterTypeForAjax(typeof(AjaxSample.DemoMethods));
}
注意:typeof(AjaxSample.DemoMethods)中,AjaxSample是命名空间,DemoMethods是要包含要调用方法的类,即上面第3步.新建类DemoMethods
7.修改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……
Feedback
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2005-09-19 13:12 by InterMa 的 Blogfunction GetMac()
{
var clientIP="192.168.0.1";
document.getElementById("Mac").value=DemoMethods.GetCustomerMac(clientIP).value
alert(DemoMethods.GetCustomerMac(clientIP).value);
}
里边的这一行:document.getElementById("Mac")
"Mac"是什么东西的标示?
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2005-09-19 13:15 by InterMa 的 Blog欧,大概懂了,应该是个label之类的冬冬。
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2005-09-19 14:27 by 拙劣的程序员不错不错
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2005-09-19 14:30 by 冰戈你这哪是取得客户端IP?明明是服务端的嘛,你测试了没?
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2005-09-19 14:36 by №阿儒№default.js中是如何定位客户端IP的,你这里用var clientIP="192.168.0.1";
能行吗?能在外网使用吗?
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2005-09-19 14:49 by 代码乱了,不知道该怎么办!to interMac
是一个input或TextBox,id是Mac,这里我已经注释掉了,可以不用
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2005-09-19 14:53 by 代码乱了,不知道该怎么办!to 冰戈
这个函数知识测试Ajax用,IP你可以输入你自己的IP试试,
你还可以写一个简单一点的函数
[Ajax.AjaxMethod]
public string GetServerTime()
{
return System.DateTime.Now.ToString();
}
在default.js里面加上一个方法:
function JSGetServerTime()
{
alert(NetAjax.WebForm1.GetServerTime().value);
}
在客户端调用JSGetServerTime就可以了,
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2005-09-19 15:11 by 風語者·疾風冰戈,这个怎么不是取得客户端的?他服务器端执行nbtstat -a XXX.XXX.XXX.XXX,而这个IP就是客户端的IP,所以取到的肯定是客户端的IP啊。再说这本来就只是一个例子而以,若要真是取客户端IP用这样来做嘛?
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2005-09-19 15:25 by Magicloud和使用javascript调用webservice有什么不同……
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2005-09-19 15:28 by 代码乱了,不知道该怎么办!基本原理是使用异步的xmlhttp请求。
当然也可以用javascript调用webservice来实现!
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2005-09-19 15:43 by 冰戈呵呵,不好意思,我测试的时候没注意修改clientIP
function GetMac()
{
var clientIP="192.168.0.1";
//document.getElementById("Mac").value=DemoMethods.GetCustomerMac(clientIP).value;
alert(DemoMethods.GetCustomerMac(clientIP).value);
}
所以感觉是错的,后来发现问题所在了,赶紧过来看看,就遭到 風語者·疾風 的质疑,呵呵,不好意思……
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2005-09-19 16:49 by 代码乱了,不知道该怎么办!谢谢各位的支持!
如果有好的建议请提出,或者有好的Ajax方面的资料请和我联系!
jrt324@126.com
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2005-09-20 11:44 by sunny我得到的结果是
undefined
是不是必须用.net 2.0?? 我是在1.1下做的测试
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2005-09-20 11:47 by sunny终于成了! 原来我把 value 写成了 Value
一个字符之差!!
看来javascript还需多下功夫学学呢!
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2005-09-20 13:07 by 代码乱了,不知道该怎么办!to sunny
可以了吗?
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2005-09-20 13:33 by 存在所以孤独问:
如果我在后台需要处理页面上一些控件比如:textbox里的数据,你还得从javascript的函数里穿到后台吧
如果直接在后台得,是得不到的
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2005-09-20 14:01 by 代码乱了,不知道该怎么办!to 存在所以孤独
当然可以得到的!当你在在服务器端取到textbox的值如
[Ajax.AjaxMethod]
public string GetTextBoxValue()
{
return Text1.text;
}
在default.js里面加上一个方法:
function JSGetText()
{
alert(NetAjax.WebForm1.GetTextBoxValue().value);
}
很简单!
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2005-09-20 14:14 by 存在所以孤独to:代码乱了,不知道该怎么办!
呵呵,我想你误会的意思了.我的意思是这样:
比如,我一开始用的是有刷新的:
<asp:button id="AddButton" Runat="server" Text="添 加"></asp:button>
.cs里的方法是:
private void Add_Click(object sender, System.EventArgs e)
{
try
{
string name = this.Nametxt.value;
string age = this.Agetxt.value
Model.PerpleInfo Info = new PerpleInfo (name,age);
BLL.Perple.insert(Info );
}
catch(Exception ex)
{
.......
}
}
==============================================
但是用了你的方法,就得这样了:
[Ajax.AjaxMethod()]
public void Add(string name,string age)
{
string name = name;//用string name = this.Name.value行么??
string age = age
.........
}
是不是这样的?你在.cs里想用页面的数据,就得用传递到后台了,对不?
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2005-09-20 14:27 by 代码乱了,不知道该怎么办![Ajax.AjaxMethod()]
public void Add(string name,string age)
{
string name = name;//用string name = this.Name.value行么??-
//用string name = this.Name.value行么??-可以的
string age = age
.........
}
但是我还没有明白你的意思!你想实现什么?能再说清楚一点吗?
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2005-09-20 14:36 by 存在所以孤独to:代码乱了,不知道该怎么办!
你有msn么:偶的是 zklvy@hotmail.com 在这个上和你说吧
我的意思是,你想执行一个插入操作,当然插入的数据来自页面
你直接用
public void Add()
{
string name = this.Name.value;
//这步不能得到数据name是null
//你自己测试一下就知道了
}
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2005-09-20 14:53 by 代码乱了,不知道该怎么办!我最近都没有用MSN
我的MSN:jrt324@126.com
QQ:54433048
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2005-10-18 18:34 by love_asp_net为什么最后没有值呢?
length=-1
请楼主再告知一下,谢谢了
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2005-10-18 18:42 by love_asp_net楼主麻烦你解释一下,这几句话的意思!
process.StartInfo.FileName = "nbtstat";
process.StartInfo.Arguments = "-a "+clientIP;
process.StartInfo.UseShellExecute = false;
process.StartInfo.CreateNoWindow = true;
process.StartInfo.RedirectStandardOutput = true;
谢谢了!!!
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2006-04-12 11:14 by 太阳种子看不懂啊,楼主能不能加点注释,好方便我们这些入门者看。
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2006-04-25 08:41 by xpcnbtstat 好像只能查一个子网里的
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2006-05-29 16:59 by hrf_dotnet你的demo能运行吗?????????????????
按你的步骤做能成功吗——失败???????????
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2007-01-29 13:33 by 兵document.getElementById("Mac").value=DemoMethods.GetCustomerMac(clientIP).value;
alert(DemoMethods.GetCustomerMac(clientIP).value);
是错误的代码啊 JS里怎么能调用CS里的代码呢
还请指教啊
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2007-04-27 11:06 by 冰凝只能获取局域网里的啊,放到服务器就得到的值就为null了
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2007-04-27 21:46 by 代码乱了@冰凝
是的,我只是作一个演示而已
# re: 初次体验.net Ajax无刷新技术 回复 更多评论
2007-05-08 21:48 by Lang_Hai没有连接成功就会返回空.
6.在page页面的Page_Load事件中加上
相关文章推荐
- 初次体验.net Ajax无刷新技术
- 初次体验.net Ajax无刷新技术
- Re:[转载]初次体验.NET Ajax无刷新技术
- .NET Ajax无刷新技术的初次体验
- 初次体验.net Ajax无刷新技术
- (转)初次体验.net Ajax无刷新技术
- 初次体验.net Ajax无刷新技术
- 初次体验.net Ajax无刷新技术
- 初次体验.NET Ajax无刷新技术
- 初次体验.net Ajax无刷新技术
- 初次体验.net Ajax无刷新技术
- 体验.NET Ajax无刷新技术
- 体验.net Ajax无刷新技术的惊喜
- .NET Ajax的无刷新技术实例详解
- .net Ajax无刷新技术
- 技术干货 | 初次微服务体验:从Docker容器农场说起
- NET Ajax的无刷新技术实例详解(重点)
- 泛函编程(2)-初次体验泛函编程
- XMLHttpRequest对象无刷新技术
- 4种页面无刷新更新数据的技术