本文由 ChatMoney团队出品

sql注入

漏洞描述

当应用程序将用户输入直接拼接到sql语句中时,攻击者可以插入恶意sql代码来篡改原始查询,获取或破坏数据库信息。

防御措施

预处理语句

使用预处理语句可以有效防止sql注入,因为参数值不会被视为sql的一部分。

$stmt = $pdo->prepare('select * from users where username = :username');
$stmt->execute(['username' => $_post['username']]);

使用pdo或mysqli

确保使用pdo或mysqli扩展,并启用它们提供的模拟预处理功能。

转义输入

如果无法使用预处理语句,应至少对用户输入进行适当的转义。

$username = $db->real_escape_string($_post['username']);
$query = "select * from users where username = '$username'";

使用orm

对象关系映射(orm)工具通常提供内置的sql注入保护。

跨站脚本攻击(xss)

漏洞描述

攻击者通过在网站上注入恶意脚本,当其他用户浏览该网站时,这些脚本会被执行,可能导致信息泄露。

防御措施

过滤和转义输出

对所有的输出数据应用html实体编码或剥离标签。

echo htmlspecialchars($user_input, entry_tags, $charset);

内容安全策略(csp)

使用http头content-security-policy来限制浏览器加载页面时外部资源的权限。

使用http only cookie

设置cookie属性为httponly,以防止客户端脚本访问cookie。

setcookie('session_id', '...', httponly=>true);

跨站请求伪造(csrf)

漏洞描述

攻击者利用用户在其他选项卡或窗口中已认证的身份,诱导用户点击链接或访问站点,执行非预期的操作。

防御措施

使用csrf tokens

在表单中嵌入随机生成的、与用户会话关联的token,并在提交时验证这个token。

// 生成一个csrf token$_sssion['csrf_token'] = bin2hex(random_bytes(32));

// 表单中添加token
<input type="hidden" name="csrf_token" value="<?php echo $_sssion['csrf_token']; ?>"
// 验证tokenif ($_post['csrf_token'] != $_sssion['csrf_token']) {// 拒绝请求
}

验证请求来源

检查http referer头部,确保请求来自合法的源。

同步操作确认

对于敏感操作,要求用户重新输入密码或进行二次验证。

文件上传漏洞

漏洞描述

用户可以上传恶意文件,如脚本文件,进而控制服务器或者利用文件包含漏洞执行远程代码。

防御措施

文件类型检查

只允许预定义的文件类型上传,并对文件扩展名进行检查。

$allowed_types = ['image/jpeg', 'image/png'];
$file_type = exif_imagetype($_files['upload']['tmp_name']);
if (!in_array($file_type, $allowed_types)) {// 拒绝上传
}

文件内容检查

使用文件扫描工具如clamav扫描上传的文件内容。

文件权限和路径

存储上传文件的目录不应具有执行权限,并且不应该位于可以通过web访问的路径下。

使用白名单机制

不要基于黑名单排除不安全的文件类型,而是应该使用白名单仅允许特定的安全文件类型。

关于我们

本文由ChatMoney团队出品,ChatMoney专注于AI应用落地与变现,我们提供全套、持续更新的AI源码系统与可执行的变现方案,致力于帮助更多人利用AI来变现,欢迎进入ChatMoney获取更多AI变现方案!

PHP安全防御需注意点的点的更多相关文章

  1. LDAP注入与防御解析

    [目录] 0x1 LDAP介绍 0x2 LDAP注入攻击及防御 0x3 参考资料 0x1 LDAP介绍 1 LDAP出现的背景 LDAP(Lightweight Directory Access Pr ...

  2. 安全测试 - CSRF攻击及防御

    CSRF(Cross-site request forgery跨站请求伪造) 尽管听起来像跨站脚本(XSS),但它与XSS非常不同,并且攻击方式几乎相左.XSS利用站点内的信任用户,而CSRF则通过伪 ...

  3. 安全测试 - XSS如何防御

    XSS主要是通过劫持用户COOKIE,执行JS脚本进行攻击 如何发现: 可以使用<script>alert(/yourname/)</script> script最具有代表性也 ...

  4. web应用安全防御100技 好书再次阅读, 变的只是表象,被概念迷惑的时候还是静下心来回顾本质

    如何进行web应用安全防御,是每个web安全从业者都会被问到的问题,非常不好回答,容易过于肤浅或流于理论,要阐明清楚,答案就是一本书的长度.而本文要介绍一本能很好回答这个问题的优秀书籍——<we ...

  5. x01.Game.LitSkull: 梯次防御

    1.人要有点精神 人要有点精神,否则,不是沦落为毫无意义的看客,就是退化成食色性也的动物,有被开除球籍的危险,如晚清. 2.框架 引号头文件在当前目录下搜寻,三角头文件在配置目录下搜寻,这是一个简单的 ...

  6. Android应用与系统安全防御

    来源:HTTP://WWW.CNBLOGS.COM/GOODHACKER/P/3864680.HTML ANDROID应用安全防御 Android应用的安全隐患包括三个方面:代码安全.数据安全和组件安 ...

  7. Java JDBC下执行SQL的不同方式、参数化预编译防御

    相关学习资料 http://zh.wikipedia.org/wiki/Java数据库连接 http://lavasoft.blog.51cto.com/62575/20588 http://blog ...

  8. bzoj3035: 导弹防御塔

    Description Freda的城堡——“Freda,城堡外发现了一些入侵者!”“喵...刚刚探究完了城堡建设的方案数,我要歇一会儿嘛lala~”“可是入侵者已经接近城堡了呀!”“别担心,rain ...

  9. 恒天云技术分享系列4 – OpenStack网络攻击与防御

    恒天云技术分享系列:http://www.hengtianyun.com/download-show-id-13.html 云主机的网络结构本质上和传统的网络结构一致,区别大概有两点. 1.软网络管理 ...

  10. cocos2d-x设计模式发掘之五:防御式编程模式

    http://www.ityran.com/archives/2105 本文由子龙山人原创,泰然授权转载,转载请注明出处并通知子龙山人! 声明:防御式编程是提高程序代码质量的一种手段,它不能算是真正意 ...

随机推荐

  1. 算法图解,关于数组,链表,以及大O表示法

    有关数组.链表以及大O表示法 关于数组 [1] 连续性:数组在内存中连续储存,就像是看电影的一群人排排坐. [2] 易读性:数组中的元素可以随意读取. [3] 难改性:由于连续的特性,增减元素都会导致 ...

  2. Centos双网卡冗余绑定

    1. 前言 关于双网卡绑定,前前后后踩过不少的坑,虽然这是 RHCE 中的一道题,但是在实践中碰到问题也够喝一壶的. 在实践中,虚拟机.物理机都做过,但是不尽相同,大部分的坑也集中在这里,本文长期更新 ...

  3. Vmware ESXi 是免费吗?一文弄懂vSphere功能特性及ESXi与vSphere到底有什么区别和联系。

    目录 收起 一.对VMware vSphere及ESXi的相关疑问 1.Vmware vSphere 有些什么功能? 2.ESXi 是否真正免费? 3. ESXi 和 vSphere 到底有什么区别, ...

  4. 【Markdown】公式指导手册

    点击跳转至 Cmd Markdown 简明语法手册 ,立刻开始 Cmd Markdown 编辑阅读器的记录和写作之旅! 本文为 MathJax 在 Cmd Markdown 环境下的语法指引. Cmd ...

  5. 探秘Transformer系列之(23)--- 长度外推

    探秘Transformer系列之(23)--- 长度外推 目录 探秘Transformer系列之(23)--- 长度外推 0x00 概述 0x01 背景 1.1 问题 1.2 解决思路 1.3 微调的 ...

  6. 免费在线试用 200+ Linux 和 Unix 操作系统

    Linux 和 Unix 存在着各种各样的发行版本,有的界面美观,有的功能强大,想要尝试不同的 Linux 和 Unix 操作系统,你可能会烦于进行本地安装.不急,今天,我们来介绍一个强大的服务,Di ...

  7. WCHNET_SocketSend返回0x11原因及解决方法

    问题描述: TCPCLIENT模式使用WCHNET_SocketSend发送有概率会返回0x11 按wchnet.h定义为内存溢出错误. 异常分析: 通过WCHNET_QueryUnack查看,发现异 ...

  8. 无耳 Solon Ai MCP,发布工具服务,使用工具服务。效果预览!

    solon-ai-mcp 是 solon-ai 的扩展特性.提供 mcp 协议的支持.通过它,可以方便的发布 Tool Service,方便的使用 Tool Service. 引入依赖包 <de ...

  9. Quartz.Net定时任务

    参照: [项目升级]集成Quartz.Net Job实现(一) - 腾讯云开发者社区-腾讯云 (tencent.com) Quartz分布式任务调度 - 掘金 (juejin.cn) 基本概念: Qu ...

  10. Linux的API

    一.常用命令 1.Linux命令之剪切 mv 目标文件 目的文件 2.Linux之新增文件夹 mkdir 路径+文件名 3.Linux之删除命令 rm 删除文件 rmdir 删除文件夹