ASP.NET Core 预防开放式重定向攻击

写在前面

为预防钓鱼网站的常用套路,在进行 Web 应用程序的开发时,原则上应该将所有由用户提交的数据视为不可信。如果应用程序中包含了基于 URL 内容重定向的功能,需要确保这种类型的重定向操作只能在应用本地完成,或者明确判断其重定向到的是已知 URL,绝不能是 querystring 中可能包含的任何 URL。

ASP.NET Core 的 MVC基类中就提供了两种判断是否为本地URL的方法,这边做个记录;

两个方法分别为:LocalRedirect 和 IsLocalUrl 。

代码实现

cs 复制代码
        public ActionResult Index()
        {
            return Content("Index");
        }

        public IActionResult SomeAction(string redirectUrl)
        {
            return LocalRedirect(redirectUrl);
        }

        private IActionResult RedirectToLocal(string returnUrl)
        {
            if (Url.IsLocalUrl(returnUrl))
            {
                return Redirect(returnUrl);
            }
            else
            {
                return RedirectToAction(nameof(WeatherForecastController.Index), "WeatherForecastController");
            }
        }

调用示例

相关推荐
这里有鱼汤3 分钟前
分享一个自动登录miniQMT的Python方法,建议收藏
后端
欧阳码农31 分钟前
我的AI自学路线,可能对你有用
前端·人工智能·后端
CF14年老兵1 小时前
Python参数传递:从混沌到明晰的魔法之旅
后端·python·trae
Victor3562 小时前
Redis(13)Redis的哈希(Hash)类型有哪些常用命令?
后端
Victor3562 小时前
Redis(12)Redis的字符串(String)类型有哪些常用命令?
后端
uzong9 小时前
面试官:Redis中的 16 库同时发送命令,服务端是串行执行还是并行执行
后端·面试·架构
追逐时光者10 小时前
.NET 使用 MethodTimer 进行运行耗时统计提升代码的整洁性与可维护性!
后端·.net
你的人类朋友11 小时前
【Node.js】什么是Node.js
javascript·后端·node.js
David爱编程12 小时前
面试必问!线程生命周期与状态转换详解
java·后端
LKAI.13 小时前
传统方式部署(RuoYi-Cloud)微服务
java·linux·前端·后端·微服务·node.js·ruoyi