前兩天,一個朋友讓我?guī)退麑戇@樣一個程序:在asp.net里面訪問asp的頁面,把數(shù)據(jù)提交對方的數(shù)據(jù)庫后,根據(jù)返回的值(返回值為:OK或ERROR),如果為OK再把填入本地數(shù)據(jù)庫。當時,想當然,覺得很簡單,用js的xmlhttp ,如果根據(jù)response 的值是“OK”就執(zhí)行提交本地數(shù)據(jù)庫。很快寫完發(fā)過去,讓朋友試試,一試發(fā)現(xiàn)不行,后來一問,原來是跨域訪問,我給忽略了,于是讓朋友把asp改成web service,可朋友說程序是合作公司做的,只會asp,不會用web service ,狂暈ing。沒辦法,只能請出asp.net的 WebResponse了,很多網(wǎng)站采集程序都是用這個。第一版寫完了,倒是可以跨域訪問了,不過是亂碼,調整有關編碼的方式,終于可以了。這個應用雖小可是涉及的知識點不少:
1、xmlhttp 不能跨域提交。
當然XMLHttpRequest還是權宜的解決的方法,
2、webresponse可以進行跨域訪問,不過要注意
1)、get和post的區(qū)別。
2)、注意Timeout的問題。
這些都是簡單的程序,記下來備忘,高手就不必看了。
不廢話了,下面是相關的c#代碼:
復制代碼 代碼如下:
/// summary>
/// 使用Post方法發(fā)送數(shù)據(jù)
/// /summary>
/// param name=”pi_strPostURl”>提交地址/param>
/// param name=”pi_strParm”>參數(shù)/param>
/// returns>/returns>
public static string PostResponse(string pi_strPostURl, string pi_strParm)
{
try
{
//編碼
Encoding t_Encoding = Encoding.GetEncoding(“GB2312“);
Uri t_Uri = new Uri(pi_strPostURl);
byte[] paramBytes = t_Encoding.GetBytes(pi_strParm);
WebRequest t_WebRequest = WebRequest.Create(t_Uri);
t_WebRequest.Timeout = 100000;
//設置ContentType
t_WebRequest.ContentType = “application/x-www-form-urlencoded“;
t_WebRequest.Method = EnumMethod.POST.ToString(); //初始化
using (Stream t_REStream = t_WebRequest.GetRequestStream())
{
//發(fā)送數(shù)據(jù)
requestStream.Write(paramBytes, 0
, paramBytes.Length);
}
WebResponse t_WebResponse =
t_WebRequest.GetResponse();
using (StreamReader t_StreamReader = new StreamReader(t_WebResponse .GetResponseStream(), t_Encoding))
{
return t_StreamReader.ReadToEnd();
}
}
catch
{
return “ERROR“;
}
}
public static string GetResponse(string pi_strPostURl, string pi_strParm)
{
try
{
//編碼
Encoding t_Encoding = Encoding.GetEncoding(“GB2312“);
Uri t_Uri = new Uri(string.Format(“{0}?{1}“, pi_strPostURl, pi_strParm));
WebRequest t_WebRequest =
WebRequest.Create(t_Uri);
t_WebRequest.Timeout = 100000;
t_WebRequest.ContentType = “application/x-www-form-urlencoded“;
t_WebRequest.Method = EnumMethod.GET.ToString();
WebResponse t_WebResponse =
t_WebRequest.GetResponse();
using (StreamReader t_StreamReader = new StreamReader(t_WebResponse.GetResponseStream(), t_Encoding))
{
return t_StreamReader.ReadToEnd();
}
}
catch (Exception e)
{
return e.ToString();
}
}
public static string AtionResponse(string pi_Url, EnumMethod pi_Method)
{
string t_strUrlPath=“”;
string t_parm = “”;
Uri t_Url = new Uri(pi_Url);
t_parm= t_Url.Query;
if (parmString.StartsWith(“?“))
t_parm = t_parm.Remove(0, 1);
t_strUrlPath = “http://“ + t_Url .Authority + t_Url .AbsolutePath;
return GetResponse(t_strUrlPath, t_parm, pi_Method);
}
public enum EnumMethod
{
POST,
GET
}
現(xiàn)在jquery ajax支持跨域了,下面看個實例我們可對上面進行處理成json數(shù)據(jù)即可
JQuery.getJSON也同樣支持jsonp的數(shù)據(jù)方式調用。
客戶端JQuery.ajax的調用代碼示例:
復制代碼 代碼如下:
$.ajax({
type : "get",
async:false,
url : "https://www.jb51.net/ajax.do",
dataType : "jsonp",
jsonp: "callbackparam",//服務端用于接收callback調用的function名的參數(shù)
jsonpCallback:"success_jsonpCallback",//callback的function名稱
success : function(json){
alert(json);
alert(json[0].name);
},
error:function(){
alert('fail');
}
});
服務端返回數(shù)據(jù)的示例代碼:
復制代碼 代碼如下:
public void ProcessRequest (HttpContext context) {
context.Response.ContentType = "text/plain";
String callbackFunName = context.Request["callbackparam"];
context.Response.Write(callbackFunName + "([ { name:"John"}])");
}
而jquery.getScript方式處理的原理類似,也同樣需要服務端返回數(shù)據(jù)上做支持,不同的是服務端返回的結果不同。不是返回一個callback的function調用,而是直接將結果賦值給請求傳遞的變量名。客戶端則是像引入一個外部script一樣加載返回的數(shù)據(jù)。
您可能感興趣的文章:- AJAX javascript的跨域訪問執(zhí)行
- 解決AJAX中跨域訪問出現(xiàn)''沒有權限''的錯誤
- ASP.NET XmlHttp跨域訪問實現(xiàn)代碼
- asp.net Cookie跨域、虛擬目錄等設置方法
- JQuery Ajax 跨域訪問的解決方案
- asp.net(C#)跨域及跨域寫Cookie問題
- ASP.NET MVC中EasyUI的datagrid跨域調用實現(xiàn)代碼
- asp.net關于Cookie跨域(域名)的問題
- AJAX的跨域訪問-兩種有效的解決方法介紹
- 支持Ajax跨域訪問ASP.NET Web Api 2(Cors)的示例教程