当前位置: 移动技术网 > IT编程>开发语言>c# > 关于C#中ajax跨域访问问题

关于C#中ajax跨域访问问题

2019年07月18日  | 移动技术网IT编程  | 我要评论

最近因项目需要,需要跨域请求访问数据。跨域访问是指什么?

[跨域]:指的是浏览器不能执行其他网站的脚本。它是由浏览器的同源策略造成的,是浏览器对javascript施加的安全限制。所谓同域是指,域名,协议,端口均相同,不明白没关系,举个栗子:例如,我的电脑上有2个服务器 192.168.0.11和192.168.0.12。如果第一个服务器上的页面要访问第二个服务器上面的数据,就叫做跨域。或者 要访问也是不同域名也是跨域。 下面给出完整请求案例:

前端页面请求代码片:

<script type="text/javascript">
  function ajaxsubmit(name,phone) {
   $.ajax({
    type: "get",
    url: "http://10.10.10.132:35709/appinterface/resourceinsert.ashx",
    data: { "share_name": encodeuri(name), "telphone": encodeuri(phone), "fromtype": 4 },
    datatype : "jsonp",
    jsonp: "callback",
    jsonpcallback: "successcallback",
    success: function (json) {
     alert(json.msg);
    },
    error:function(e){
     alert("提交失败!请稍后再试");
    }
   });
  }
 </script>

一般处理程序代码片:

public class resourceinsert : ihttphandler
 {
  public void processrequest(httpcontext context)
  {
   context.response.contenttype = "application/json";
   context.response.contentencoding = system.text.encoding.utf8;
   cms.model.resource model = new model.resource();
   cms.bll.resource bll = new bll.resource();
   //你所需要进行的操作
   model.share_name = httputility.urldecode(context.request["share_name"]);
   model.ask_telphone = httputility.urldecode(context.request["telphone"]);
   model.back_row_one = context.request["fromtype"];
   converthelper ch = new converthelper();
   model.share_name = ch.removespecialchar(model.share_name);
   //successcallback为跨域请求回调函数,切记必不可少。获取方式也可以为context.request["callback"],
   //对应前端页面发起请求的jsonp和jsonpcallback格式为:jsonp_value=jsonpcallback_value
   if (bll.exists(model.share_name, model.ask_telphone))
   {
    message temp = new message(1, "我们已收到您的请求额!请勿重复提交!", null);
    context.response.write("successcallback" + "(" + jsonconvert.serializeobject(temp) + ")");
    context.response.end();
    return;
   }
   else
   {
    if (bll.add(model) > 0)
    {
     message temp = new message(1, "提交成功,我们工作人员会尽快回复你!感谢关注!", null);
     context.response.write("successcallback" + "(" + jsonconvert.serializeobject(temp) + ")");
     context.response.end();
     return;
    }
    else
    {
     message temp = new message(0, "请确认信息填写无误!", null);
     context.response.write("successcallback" + "(" + jsonconvert.serializeobject(temp) + ")");
     context.response.end();
     return;
    }
   }
  }
  public bool isreusable
  {
   get
   {
    return false;
   }
  }
 }

你以为到这里完了吗?当然没有/斜眼笑。配置文件中当然不能少,web.config文件中的 system.webserver 节点下 增加如下配置:

<system.webserver>
 <httpprotocol>
  <customheaders>
  <add name="access-control-allow-methods" value="options,post,get"/>
  <add name="access-control-allow-headers" value="x-requested-with,content-type"/>
  <add name="access-control-allow-origin" value="*" />
  </customheaders>
 </httpprotocol>
 </system.webserver>

以上所述是小编给大家介绍的关于c#中ajax跨域访问问题,希望对大家有所帮助

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网