首页>>帮助中心>>香港云服务器.net如何防御csrf攻击

香港云服务器.net如何防御csrf攻击

2023/5/24 480次

香港云服务器.net项目中防御csrf攻击的方法

1首先,在.net项目添加以下代码;

<% using (Html.BeginForm("Login", "Admin", FormMethod.Post))

{ %>

<%=Html.AntiForgeryToken() %>

<%= Html.ValidationSummary(true, "登录不成功。请更正错误并重试。") %>

<div>

<fieldset>

<legend>帐户信息</legend>

<div class="editor-label">

<%= Html.LabelFor(m => m.UserName) %>

</div>

<div class="editor-field">

<%= Html.TextBoxFor(m => m.UserName)%>

<%= Html.ValidationMessageFor(m => m.UserName)%>

<label id="UserNameTip"></label>

</div>

<div class="editor-label">

<%= Html.LabelFor(m => m.Password) %>

</div>

<div class="editor-field">

<%= Html.PasswordFor(m => m.Password) %>

<%= Html.ValidationMessageFor(m => m.Password) %>

</div>

<p>

<input type="submit" value="登录" />

</p>

</fieldset>

</div>

<% } %>

2.代码添加好后,在对应的Action中用[ValidateAntiForgeryToken]进行标识即可;

[HttpPost]

[ValidateAntiForgeryToken]

public ActionResult Login(Usr usr)

{

if (ModelState.IsValid)

{

var model = DB.Context.Single(p => p.SystemUser == true && p.UserName == usr.UserName && p.Password == usr.Password);

if (model != null)

{

authenticate.Login(usr.UserName, usr.Role);

return RedirectToAction("UserList", "Admin");

}

else

{

ModelState.AddModelError("", "提供的用户名或密码不正确。");

}

}

return View(usr);

}

一诺网络香港免备案专区,提供「香港增强云服务器」和「香港特惠云服务器」两种类型的高可用弹性计算服务,搭载新一代英特尔®至强®铂金处理器,接入CN2低延时高速回国带宽线路,网络访问顺滑、流畅。机房网络架构采用了BGP协议的解决方案可提供多线路互联融合网络,使得不同网络运营商线路的用户都能通过最佳路由实现快速访问。香港云服务器低至29元/月,购买链接:https://www.enuoidc.com/vps.html?typeid=2