Maison > développement back-end > Tutoriel C#.Net > Introduction détaillée aux problèmes d'accès inter-domaines ajax en C#

Introduction détaillée aux problèmes d'accès inter-domaines ajax en C#

黄舟
Libérer: 2017-05-14 10:49:30
original
2651 Les gens l'ont consulté

J'ai récemment travaillé sur un projet qui nécessitait des requêtes inter-domaines pour accéder aux données. Cet article partagera avec vous une explication détaillée du code d'accès inter-domaines ajax en C# Les amis qui en ont besoin peuvent se référer à

Récemment, en raison des besoins du projet, des demandes inter-domaines. sont nécessaires pour accéder aux données. Que signifie l’accès inter-domaines ?

[Cross-domain] : Désigne le fait que le navigateur ne peut pas exécuter de scripts provenant d'autres sites internet. Cela est dû à la politique de même origine du navigateur, une restriction de sécurité imposée par le navigateur sur JavaScript. Le soi-disant même domaine signifie que le nom de domaine, le protocole et le port sont identiques. Peu importe si vous ne comprenez pas. Par exemple, il y a deux serveurs sur mon ordinateur, 192.168.0.11 et 192.168.0.12. . Si une page du premier serveur doit accéder aux données du deuxième serveur, cela est appelé cross-domain. Ou http://www.baidu.com pour accéder à www.xxx.com est également un nom de domaine différent et inter-domaines. Le cas de demande complet est donné ci-dessous :

Morceau de code de demande de la page frontale :

<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>
Copier après la connexion

Morceau de code du gestionnaire général :

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;
   }
  }
 }
Copier après la connexion

Pensez-vous que c'est terminé ici? Bien sûr que non/en louchant. Le Fichier de configuration est bien sûr indispensable Ajoutez la configuration suivante sous le nœud system.webServer dans le fichier web.config :

<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>
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal