亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

在ASP.NETMVC中設置訪問-控制-允許-原產地-最簡單的可能方法

在ASP.NETMVC中設置訪問-控制-允許-原產地-最簡單的可能方法

一只名叫tom的貓 2019-11-07 10:06:19
在ASP.NETMVC中設置訪問-控制-允許-原產地-最簡單的可能方法我有一個簡單的actionMethod,它返回一些json。它運行在ajax.example.com上。我需要從另一個網站訪問這個網站。如果我試著叫它,我就會得到預期的.:Origin http://someothersite.com is not allowed by Access-Control-Allow-Origin.我知道有兩種方法可以解決這個問題:JSONP并創建一個自定義HttpHandler若要設置標題,請執行以下操作。有沒有更簡單的方法?一個簡單的操作不可能定義一個允許的起源列表,或者簡單地允許每個人?也許是動作過濾器?最佳方案是:return json(mydata, JsonBehaviour.IDontCareWhoAccessesMe);
查看完整描述

3 回答

?
富國滬深

TA貢獻1790條經驗 獲得超9個贊

對于普通ASP.NETMVC控制器

創建一個新屬性

public class AllowCrossSiteJsonAttribute : ActionFilterAttribute{
    public override void OnActionExecuting(ActionExecutingContext filterContext)
    {
        filterContext.RequestContext.HttpContext.Response.AddHeader("Access-Control-Allow-Origin", "*");
        base.OnActionExecuting(filterContext);
    }}

標記你的行動:

[AllowCrossSiteJson]public ActionResult YourMethod(){
    return Json("Works better?");}

對于ASP.NETWebAPI

using System;using System.Web.Http.Filters;public class AllowCrossSiteJsonAttribute : ActionFilterAttribute{
    public override void OnActionExecuted(HttpActionExecutedContext actionExecutedContext)
    {
        if (actionExecutedContext.Response != null)
            actionExecutedContext.Response.Headers.Add("Access-Control-Allow-Origin", "*");

        base.OnActionExecuted(actionExecutedContext);
    }}

標記整個API控制器:

[AllowCrossSiteJson]public class ValuesController : ApiController{

或單個API調用:

[AllowCrossSiteJson]public IEnumerable<PartViewModel> Get(){
    ...}

對于InternetExplorer<=v9

IE<=9不支持CORS。我已經編寫了一個javascript,它將通過代理自動路由這些請求。它是100%透明的(您只需包括我的代理和腳本)。

使用Nuget下載corsproxy并按照包括的指示。



查看完整回答
反對 回復 2019-11-08
  • 3 回答
  • 0 關注
  • 455 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號