System.Web.Http.Cors配置跨域訪問的兩種方式
使用System.Web.Http.Cors配置跨域訪問,衆多大神已經發布了不少文章,我就不在詳細描述了,做爲小白我只說一下本身的使用心得。在webapi中使用System.Web.Http.Cors配置跨域信息能夠有兩種方式。
一種是在App_Start.WebApiConfig.cs的Register中配置以下代碼,這種方式將在全部的webapi Controller裏面起做用。web
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web.Http;
using System.Web.Http.Cors;api
namespace YDTG.Service
{
public static class WebApiConfig
{
public static void Register(HttpConfiguration config)
{
// Web API 配置和服務跨域
// Web API 路由
config.MapHttpAttributeRoutes();app
config.Routes.MapHttpRoute(
name: "DefaultApi",
routeTemplate: "api/{controller}/{action}/{id}",
defaults: new { id = RouteParameter.Optional }
);
//這是重點,從配置文件的appsettings節點中讀取跨域的地址
var cors = new EnableCorsAttribute(ConfigurationManager.AppSettings["origins"], "*", "*");
config.EnableCors(cors);
}
}
}
配置文件以下,注意必定要加上httpcors
<add key="origins" value="http://localhost:9012,http://192.168.1.108:9012" />
1
第二種方式就是在每一個webapiController類中設置,即每一個控制器個性化配置,以下代碼。post
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Http.Cors;
using System.Web.Mvc;網站
namespace Service.Controllers
{
[EnableCors("http://localhost:9012,http://192.168.1.108:9012", "*", "*")]
public class HomeController : Controller
{
public ActionResult Index()
{
ViewBag.Title = "Home Page";spa
return View();
}
}
}
注意事項
EnableCors共三個參數分別爲origins、headers和methods。origins配置容許訪問的域名,多個域名以逗號分隔便可,域名必定要完整,若是是ip地址前面要加上「http」,只使用IP的話必定會失效的。參數headers配置所支持的資源。參數methods配置支持的方法,get、post、put等。若是容許任意域名、任意資源、任意方法訪問本身的webapi,則三個參數所有使用星號」*」便可。
「EnableCors(「http://localhost:9012,http://192.168.1.108:9012「, 「「, 「「)」中的配置若是出現錯誤的話不會報錯,而是直接禁止未出如今配置表中的資源訪問。
若是使用第一種方式那麼能夠從配置文件中讀取網站列表,若是使用第二種方式,全部的參數只能使用常量。
---------------------
原文:https://blog.csdn.net/chaoyangzhixue/article/details/52251322 .net