我正在处理一个看似简单的问题:在我的授权过滤器中,我检查一些条件是否满足条件,我需要从Query字符串中删除某些值,并将用户重定向到生成的URL.但是,这给了我一些比我想要的更多的问题.看起来像这样:
public void OnAuthorization(AuthorizationContext filterContext) { if (!SomeCondition()) { RedirectToCleanUrl(filterContext); } }
在我的RedirectToCleanUrl中,我剥离了查询字符串,并尝试将其重定向到新的URL.看起来像这样:
private void RedirectToCleanUrl(AuthorizationContext filterContext) { var queryStringParams = new NameValueCollection(filterContext.HttpContext.Request.QueryString); // Stripping the key queryStringParams.Remove("some_key"); var routeValueDictionary = new RouteValueDictionary(); foreach (string x in queryStringParams) { routeValueDictionary.Add(x,queryStringParams[x]); } foreach (var x in filterContext.RouteData.Values) { routeValueDictionary.Add(x.Key,x.Value); } filterContext.Result = new RedirectToRouteResult(routeValueDictionary); }
解决方法
这是我最后写的代码:
protected void StripQueryStringAndRedirect(System.Web.HttpContextBase httpContext,string[] keysToRemove) { var queryString = new NameValueCollection(httpContext.Request.QueryString); foreach (var key in keysToRemove) { queryString.Remove(key); } var newQueryString = ""; for (var i = 0; i < queryString.Count; i++) { if (i > 0) newQueryString += "&"; newQueryString += queryString.GetKey(i) + "=" + queryString[i]; } var newPath = httpContext.Request.Path + (!String.IsNullOrEmpty(newQueryString) ? "?" + newQueryString : String.Empty); if (httpContext.Request.Url.PathAndQuery != newPath) { httpContext.Response.Redirect(newPath,true); } }
原文地址:https://www.jb51.cc/csharp/96710.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。