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 :
"http://www.xxx.com/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一样加载返回的数据 来源:http://www.111cn.net/net/net/56393.htm

时间: 2024-10-16 16:00:48

asp.net中WebResponse 跨域访问示例的相关文章

ASP.NET中Cookie跨域的问题及解决代码

ASP.NET中Cookie跨域的问题及解决代码 http://www.liyumei.net.cn/post/share18.html Cookies揭秘  http://www.cnblogs.com/zhangziqiu/archive/2009/08/06/cookies-javascript-aspnet.html 最近在项目开发中遇到一个很棘手的问题,一个用户在顶级域名登录后,跳转到自己所拥有的二级域名下管理二级网站时,cookie丢失了,一直找解决办法找了整整两天,百度谷歌一大堆,

ASP.NET Web API 跨域访问

情景:http://localhost:8080/的web应用下访问http://localhost:8081下的Action时称为跨域访问. 前提,启动8080web应用实例,再启动8081web应用实例利用ajax去访问. 首先,在自己的Web API应用中,添加NuGet服务包,联机: 然后选择图中的,安装: 在Web API应用的App_Start/WebApiConfig.cs下的 public static void Register(HttpConfiguration config

ASP.NET Web API 跨域访问(CORS)要注意的地方

一.客户端用JSONP请求数据 如果你想用JSONP来获得跨域的数据,WebAPI本身是不支持javascript的callback的,它返回的JSON是这样的: {"YourSignature": "嫁人要嫁程序员,钱多话少死得早"} 然而,JSONP请求期望得到这样的JSON: jQuery123456({"YourSignature": "嫁人要嫁程序员,钱多话少死得早"}) 所以我们需要对WebAPI做拓展,让它支持这

Asp.Net MVC 中实现跨域访问

在ASP.Net webapi中可以使用  Microsoft.AspNet.WebApi.Cors  来实现: public static class WebApiConfig { public static void Register(HttpConfiguration config) { // New code config.EnableCors(); config.Routes.MapHttpRoute( name: "DefaultApi", routeTemplate: &

支持Ajax跨域访问ASP.NET Web Api 2(Cors)的简单示例教程演示

随着深入使用ASP.NET Web Api,我们可能会在项目中考虑将前端的业务分得更细.比如前端项目使用Angularjs的框架来做UI,而数据则由另一个Web Api 的网站项目来支撑.注意,这里是两个Web网站项目了,前端项目主要负责界面的呈现和一些前端的相应业务逻辑处理,而Web Api则负责提供数据. 这样问题就来了,如果前端通过ajax访问Web Api项目话,就涉及到跨域了.我们知道,如果直接访问,正常情况下Web Api是不允许这样做的,这涉及到安全问题.所以,今天我们这篇文章的主

Angular2中对ASP.NET MVC跨域访问

应用场景 项目开发决定使用angular2进行前后端分离开发,由我负责后端服务的开发,起初选择的是web api进行开发.对跨域访问通过API中间件+过滤器对跨域访问进行支持.开发一段后,通知需要移植到MVC4项目中一同发布angular2并且放弃API,但前期开发仍然需要分离开发. 遇到的问题 想继续使用中间件和过滤器的方式对MVC中的Action进行操作和限制,但经过尝试后发现行不通.主要问题有几下几点. API的处理管道和MVC的处理管道是两个完全不同的东西,所以原来用于API中的编码和方

在ASP.NET 5应用程序中的跨域请求功能详解

在ASP.NET 5应用程序中的跨域请求功能详解 浏览器安全阻止了一个网页中向另外一个域提交请求,这个限制叫做同域策咯(same-origin policy),这组织了一个恶意网站从另外一个网站读取敏感数据,但是一些特殊情况下,你需要允许另外一个站点跨域请求你的网站. 跨域资源共享(CORS:Cross Origin Resources Sharing)是一个W3C标准,它允许服务器放宽对同域策咯的限制,使用CORS,服务器可以明确的允许一些跨域的请求,并且拒绝其它的请求.CORS要比JSONP

Web Api跨域访问配置及调用示例

1.Web Api跨域访问配置. 在Web.config中的system.webServer内添加以下代码: <httpProtocol> <customHeaders> <add name="Access-Control-Allow-Origin" value="*" /> <add name="Access-Control-Allow-Headers" value="*" />

asp.net允许跨域访问

C# ASP.NET MVC 配置允许跨域访问 在web.config文件中的 system.webServer 节点下 增加如下配置 <httpProtocol> <customHeaders> <add name="Access-Control-Allow-Origin" value="*" /> <add name="Access-Control-Allow-Headers" value="