一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - ASP.NET教程 - asp.net中WebResponse 跨域訪問實例代碼

asp.net中WebResponse 跨域訪問實例代碼

2019-11-26 13:42ASP.NET教程網 ASP.NET教程

一篇朋友很久前寫的asp.net中WebResponse 跨域訪問示例,下面我轉過來與大家一起學習學習,希望文章對大家會有幫助

前兩天,一個朋友讓我幫他寫這樣一個程序:在asp.net里面訪問asp的頁面,把數據提交對方的數據庫后,根據返回的值(返回值為:OK或ERROR),如果為OK再把填入本地數據庫。當時,想當然,覺得很簡單,用js的xmlhttp ,如果根據response 的值是“OK”就執行提交本地數據庫。很快寫完發過去,讓朋友試試,一試發現不行,后來一問,原來是跨域訪問,我給忽略了,于是讓朋友把asp改成web service,可朋友說程序是合作公司做的,只會asp,不會用web service ,狂暈ing。沒辦法,只能請出asp.net的 WebResponse了,很多網站采集程序都是用這個。第一版寫完了,倒是可以跨域訪問了,不過是亂碼,調整有關編碼的方式,終于可以了。這個應用雖小可是涉及的知識點不少:

1、xmlhttp 不能跨域提交。

當然XMLHttpRequest還是權宜的解決的方法,

2、webresponse可以進行跨域訪問,不過要注意

1)、get和post的區別。
2)、注意Timeout的問題。

這些都是簡單的程序,記下來備忘,高手就不必看了。

不廢話了,下面是相關的c#代碼:

 

復制代碼代碼如下:

/// <summary>
        /// 使用Post方法發送數據
        /// </summary>
        /// <param name=”pi_strPostURl”>提交地址</param>
        /// <param name=”pi_strParm”>參數</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())
                {
                    //發送數據
                    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
        }

 

現在jquery ajax支持跨域了,下面看個實例我們可對上面進行處理成json數據即可

JQuery.getJSON也同樣支持jsonp的數據方式調用。

客戶端JQuery.ajax的調用代碼示例:

 

復制代碼代碼如下:


$.ajax({
 type : "get",
 async:false,
 url : "//www.ythuaji.com.cn/ajax.do",
 dataType : "jsonp",
 jsonp: "callbackparam",//服務端用于接收callback調用的function名的參數
 jsonpCallback:"success_jsonpCallback",//callback的function名稱
 success : function(json){
  alert(json);
  alert(json[0].name);
 },
 error:function(){
  alert('fail');
 }
});

 

 

 

服務端返回數據的示例代碼:

 

復制代碼代碼如下:

public void ProcessRequest (HttpContext context) {
 context.Response.ContentType = "text/plain";
 String callbackFunName = context.Request["callbackparam"];
 context.Response.Write(callbackFunName + "([ { name:"John"}])");
}

 

而jquery.getScript方式處理的原理類似,也同樣需要服務端返回數據上做支持,不同的是服務端返回的結果不同。不是返回一個callback的function調用,而是直接將結果賦值給請求傳遞的變量名。客戶端則是像引入一個外部script一樣加載返回的數據。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产一区二区三区在线看 | 搓光美女衣 | 人体做爰aaaa免费 | 亚洲第一网色综合久久 | 勾搭已婚高h | japan孕妇孕交freehd | 精品一区二区三区在线播放 | 免费国产好深啊好涨好硬视频 | 百合女女师生play黄肉黄 | 四虎综合九九色九九综合色 | 小仙夜晚慰自催眠mp3护士篇 | 毛茸茸的大逼 | 日日操视频 | 四虎精品成人免费视频 | 99久久精品无码一区二区毛片 | 精品人伦一区二区三区潘金莲 | 韩国久播影院理论片不卡影院 | 天堂素人在线 | 天堂网www在线中文天堂 | 国产xx肥老妇视频奂费 | 15一16japanese破| 丰满肥臀风间由美357在线 | 日本无遮挡吸乳视频看看 | 国内精品久久久久久野外 | 男人的天堂va | 村上里沙40分钟在线观看 | 国产在线精品成人一区二区三区 | 国产亚洲精品日韩香蕉网 | 小舞丝袜调教喷水沦为肉奴 | 免费视频大全 | ova催眠性指导5最新在线 | 99热久久这里只有精品6国产网 | 三上悠亚精品专区久久 | 无人在线视频高清免费观看动漫 | 精品午夜寂寞黄网站在线 | 欧美同志video 在线观看 | 国产农村一一级特黄毛片 | 好大好硬好深好爽想要吃奶 | 精品视频中文字幕 | 高清视频在线观看+免费 | 天天干天天色综合网 |