本文整理汇总了C#中IPipelines.EnableCors方法的典型用法代码示例。如果您正苦于以下问题:C# IPipelines.EnableCors方法的具体用法?C# IPipelines.EnableCors怎么用?C# IPipelines.EnableCors使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类IPipelines
的用法示例。
在下文中一共展示了IPipelines.EnableCors方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: RequestStartup
protected override void RequestStartup(IWindsorContainer container, IPipelines pipelines, NancyContext context)
{
pipelines.BeforeRequest.AddItemToEndOfPipeline(nancyContext =>
{
this.Info(() => "Api invoked at {0}[{1}]".FormatWith(nancyContext.Request.Method, nancyContext.Request.Url));
var token = "";
var cookie = nancyContext.Request.Headers.Cookie.FirstOrDefault(x => (x.Name + "").ToLower() == "token");
if (cookie != null)
token = HttpUtility.UrlDecode(cookie.Value);
nancyContext.Request.Headers.Authorization = "Token {0}".FormatWith(token);
var user = container.Resolve<ITokenizer>().Detokenize(token, nancyContext, new DefaultUserIdentityResolver());
if (user != null)
{
nancyContext.CurrentUser = user;
}
return null;
});
pipelines.AfterRequest.AddItemToEndOfPipeline(nancyContext => this.Info(() => "Api invoked successfully at {0}[{1}]".FormatWith(nancyContext.Request.Method, nancyContext.Request.Url)));
pipelines.OnError.AddItemToEndOfPipeline((nancyContext, exception) =>
{
this.Error(() => "Error on Api request {0}[{1}] => {2}".FormatWith(nancyContext.Request.Method, nancyContext.Request.Url, exception));
var errorResponse = ErrorResponse.FromException(exception);
if (exception is LightstoneAutoException)
errorResponse.StatusCode = HttpStatusCode.ImATeapot;
return errorResponse;
});
pipelines.EnableCors(); // cross origin resource sharing
TokenAuthentication.Enable(pipelines, new TokenAuthenticationConfiguration(container.Resolve<ITokenizer>()));
base.RequestStartup(container, pipelines, context);
}
示例2: ApplicationStartup
protected override void ApplicationStartup(TinyIoCContainer container, IPipelines pipelines)
{
base.ApplicationStartup(container, pipelines);
//var configuration = new StatelessAuthenticationConfiguration(context =>
//{
// var token = context.AuthorizationHeaderToken();
// var authenticator = container.Resolve<IAuthenticateUser>();
// return string.IsNullOrWhiteSpace(token) ? null : authenticator != null ? authenticator.GetUserIdentity(token) : null;
//});
//StatelessAuthentication.Enable(pipelines, configuration);
pipelines.EnableStatelessAuthentication(container.Resolve<IAuthenticateUser>());
pipelines.EnableCors(); // cross origin resource sharing
pipelines.EnableMonitoring();
//Make every request SSL based
//pipelines.BeforeRequest += ctx =>
//{
// return (!ctx.Request.Url.Scheme.Equals("https", StringComparison.OrdinalIgnoreCase)) ?
// (Response)HttpStatusCode.Unauthorized :
// null;
//};
}
示例3: RequestStartup
protected override void RequestStartup(TinyIoCContainer container, IPipelines pipelines, NancyContext context)
{
base.RequestStartup(container, pipelines, context);
if (!_corsConfiguration.DisableCors)
{
pipelines.EnableCors(_corsConfiguration);
}
}