博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
强化网站安全性:避免跨网站脚本攻击(XSS)
阅读量:5015 次
发布时间:2019-06-12

本文共 1881 字,大约阅读时间需要 6 分钟。

    XSS攻击分为:“你的网站攻击别人的网站”或是“别人的网站攻击你的网站”两种。

  在ASP.NET MVC里,这两种攻击情境都内建了相应的防护措施,要防止“你的网站攻击别人的网站”,可以使用Html.Encode、Url.Encode或Ajax.JavaScriptStringEncode辅助方法;

而防止“别人的网站攻击你的网站”则使用AntiForgeryToken辅助方法。

  Html.Encode辅助方法无非就是进行Html编码;Url.Encode辅助方法无非就是进行Url编码;Ajax.JavaScriptStringEncode辅助方法就是Js字符串进行文字编码,确保输出的Js字符串

不会含有恶意XSS攻击字符串。

Ajax.JavaScriptStringEncode辅助方法例:

介绍AntiForgeryToken辅助方法:

视图代码

1 @using (Html.BeginForm()) { 2     @Html.AntiForgeryToken() 3     @Html.ValidationSummary(true) 4  5     
6
请输入您的账号、密码 7 8
9 @Html.LabelFor(model => model.email)10
11
12 @Html.TextBoxFor(model => model.email, new { data_val_email="请输入Email地址"})13 @Html.ValidationMessageFor(model => model.email)14
15 16
17 @Html.LabelFor(model => model.password)18
19
20 @Html.EditorFor(model => model.password)21 @Html.ValidationMessageFor(model => model.password)22
23 24

25 26

27
28 }

 

注: AntiForgeryToken辅助方法,必须以Html.BeginForm声明才行,单纯HTML的<form>标签是不行的

C#代码

1 [HttpPost] 2 [ValidateAntiForgeryToken] 3 public ActionResult Login(MemberLoginViewModel login, string returnUrl) 4 { 5     if (ValidateUser(login)) 6     { 7  8         FormsAuthentication.SetAuthCookie(login.email, false); 9 10         if (string.IsNullOrEmpty(returnUrl))11         {12             return RedirectToAction("Index", "Home");13         }14         else15         {16             return Redirect(returnUrl);17         }18     }19 20     ModelState.AddModelError("", "您输入的账号或密码错误");21     return View();22 }

 

posted on
2014-05-14 10:01 阅读(
...) 评论(
...)

转载于:https://www.cnblogs.com/linhui/p/3727074.html

你可能感兴趣的文章
golang——(strings包)常用字符串操作函数
查看>>
发布aar到jcenter
查看>>
跨浏览器问题的五种解决方案
查看>>
XPath定位时,使用文本的方法小技巧。
查看>>
安装pandas报错(AttributeError: 'module' object has no attribute 'main')
查看>>
ch02 fundamental definition 01
查看>>
JSON解析
查看>>
Position is everything?(css定位学习的一些心得)(一)
查看>>
如何提高编程水平
查看>>
Jquery Uploadify3.21.与2.1版本 使用中存在的问题--记录三
查看>>
Linux查看进程的内存占用情况 分类: ubuntu ...
查看>>
[BZOJ 2818]Gcd
查看>>
FORM值传递与地址传递
查看>>
(译)yaml快速教程
查看>>
C:大数相加
查看>>
160. Intersection of Two Linked Lists
查看>>
人生苦短,我用python-- Day11
查看>>
JAVA Bean
查看>>
ehcache memcache redis 三大缓存男高音_转
查看>>
curd_3
查看>>