Is there any Equivalent to ValidateAntiForgeryToken in ServiceStack?

前端 未结 2 1993
有刺的猬
有刺的猬 2021-01-15 09:38

I\'m looking at SS code in github and I can\'t to find any equivalent to ValidateAntiForgeryToken because I don\'t want to reinvent the wheel and I\'d like to reuse as much

相关标签:
2条回答
  • 2021-01-15 10:13

    I ended up by creating a requestFilterAttibute with similar capabilities of the asp.net mvc

    this is the code I've done so far:

    [AttributeUsage(AttributeTargets.Class | AttributeTargets.Method, Inherited = false, AllowMultiple = false)]
        public class ValidateHttpAntiForgeryToken : RequestFilterAttribute
        {
            public override void Execute(IHttpRequest req, IHttpResponse res, object requestDto)
            {
               try
                {
                    if (IsAjaxRequest(req))
                        ValidateRequestHeader(req);
                    else
                        AntiForgery.Validate();
    
                }
                catch (Exception ex)
                {
                    res.StatusCode = 403;
                    res.StatusDescription = ex.Message;
                }
            }
    
            private void ValidateRequestHeader(IHttpRequest req)
            {
                var cookie = req.Cookies.FirstOrDefault(c => c.Value.Name.Contains(AntiForgeryConfig.CookieName));
                if (cookie.Value == null)
                {
                    throw new HttpAntiForgeryException(String.Format("Missing {0} cookie", AntiForgeryConfig.CookieName));
                }
                IEnumerable<string> xXsrfHeaders = req.Headers.GetValues("__RequestVerificationToken");
                if (xXsrfHeaders == null || !xXsrfHeaders.Any())
                    throw new HttpAntiForgeryException("Missing X-XSRF-Token HTTP header");
                AntiForgery.Validate(cookie.Value.Value, xXsrfHeaders.FirstOrDefault());
    
            }
    
            private static bool IsAjaxRequest(IHttpRequest request)
            {
                IEnumerable<string> xRequestedWithHeaders = request.Headers.GetValues("X-Requested-With");
                if (xRequestedWithHeaders != null && xRequestedWithHeaders.Any())
                {
                    string headerValue = xRequestedWithHeaders.FirstOrDefault();
                    if (!String.IsNullOrEmpty(headerValue))
                    {
                        return String.Equals(headerValue, "XMLHttpRequest", StringComparison.OrdinalIgnoreCase);
                    }
                }
                return false;
            }
        }
    
    0 讨论(0)
  • 2021-01-15 10:24

    It looks like that wheel has already been invented:

    https://github.com/ServiceStack/ServiceStack/tree/master/src/ServiceStack/Html/AntiXsrf

    0 讨论(0)
提交回复
热议问题