xss跨站脚本攻击:恶意攻击者往Web页面里插入恶意Script代码,当用户浏览该页之时,嵌入其中Web里面的Script代码会被执行,从而达到恶意攻击用户的目的。php
例如:某些论坛容许用户自由发言,而不对用户的输入数据进行检测,直接显示在页面中。css
如果用户输入了某些css样式代码,html表格代码,显示在页面后会改变页面的布局。html
如果输入某些js代码,用于获取其余用户的文件,或者修改本地文件,也能够发送用户cookie等信息到本身的计算机中模拟用户登陆前端
通常能够经过函数处理htmlspecialchars(php中)或者正则或者模板本身处理python
xsrf(csrf)跨站点请求伪造:ajax
CSRF攻击实例:安全
受害者 Bob 在银行有一笔存款,经过对银行的网站发送请求 http://bank.example/withdraw?account=bob&amount=1000000&for=bob2 可使 Bob 把 1000000 的存款转到 bob2 的帐号下。一般状况下,该请求发送到网站后,服务器会先验证该请求是否来自一个合法的 session,而且该 session 的用户 Bob 已经成功登录。服务器
黑客 Mallory 本身在该银行也有帐户,他知道上文中的 URL 能够把钱进行转账操做。Mallory 能够本身发送一个请求给银行:http://bank.example/withdraw?account=bob&amount=1000000&for=Mallory。可是这个请求来自 Mallory 而非 Bob,他不能经过安全认证,所以该请求不会起做用。cookie
这时,Mallory 想到使用 CSRF 的攻击方式,他先本身作一个网站,在网站中放入以下代码: src=”http://bank.example/withdraw?account=bob&amount=1000000&for=Mallory ”,而且经过广告等诱使 Bob 来访问他的网站。当 Bob 访问该网站时,上述 url 就会从 Bob 的浏览器发向银行,而这个请求会附带 Bob 浏览器中的 cookie 一块儿发向银行服务器。大多数状况下,该请求会失败,由于他要求 Bob 的认证信息。可是,若是 Bob 当时恰巧刚访问他的银行后不久,他的浏览器与银行网站之间的 session 还没有过时,浏览器的 cookie 之中含有 Bob 的认证信息。这时,悲剧发生了,这个 url 请求就会获得响应,钱将从 Bob 的帐号转移到 Mallory 的帐号,而 Bob 当时绝不知情。等之后 Bob 发现帐户钱少了,即便他去银行查询日志,他也只能发现确实有一个来自于他本人的合法请求转移了资金,没有任何被攻击的痕迹。而 Mallory 则能够拿到钱后逍遥法外。
拦截方法之一:token
CSRF 攻击之因此可以成功,是由于黑客能够彻底伪造用户的请求,该请求中全部的用户验证信息都是存在于 cookie 中,所以黑客能够在不知道这些验证信息的状况下直接利用用户本身的 cookie 来经过安全验证。要抵御 CSRF,关键在于在请求中放入黑客所不能伪造的信息,而且该信息不存在于 cookie 之中。能够在 HTTP 请求中以参数的形式加入一个随机产生的 token,并在服务器端创建一个拦截器来验证这个 token,若是请求中没有 token 或者 token 内容不正确,则认为多是 CSRF 攻击而拒绝该请求。
python使用token进行处理代码:(因为该token数据并不存在在cookie中,用户不能直接使用cookie模拟登录状态发送请求,用户必须先get请求该页面,从而得到token,而后才能附上该token提交数据请求。固然这种方法也不是彻底能够防止的)
在前端,form表单中将数据添加到了input:_xsrf隐藏标签中,同时也为该用户生成了一个cookie:_xsrf存放在用户cookie中
能够经过form表单传递这个令牌,也能够经过ajax将令牌数据传递到服务端进行识别
class CsrfHandler(BaseRequestHandler): def get(self, *args, **kwargs): self.render('csrf.html') def post(self, *args, **kwargs): self.write('提交') settings ={ 'template_path':'views', 'static_path':'statics', 'cookie_secret':'dafawafawfaw', 'xsrf_cookies':True, }
<form action="/csrf" method="post"> {% raw xsrf_form_html() %} <input type="text" name="nm"/> <input type="password" name="pawd"> <input type="submit" value="提交"> </form>
function getCookie(name) { var r = document.cookie.match("\\b" + name + "=([^;]*)\\b"); return r ? r[1] : undefined; } jQuery.postJSON = function(url, args, callback) { args._xsrf = getCookie("_xsrf"); $.ajax({url: url, data: $.param(args), dataType: "text", type: "POST", success: function(response) { callback(eval("(" + response + ")")); }}); };