博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用nodejs防止csurf攻击的方法
阅读量:5925 次
发布时间:2019-06-19

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

一.CSRF是什么?

  CSRF(Cross-site request forgery),中文名称:跨站请求伪造,也被称为:one click attack/session riding,缩写为:CSRF/XSRF。

二.CSRF可以做什么?

  你这可以这么理解CSRF攻击:攻击者盗用了你的身份,以你的名义发送恶意请求。CSRF能够做的事情包括:以你名义发送邮件,发消息,盗取你的账号,甚至于购买商品,虚拟货币转账......造成的问题包括:个人隐私泄露以及财产安全。

三.CSRF漏洞现状

  CSRF这种攻击方式在2000年已经被国外的安全人员提出,但在国内,直到06年才开始被关注,08年,国内外的多个大型社区和交互网站分别爆出CSRF漏洞,如:NYTimes.com(纽约时报)、Metafilter(一个大型的BLOG网站),YouTube和百度HI......而现在,互联网上的许多站点仍对此毫无防备,以至于安全业界称CSRF为“沉睡的巨人”。

四.CSRF的原理

  下图简单阐述了CSRF攻击的思想:

  

  从上图可以看出,要完成一次CSRF攻击,受害者必须依次完成两个步骤:

  1.登录受信任网站A,并在本地生成Cookie。

  2.在不登出A的情况下,访问危险网站B。

以上内容转自 的博文

 四.nodejs防止CSURF攻击的方法:

  1)安装csurf和express-session包,因为csurf包依赖express-session包,所以两个依赖包都要安装   

cnpm  insatll csurf --savecnpm  install express-session --save

  2)安装完依赖后,先在app.js文件中引入express-session模块,该模块的引入放在路由的前面,不然会报错

var session = require('express-session');app.use(session({        //生成一个session实例    secret: 'keyboard cat',    resave: false,    saveUninitialized: false,}));

  3)使用csurf模块

var csurf = require('csurf');   //引入模块var csrfProtection = csurf();   //设置路由中间件router.use(csrfProtection);    router.get('/user/signup',function(req,res,next){    res.render('user/signup',{        csrfToken: req.csrfToken()     }); });

  4)隐藏csrfToken

  

 

转载于:https://www.cnblogs.com/y-yxh/p/5761941.html

你可能感兴趣的文章
Java并发编程基础-线程-状态
查看>>
HTTPS 部署简要指南
查看>>
MySQL用户管理
查看>>
Jquery——输入验证
查看>>
java读取某个文件夹下的所有文件
查看>>
★不评价别人的生活,是一个…
查看>>
Java生成十六进制的MD5加密字符串
查看>>
struts2 传值方式
查看>>
CentOS7 zookeeper3.4.11安装部署
查看>>
使用gitlab+git+mysql+redis+nginx搭建自己的代码管理平台
查看>>
C++ 语言中定义了如下转义字符(C ++ primer)
查看>>
自己动手写一个Camera
查看>>
join
查看>>
设计模式:装饰者
查看>>
树莓派 ( Raspberry pi ) 安装火狐浏览器
查看>>
jquery slider的总结
查看>>
CentOS minimal+VirtualBox 设置桥接DHCP网络连接
查看>>
phpredis编译安装
查看>>
stackless突破python用户级线程库和复杂递归---<<python核心编程第二版>>
查看>>
SQL:exist使用
查看>>