问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
你好,欢迎来到懂视!登录注册
当前位置: 首页 - 正文

[译]七大最常见的前端安全攻击

发布网友 发布时间:2024-10-20 19:06

我来回答

1个回答

热心网友 时间:2024-10-20 20:01

如果你正在构建 web 应用,那么你不仅要关注应用的开发,还要关注其安全性。

❝ 事实上,由于 web 应用程序设计不当,每天发生的 网络攻击超过 2,200 起。 ❞

因此,你必须了解 web 应用中可能发生的不同类型的攻击,以及如何防范这些攻击。

1. 跨站脚本攻击 (Cross-Site Scripting:XSS)

跨站脚本攻击(XSS)是最常见的攻击之一。在 XSS 攻击中,攻击者将恶意脚本注入可信网站,然后在用户浏览器中执行。

什么会导致 XSS 攻击?

XSS 攻击的主要原因之一是在页面上渲染用户输入内容之前,对这些输入未处理或处理不当。例如,攻击者可以使用 JavaScript 注入恶意代码,并在应用渲染 DOM 时执行。

这些恶意代码最终会访问并窃取用户会话令牌、cookie 和其他存储在浏览器中的敏感信息。

❝ 笔者举例:比如用户输入,未进行处理的话,在展示这段内容时可能会在浏览器提示 foolish。❞

如何防止 XSS 攻击?

防止跨站脚本攻击并不难,对用户输入内容的验证是核心。

确保对用户插入的数据进行过滤,内容进行编码。此外,考虑使用 内容安全策略(CSP)来*加载的资源和脚本。或者,只需使用 Angular、Vue 和 React 等框架,这些框架都有针对跨站脚本攻击的内置预防机制。

2. SQL 注入

SQL 注入是一种存在已久的致命攻击。攻击会操纵数据库查询以获得未经授权的数据库访问权限,从而执行恶意活动,如破坏数据库或窃取敏感数据。

❝ 简单地说,SQL 注入可让攻击者从你的前端执行 SQL 查询。这可能会导致破坏性操作,使你的数据库宕机 ❞

例如,2020 年对爱沙尼亚*健康数据库的攻击导致几乎所有爱沙尼亚公民的健康记录泄露,就是近年来发生的大规模 SQL 注入事件的一个令人痛心的例子。

如何防止 SQL 注入?

防止 SQL 注入的策略分为两个部分:

3. 跨站请求伪造(Cross Site Request Forgery: CSRF)

跨站请求伪造(CSRF)是一种前端安全攻击,它会欺骗特定应用上的认证用户,让他们执行他们不希望执行的请求。

❝ 这可能是一个伪装过的表单、链接或按钮,在用户发出请求时会更改用户凭据、删除或篡改敏感数据,或无意中从用户的银行账户中转移资金。 ❞ ❝ 笔者举例:,登录的用户访问到这个 img 标签时,会发起转账请求并自动带上登录相关的 cookie。 ❞

如何防止 CSRF 攻击?

防止 CSRF 攻击的最简单方法之一就是使用从服务器生成的 CSRF 令牌。你可以与客户端共享这些令牌,这样服务端就可以在收到的每个请求中检查令牌并验证其真实性。如果客户端未能提供准确的令牌,服务器就可以拒绝所请求的操作。

此外,.NET、Joomla、Spring(Spring Security)和 Ruby on Rails 等框架都内置了 CSRF 支持,可防止此类攻击。

4. 中间人攻击

中间人(MitM)攻击指攻击者截获并操纵双方之间传输的信息。

❝ 例如,攻击者可以拦截你与*.com 的连接,窃取你的凭据,然后将你的请求转发给 *。 ❞

当攻击者利用不安全的通信渠道(通常通过公共 WiFi)时,就可以发生此类攻击。这种攻击的受害者并不觉得自己受到了攻击,因为他们认为自己正在与服务器进行非常正常和安全的对话,而他们正在共享的信息却在途中被窥探或篡改。

如何防止中间人攻击?

5. 点击劫持

点击劫持(A.K.A - UI 纠错攻击)是一种欺骗机制,它欺骗用户点击了不是他们想要访问的东西。

它将隐藏元素覆盖在网站上一些可点击的内容之上。在这种情况下,用户实际上是在点击一个非预期元素,而该元素可能会在未经用户同意的情况下触发资金转移等意外操作。

❝ 笔者举例:攻击者开发了一个页面,里面用 iframe 加载平铺了百度页面,并在百度搜索的按钮上覆盖一个元素,用户点击搜索时,实际点击的是搜索之上的那个元素。 ❞

如何防止点击劫持攻击?

