为了账号安全,请及时绑定邮箱和手机立即绑定

在ASP.NETMVC中设置访问-控制-允许-原产地-最简单的可能方法

在ASP.NETMVC中设置访问-控制-允许-原产地-最简单的可能方法

海绵宝宝撒 2019-07-22 12:12:35
在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贡献2051条经验 获得超10个赞

对于普通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-07-23
  • 3 回答
  • 0 关注
  • 336 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信