IT技术:如何有效避免java编程语言中的CSRF攻击?
随着近些年云计算产业处于落地阶段,互联网人才的不断输出,JAVA编程语言因其独有的特点,使其在各项服务器中应用程序的开发所占有一定的优势,随着JSP技术的发展,使JAVA编程语言的网络应用更为实际化、更高效快捷,成为IT产业常用的技术,吸引了越来越多的学子学习JAVA编程语言。
北京八维教育和大家一起分享IT技术如何有效避免JAVA编程语言中的CSRF攻击?,希望能够帮助到正在学习的学子们。
跨站请求伪造(英语:Cross-site request forgery),也被称为 one-click attack 或者 session riding,通常缩写为 CSRF 或者 XSRF, 是一种挟制用户在当前已登录的Web应用程序上执行非本意的操作的攻击方法。跟跨网站脚本(XSS)相比,XSS 利用的是用户对指定网站的信任,CSRF 利用的是网站对用户网页浏览器的信任。
1. 攻击细节
跨站请求攻击,简单地说,是攻击者通过一些技术手段欺骗用户的浏览器去访问一个自己曾经认证过的网站并运行一些操作(如发邮件,发消息,甚至财产操作如转账和购买商品)。由于浏览器曾经认证过,所以被访问的网站会认为是真正的用户操作而去运行。这利用了web中用户身份验证的一个漏洞:简单的身份验证只能保证请求发自某个用户的浏览器,却不能保证请求本身是用户自愿发出的。
1.1 例子
假如一家银行用以运行转账操作的URL地址如下:http://www.examplebank.com/withdraw?account=AccoutName&amount=1000&for=PayeeName
那么,一个恶意攻击者可以在另一个网站上放置代码
如果有账户名为Alice的用户访问了恶意站点,而她之前刚访问过银行不久,登录信息尚未过期,那么她就会损失1000资金。
这种恶意的网址可以有很多种形式,藏身于网页中的许多地方。此外,攻击者也不需要控制放置恶意网址的网站。例如他可以将这种地址藏在论坛,博客等任何用户生成信息的网站中。这意味着如果服务端没有合适的防御措施的话,用户即使访问熟悉的可信网站也有受攻击的危险。
透过例子能够看出,攻击者并不能通过CSRF攻击来直接获取用户的账户控制权,也不能直接窃取用户的任何信息。他们能做到的,是欺骗用户浏览器,让其以用户的名义运行操作。
2. 防御措施
2.1 检查Referer字段
HTTP头中有一个Referer字段,这个字段用以标明请求来源于哪个地址。在处理敏感数据请求时,通常来说,Referer字段应和请求的地址位于同一域名下。以上文银行操作为例,Referer字段地址通常应该是转账按钮所在的网页地址,应该也位于www.examplebank.com之下。而如果是CSRF攻击传来的请求,Referer字段会是包含恶意网址的地址,不会位于www.examplebank.com之下,这时候服务器就能识别出恶意的访问。
这种办法简单易行,工作量低,仅需要在关键访问处增加一步校验。但这种办法也有其局限性,因其完全依赖浏览器发送正确的Referer字段。虽然http协议对此字段的内容有明确的规定,但并无法保证来访的浏览器的具体实现,亦无法保证浏览器没有安全漏洞影响到此字段。并且也存在攻击者攻击某些浏览器,篡改其Referer字段的可能。
2.2 添加校验token
由于CSRF的本质在于攻击者欺骗用户去访问自己设置的地址,所以如果要求在访问敏感数据请求时,要求用户浏览器提供不保存在cookie中,并且攻击者无法伪造的数据作为校验,那么攻击者就无法再运行CSRF攻击。这种数据通常是窗体中的一个数据项。服务器将其生成并附加在窗体中,其内容是一个伪随机数。当客户端通过窗体提交请求时,这个伪随机数也一并提交上去以供校验。正常的访问时,客户端浏览器能够正确得到并传回这个伪随机数,而通过CSRF传来的欺骗性攻击中,攻击者无从事先得知这个伪随机数的值,服务端就会因为校验token的值为空或者错误,拒绝这个可疑请求。
更多关于JAVA编程语言培训的问题,欢迎咨询北京八维教育,北京八维教育云计算专业以全球市场占有率最高的JAVA编程语言为核心技术,培养学生“需求拆分、模块设计、项目拆分、项目维护”四大能力,在“课程设计、项目库建设、企业实操、答辩考核”五大标准下,学生毕业后成为诸多领域,通过云计算技术有效利用各类资源加速应用的并发运行能力,具备可持续发展能力的人才。
开班信息
热点问答
面试题库
IT培训技术知识分享:java开发工程师需要掌握哪些知识?
IT技能云计算培训技术干货Kubernetes教程分享
IT行业解惑:2023Java行业就业发展前景怎么样?
IT行业解惑:2023从Java培训班出来好就业吗?
IT行业解惑:java和php哪个好?
IT行业解惑:java后端开发需要学什么课程?
IT行业解惑:java和c++哪个好?
IT行业解惑:零基础学前端好还是学java好?
IT行业解惑:女生学学云计算技术与应用就业发展前景怎么样?
IT行业解惑:java从入门到精通需要多久?
IT行业解惑:学java要学多久才能参加工作?
IT行业解惑:java编程开发可以从事什么工作?
IT行业解惑:云计算主要学什么课程内容?
IT行业解惑:java就业发展前景怎么样?
IT培训技术知识分享:零基础java编程开发入门应该怎么学?
IT培训技术知识分享:java编程开发有哪些技术?
IT行业解惑:女生适合学java编程开发吗?
IT行业解惑:IT云计算学习是否很难?
推荐问答
IT行业解惑|优秀的java软件开发工程师需要具备什么能力
Java作为一门广泛应用于企业级应用和开发的编程语言,一直以来都备受青睐。然而,对于那些对Java软件开发工程师感兴趣的人来说,他们经 ...
IT行业解惑|学习云计算有前途吗?
目前,衣食住行等各种基于互联网的服务都在产生大数据,大数据的处理和分析需要云计算。云计算的应用极大地改变了人们的生活方式、消费 ...
IT行业解惑|零基础如何学习云计算?
云计算是近年来的一项新技术。在云计算技术出现之前,没有人知道云计算,大学也没有开设云计算相关的课程。第一批从事云计算工作的人基 ...
IT行业解惑|java软件开发工程师就业前景怎么样?
对于那些想要转行Java软件开发工程师的人来说,门槛相对较低,但是要想有一个长远的职业规划,需要认真规划职业发展。...
IT行业云计算java培训课程学习笔记|Java程序员必须熟知的十项技术
在我们学习过程中需要我们去掌握一些常见的Java编程技术,那么有哪些技术是必须掌握的呢?北京八维教育培训学校整理了一份java课程培训学习笔记——Java程序员必须熟知的十项技术。...
IT技术解惑|Java工程师如何提升职场竞争力
Java作为一门广泛应用于企业级应用和开发的编程语言,一直以来都备受青睐。然而,对于那些对Java开发感兴趣的人来说,Java工程师如何提升职场竞争力呢?...
IT行业云计算java培训课程学习笔记|Java程序员必须掌握的英语词组(九)
学习Java编程语言技术,都会学习哪些内容?北京八维教育培训学校先分享整理好的一份IT行业云计算java培训课程学习笔记中的Java程序员必须掌握的英语词组...
IT行业云计算java培训课程学习笔记|Java程序员必须掌握的英语词组(八)
学习Java编程语言技术,都会学习哪些内容?北京八维教育培训学校先分享整理好的一份IT行业云计算java培训课程学习笔记中的Java程序员必须掌握的英语词组...
IT行业云计算java培训课程学习笔记|Java程序员必须掌握的英语词组(七)
学习Java编程语言技术,都会学习哪些内容?北京八维教育培训学校先分享整理好的一份IT行业云计算java培训课程学习笔记中的Java程序员必须掌握的英语词组...
IT技术解惑|云计算入门必备常识
云计算技术说难不难,说简单也不简单。首先我们要了解一下什么是云计算。云计算是基于互联网的相关服务的增加、使用和交互模式,通常涉及通过互联网来提供动态易扩展且经常是虚拟化的...
IT技术解惑|云计算技术主要学什么?
目前云计算岗位有核心技术多样化,就业岗位全面化的趋势,云计算工程师既要掌握虚拟化、容器、自动化运维及云平台等核心技术,还要了解 ...
IT技术解惑|云计算运维的就业方向有哪些?
云平台运维工程师。云平台运维工程师是云计算运维中最主要和基础的职业方向之一。他们负责管理和维护云计算平台的稳定性和性能,确保云 ...
IT技术解惑|云计算技术人才未来就业发展前景怎么样?
面对未来云计算产业的飞速发展,无论从技术层面,运营商层面还是集成与服务提供层面,企业对于云计算技术人才需求数量激增。...
java编程课程培训学习笔记|易疏忽的日志
当下越来越多的人学习Java编程技术,需要我们从基础知识学起,学好之后还要掌握一定的主流Java技术,那么有哪些技术是必须掌握的呢?北京八维教育培训学校整理了一份java课程培训学习笔记...
java编程课程培训学习笔记|equals 方法和==究竟有什么区别
我们学习过程中需要我们去掌握一些常见的Java编程技术,那么有哪些技术是必须掌握的呢?北京八维教育培训学校整理了一份java课程培训学习笔记——equals 方法和==究竟有什么区别。...
java编程课程培训学习笔记|volatile关键字有什么作用
我们学习过程中需要我们去掌握一些常见的Java编程技术,那么有哪些技术是必须掌握的呢?北京八维教育培训学校整理了一份java课程培训学习笔记——volatile关键字有什么作用。...
java编程课程培训学习笔记|缓存的淘汰策略有几种方式
目前Java编程技术发展很迅速,有哪些Java编程技术是必须掌握的呢?北京八维教育培训学校整理了一份java课程培训学习笔记——缓存的淘汰策略有几种方式。...
java编程课程培训学习笔记|数据库如何保证主键唯一性
目前Java编程技术发展很迅速,有哪些Java编程技术是必须掌握的呢?北京八维教育培训学校整理了一份java课程培训学习笔记——数据库如何保证主键唯一性。...
java编程课程培训学习笔记|redis持久化的方式
目前Java编程技术发展很迅速,有哪些Java编程技术是必须掌握的呢?北京八维教育培训学校整理了一份java课程培训学习笔记——redis持久化的方式。...
java编程课程培训学习笔记|受欢迎的Java类
目前Java编程技术发展很迅速,有哪些Java编程技术是必须掌握的呢?北京八维教育培训学校整理了一份java课程培训学习笔记——受欢迎的Java类。...
八维教育启动“晨曦破晓”计划
以科技助力高薪破局
以科技提升系统效率
以科技提高服务质量
八维教育助力学子优质就业!
请您保持通讯畅通,专属学习老师24小时内将与您1V1沟通