У меня есть метод, с помощью которого я хочу перенаправить пользователя обратно на страницу входа в систему, расположенную в корне моего веб-приложения.
Я использую следующий код:
Response.Redirect("~/Login.aspx?ReturnPath = " + Request.Url.ToString());
Но это не работает. Я предполагал, что ASP.NET автоматически разрешит URL-адрес в правильный путь. Обычно я бы просто использовал
Response.Redirect("../Login.aspx?ReturnPath = " + Request.Url.ToString());
но этот код находится на главной странице и может быть выполнен на любом уровне папки. Как мне обойти эту проблему?





Как насчет использования
Response.Redirect(String.Format("http://{0}/Login.aspx?ReturnPath = {1}", Request.ServerVariables["SERVER_NAME"], Request.Url.ToString()));
Я считаю, что это законная альтернатива, если кто-то захочет сделать это в такой форме.
I think you need to drop the "~/" and replace it with just "/", I believe / is the root
ОСТАНОВИСЬ ПРЯМО ТАМ! :-), если вы не хотите жестко запрограммировать свое веб-приложение так, чтобы его можно было установить только в корень веб-сайта.
"~ /" является - правильная вещь для использования, но причина того, что ваш исходный код не работает должным образом, заключается в том, что ResolveUrl (который используется внутри Redirect) пытается сначала определить, является ли путь, который вы передаете, является абсолютным URL-адрес (например, «** http: // сервер / ** foo / bar.htm» вместо «foo / bar.htm») - но, к сожалению, он делает это просто путем поиска символа двоеточия ':' в URL-адресе, который вы ему даете. Но в этом случае он находит двоеточие в URL-адресе, который вы указываете в значении строки запроса ReturnPath, что вводит его в заблуждение - поэтому ваш '~ /' не разрешается.
Исправление заключается в том, что вы должны кодировать URL-адрес значения ReturnPath, чтобы избежать проблемного ":" вместе с любыми другими специальными символами.
Response.Redirect("~/Login.aspx?ReturnPath = " + Server.UrlEncode(Request.Url.ToString()));
Кроме того, я рекомендую вам (или кому-либо еще) никогда не использовать Uri.ToString - потому что он дает удобочитаемую, более «дружелюбную» версию URL-адреса, а не обязательно правильную (это неэкранирует). Вместо этого используйте Uri.AbsoluteUri - вот так:
Response.Redirect("~/Login.aspx?ReturnPath = " + Server.UrlEncode(Request.Url.AbsoluteUri));
вы можете сначала разрешить URL Response.Redirect ("~ / Login.aspx); и добавьте параметры после того, как он будет разрешен.
Использование имени сервера проблематично, поскольку сайт, вероятно, может использовать настраиваемый DNS. Если протокол жестко задан как «http», это также вызовет проблемы для сайтов, использующих https.