web安全基础知识

Posted DRQ丶

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了web安全基础知识相关的知识,希望对你有一定的参考价值。

常见的web安全问题,原理和防范措施。 

  • SQL注入
  • XSS(跨站脚本攻击, Cross-Site Scripting)
  • CSRF(跨站请求伪造, Cross-site request forgery)

 

什么是SQL注入?

  • 通过构造特殊的输入参数传入web应用,导致后端执行了恶意的SQL
  • 通常由于程序员未对输入进行过滤,直接动态拼接SQL产生
  • 可以使用开源工具sqlmap,SQLninja 检测。

 

如何防范SQL注入?

原则:永远不要相信用户的任何输入

  • 对输入参数做好检查(类型和范围); 过滤和转义特殊字符
  • 不要直接拼接sql, 使用ORM可以大大降低sql注入的风险
  • 数据库层: 做好权限管理配置; 不要明文储存敏感信息。

 

什么是xss(Cross Site Scripting), 跨站脚本攻击

  • 恶意用户将代码植入到提供给其他用户使用的页面中,未经转义的恶意代码输出到其他用户的浏览器中被执行
  • 用户浏览页面的时候嵌入页面的脚本(js)会被执行,攻击用户。 比如dom中: document.cookie 可以获取页面的cookie信息。
  • 主要分为两类: 反射型(非持久型), 存储型(持久型)

 

如何防范XSS呢?

不要相信用户的任何输入!

  • 过滤(输入和参数)。 对敏感标签<script> <img><a>等进行过滤。
  • 转义。 对常见的符号("&", "<" , ">")转义(python3 html.escape)

以上是关于web安全基础知识的主要内容,如果未能解决你的问题,请参考以下文章

Web入门基础360网络安全大学Web基础公开课知识点总结(基础篇)

Java Web基础知识之安全:人生苦短,注意安全

Exp9 Web安全基础

WEB安全基础入门—操作系统命令注入(shell 注入)

WEB安全基础入门—身份验证漏洞

web安全基础