ホームページ > バックエンド開発 > C#.Net チュートリアル > C# における Ajax クロスドメイン アクセスの問題の詳細な紹介

C# における Ajax クロスドメイン アクセスの問題の詳細な紹介

黄舟
リリース: 2017-05-14 10:49:30
オリジナル
2647 人が閲覧しました

私は最近プロジェクトに取り組んでおり、クロスドメインリクエストを介してデータにアクセスする必要がありました。以下は C# の Ajax クロスドメイン アクセス コードの詳細な説明です。必要な友人は参照してください。

最近、プロジェクトのニーズにより、データにアクセスするためにクロスドメイン リクエストが必要になります。クロスドメインアクセスとはどういう意味ですか?

[クロスドメイン]: ブラウザーが他の Web サイトからのスクリプトを実行できないという事実を指します。これは、ブラウザーの同一生成元ポリシー、つまりブラウザーによって JavaScript に課せられる セキュリティ 制限によって引き起こされます。いわゆる同じドメインとは、ドメイン名、プロトコル、ポートが同じであることを意味します。たとえば、私のコンピューターには 192.168.0.11 と 192.168.0.12 という 2 つのサーバーがあります。 。最初のサーバー上のページが 2 番目のサーバー上のデータにアクセスする必要がある場合、それはクロスドメインと呼ばれます。または、www.xxx.com にアクセスする http://www.baidu.com も、別のドメイン名とクロスドメインです。 完全なリクエスト ケースを以下に示します:

フロントエンド ページ リクエスト コード部分:

<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 ノードの下に次の設定を追加します。

以上がC# における Ajax クロスドメイン アクセスの問題の詳細な紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート