当前位置: 首页>>代码示例>>C#>>正文


C# IHttpRequest.ResolveAbsoluteUrl方法代码示例

本文整理汇总了C#中IHttpRequest.ResolveAbsoluteUrl方法的典型用法代码示例。如果您正苦于以下问题:C# IHttpRequest.ResolveAbsoluteUrl方法的具体用法?C# IHttpRequest.ResolveAbsoluteUrl怎么用?C# IHttpRequest.ResolveAbsoluteUrl使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在IHttpRequest的用法示例。


在下文中一共展示了IHttpRequest.ResolveAbsoluteUrl方法的4个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: Execute

        public override void Execute(IHttpRequest req, IHttpResponse res, object requestDto)
        {
            base.Execute(req, res, requestDto); //first check if session is authenticated
            if (res.IsClosed) return; //AuthenticateAttribute already closed the request (ie auth failed)

            var session = req.GetSession();
            if (HasAllPermissions(req, session)) return;
            
            var htmlRedirect = HtmlRedirect ?? AuthService.HtmlRedirect;
            if (htmlRedirect != null && req.ResponseContentType.MatchesContentType(ContentType.Html))
            {
                var url = req.ResolveAbsoluteUrl(htmlRedirect);
                res.RedirectToUrl(url);
                return;
            }

            res.StatusCode = (int)HttpStatusCode.Forbidden;
            res.StatusDescription = "Invalid Permission";
            res.EndServiceStackRequest();
        }
开发者ID:hp-zhoujinqiao,项目名称:ServiceStack-1,代码行数:20,代码来源:RequiredPermissionAttribute.cs

示例2: Execute

        public override void Execute(IHttpRequest req, IHttpResponse res, object requestDto)
        {
            if (AuthService.AuthProviders == null) throw new InvalidOperationException("The AuthService must be initialized by calling "
                 + "AuthService.Init to use an authenticate attribute");

            var matchingOAuthConfigs = AuthService.AuthProviders.Where(x =>
                this.Provider.IsNullOrEmpty()
                || x.Provider == this.Provider).ToList();

            if (matchingOAuthConfigs.Count == 0)
            {
                res.WriteError(req, requestDto, "No OAuth Configs found matching {0} provider"
                    .Fmt(this.Provider ?? "any"));
                res.EndServiceStackRequest();
                return;
            }

            if (matchingOAuthConfigs.Any(x => x.Provider == DigestAuthProvider.Name))
                AuthenticateIfDigestAuth(req, res);

            if (matchingOAuthConfigs.Any(x => x.Provider == BasicAuthProvider.Name))
                AuthenticateIfBasicAuth(req, res);

            var session = req.GetSession();
            if (session == null || !matchingOAuthConfigs.Any(x => session.IsAuthorized(x.Provider)))
            {
                var htmlRedirect = HtmlRedirect ?? AuthService.HtmlRedirect;
                if (htmlRedirect != null && req.ResponseContentType.MatchesContentType(ContentType.Html))
                {
                    var url = req.ResolveAbsoluteUrl(htmlRedirect);
                    url = url.AddQueryParam("redirect", req.AbsoluteUri);
                    res.RedirectToUrl(url);
                    return;
                }

                AuthProvider.HandleFailedAuth(matchingOAuthConfigs[0], session, req, res);
            }
        }
开发者ID:owenlilly,项目名称:ServiceStack,代码行数:38,代码来源:AuthenticateAttribute.cs

示例3: DoHtmlRedirectIfConfigured

        protected bool DoHtmlRedirectIfConfigured(IHttpRequest req, IHttpResponse res, bool includeRedirectParam = false)
        {
            var htmlRedirect = this.HtmlRedirect ?? AuthenticateService.HtmlRedirect;
            if (htmlRedirect != null && req.ResponseContentType.MatchesContentType(MimeTypes.Html))
            {
                var url = req.ResolveAbsoluteUrl(htmlRedirect);
                if (includeRedirectParam)
                {
                    var absoluteRequestPath = req.ResolveAbsoluteUrl("~" + req.PathInfo + ToQueryString(req.QueryString));
                    url = url.AddQueryParam("redirect", absoluteRequestPath);
                }

                res.RedirectToUrl(url);
                return true;
            }

            return false;
        }
开发者ID:qqqzhch,项目名称:ServiceStack,代码行数:18,代码来源:AuthenticateAttribute.cs

示例4: DoHtmlRedirectIfConfigured

        protected bool DoHtmlRedirectIfConfigured(IHttpRequest req, IHttpResponse res, bool includeRedirectParam = false)
        {
            var htmlRedirect = this.HtmlRedirect ?? AuthService.HtmlRedirect;
            if (htmlRedirect != null && req.ResponseContentType.MatchesContentType(ContentType.Html))
            {
                var url = req.ResolveAbsoluteUrl(htmlRedirect);
                if (includeRedirectParam)
                {
                    url = url.AddQueryParam("redirect", req.AbsoluteUri);
                }

                res.RedirectToUrl(url);
                return true;
            }

            return false;
        }
开发者ID:pruiz,项目名称:ServiceStack,代码行数:17,代码来源:AuthenticateAttribute.cs


注:本文中的IHttpRequest.ResolveAbsoluteUrl方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。