为了降低点击劫持攻击的潜在风险,可以使用一种机制,即使用 X-Frame-Options 标头,以确保你的网站没有嵌入到其他网站或 IFrames 中。

6. 安全配置错误攻击

不恰当的设置、默认值和过时的配置往往会导致应用出现安全配置错误问题,从而使网络犯罪分子有机可乘。

❝ 例如,可能会出现以下情况:启用目录列表可能会泄露敏感信息、密码和仍是默认值的密钥,以及暴露错误处理信息。 ❞

如何防止安全配置错误问题?

7. 依赖性利用

❝ 笔者:上图中公司内部和公共 npm 上都有名为 company-interal-lib 的库,如果你安装时不指定公司的源,你可能会安装 npm 上的包,这个包有安全漏洞。 ❞

前端应用由大量第三方库组成,这些库的使用使开发人员的工作变得更加轻松。但开发人员经常疏忽的一点是,这些库有时可能存在安全漏洞。

❝ 例如, Log4j 存在一个巨大的漏洞,攻击者可以在 Java 环境中执行远程代码。因此,任何使用 Log4j 的应用程序都会成为这种攻击的受害者! ❞

如何防止依赖性利用?

使用广泛使用、维护得当、可靠并经过社区测试的库。

除此之外,定期审计、更新依赖关系和使用 漏洞扫描工具也能确保前端应用的安全。

总结

确保你构建的 web 应用保持高度安全非常重要。这不仅仅是为了你的应用有良好的用户体验,更是为了确保用户数据的安全。

阅读完这篇文章后,我建议你检查一下你的应用代码,看看你的应用是否容易出现上述问题,如果有,请立即采取相关策略!

感谢你的阅读。
声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。
E-MAIL:11247931@qq.com
鸿蒙NEXT EROFS 文件系统有何大优势_鸿蒙 NEXT 中的EROFS文件系统优势介... Huawei EROFS 初探 [科普] 华为P30系列手机黑科技EROFS解密 Linux磁盘剩余空间查看方法 招行信用卡分期利息多少钱招行信用卡分期利息 公司哪些事情千万不要告诉同事? 爱奇艺怎么用小米账号登录 抖音上的音乐怎么设置手机铃声 c1转c2需要什么条件考完科二 徐州c1转c2可以吗 为什么我的号码办理了流量套餐,确上不了网,还老是弹出中国移动数据连 ... 刚刚取消了中国移动4g的流量套餐和4g的流量功能 现在我重新开通了流量功... 打包饭菜能带上飞机吗? 我们在歺厅上班,突然被退了,请问劳动法 iPhone5S手机进水花屏蓝屏黑屏维修多少钱 2021年423世界读书日 心下面一个口,这字读什么? 哈利波特 魔药 制作方法 想煮一些降火的甜汤,简单做法一些的?要怎么煮,需要放多少食材?就如银耳... 买一套126平米的安置房,房产证满两年都是首套房,双方过户费多少,请大神... 江西关税什么意思 厦门合一集团有限公司合一集团董事长个人简介 江西合一百应信息科技有限公司怎么样? 江西硒人五合一健康咨询有限公司怎么样? 魅蓝note2艾迪我手机锁屏了 魅蓝note2手机锁屏了怎么打开 魅蓝5S这是怎么回事,求大神帮助 除夕可以回娘家过年吗 除夕能不能回娘家过年呢 贵人语迟教宝宝说话有什么妙招 魅蓝note2更新版本后锁屏密码还在不在?。 晨跑有助于减肥吗拜托各位了 3Q 我身体偏瘦 皮肤偏黑 要染头发 不知道 染什么颜色 最好是能坚持的时间... 皮肤黑的人染什么颜色的头发会显得白点?适合穿什么样颜色的衣服 双开单控开关的接线方法 真不知为什么,公司要星期六上班 三线双开的接法 开经偈解释 ...很孤僻,害怕孤独却又不想和别人亲近,不善于交际,不善于言辞,不管在... ...被老板开除了,没有签合同,老板违反了劳动法了吗?是否要他给我赔偿... 抖音数据分析工具蝉妈妈、达多多、考古加、飞瓜哪个比较好用?_百度知 ... 多多直播ocpx费用(多多直播收费吗) 为什么韭菜越种越细 韭菜生长越来越细怎么办 FBEC2019Unity制作人专场顺利落幕Unity叠纸巨人技术大牛分享干货满满... 怎么把移动的光纤改成桥接模式 西南是哪些地方 一个罐罐,装些饭饭,不吃饭饭,要吃罐罐.打一特产.猜对有奖.前20位 三国时期的罐茶习俗 有哪些大学里面有专科学校 肉心杏仁饼做法图解
  • 焦点

最新推荐

猜你喜欢

热门推荐