CSRF/XSRF攻击和XSS攻击

XSS(CrossSiteScripting跨站脚本)。XSS定义的主语是“脚本”,是一种跨站执行的脚本,也就是javascript脚本,指的是在网站上注入我们的javascript脚本,执行非法操作。 CSRF(Cross-siterequestforgery跨站请求伪造,也被称为“OneClickAttack”或者SessionRiding,通常缩写为CSRF或者XSRF,是…

大家好,又见面了,我是你们的朋友全栈君。

XSS(Cross Site Scripting跨站脚本)。XSS定义的主语是“脚本”,是一种跨站执行的脚本,也就是javascript脚本,指的是在网站上注入我们的javascript脚本,执行非法操作。 

CSRF(Cross-site request forgery跨站请求伪造,也被称为“One Click Attack”或者Session Riding,通常缩写为CSRF或者XSRF,是一种对网站的恶意利用。CSRF定义的主语是”请求“,是一种跨站的伪造的请求,指的是跨站伪造用户的请求,模拟用户的操作.

XSS攻击发生的条件是可以执行javascript脚本,一般在站点中总会有发表文章、留言等信息的表单,这种表单一般是写入到数据库中,然后在某个页面进行展示。我们可以在这些表单中直接编写javascript代码(<script>alert("哈哈哈哈,你被攻击了!");</script>)进行测试,看是否可以执行。如果在信息展示页面js代码可以执行,XSS攻击就成功了。

 

CSRF攻击能够成功,是因为黑客可以完全伪造用户的请求,该请求中所有的用户验证信息都是存在于cookie中,因此黑客可以在不知道这些验证信息的情况下直接利用用户自己的cookie 来通过安全验证。要抵御 CSRF,关键在于在请求中放入黑客所不能伪造的信息,并且该信息不存在于 cookie 之中。可以在 HTTP 请求中以参数的形式加入一个随机产生的 token,并在服务器端建立一个拦截器来验证这个 token,如果请求中没有token或者 token 内容不正确,则认为可能是 CSRF 攻击而拒绝该请求。这种方法要比检查 Referer 要安全一些,token 可以在用户登陆后产生并放于session之中,然后在每次请求时把token 从 session 中拿出,与请求中的 token 进行比对

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/124627.html原文链接:https://javaforall.net

(0)
上一篇 2022年4月3日 下午5:00
下一篇 2022年4月3日 下午5:00


相关推荐

  • java getmethod int_带有子类参数的Java getMethod

    java getmethod int_带有子类参数的Java getMethod我正在编写一个使用反射来动态查找和调用方法的库 只给出一个对象 一个方法名和一个参数列表 我需要调用给定的方法 就好像方法调用是在代码中显式编写的一样 我一直在使用以下方法 在大多数情况下都可以使用 staticvoidca Objectreceiv Stringmethod Object params Class gt paramTypes

    2026年3月17日
    2
  • Java基础&笔试题

    Java基础&笔试题

    2021年9月13日
    68
  • 共享内存函数(shmget、shmat、shmdt、shmctl)及其范例

    共享内存函数(shmget、shmat、shmdt、shmctl)及其范例共享内存函数由 shmget shmat shmdt shmctl 四个函数组成 下面的表格列出了这四个函数的函数原型及其具体说明 1 nbsp shmget 函数原型 shmget 得到一个共享内存标识符或创建一个共享内存对象 所需头文件 include includ

    2026年3月17日
    2
  • kubernetes清除状态为Evicted的pod

    kubernetes清除状态为Evicted的podkubectlgetpods|grepEvicted|awk'{print$1}’|xargskubectldeletepod  清除脚本#!/bin/bashforpodin$(kubectlgetpods|grepEvicted|awk'{print$1}’);dokubectldeletep…

    2022年5月16日
    94
  • ringbuffer的常规用法_likewise用法

    ringbuffer的常规用法_likewise用法C/C++Linux服务器开发/后台架构师知识体系整理环形缓冲区(RINGBUFFER)的实现原理环形缓冲区通常有一个读指针和一个写指针(一个入指针和一个出指针)。读指针指向环形缓冲区中可读的数据,写指针指向环形缓冲区中可写的缓冲区。通过移动读指针和写指针就可以实现缓冲区的数据读取和写入。在通常情况下,环形缓冲区的读用户仅仅会影响读指针,而写用户仅仅会影响写指针。如果仅仅有一个读用户和一个写用户,那么不需要添加互斥保护机制就可以保证数据的正确性。如果有多个读写用户访问环形缓冲区,那么必须添加互斥保护机

    2025年10月22日
    3
  • MacOS抓包工具Charles「建议收藏」

    MacOS抓包工具Charles「建议收藏」抓包工具有wireshark,tcpdump,还有就是Charles。今天分享的是最后一个Charles。抓包分2个,一个是移动端的,一个是macOS自带的应用。安装Charleshttps://www.charlesproxy.com/latest-release/download.do这里有官方最新的包,不过启动后有提示。也有符合社会主义特殊的软件#替换包里面的…

    2022年6月8日
    67

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号