热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

PHP十大最佳安全实践

PHP十大最佳安全实践

PHP安全性设置提示:

?
1
2
3
4
5
6
7
8
9
  DocumentRoot: /var/www/ Default Web server: Apache
  
  Default PHP configuration file: /etc/php.ini
  
  Default PHP extensions config directory: /etc/php.d/
  
  Our sample php security config file: /etc/php.d/security.ini (you need to create this file using a text editor)
  
  Operating systems: Ubuntu (the instructions should work with any other Linux distributions suchasRHEL / CentOS / Fedoraorother Unix like operating systems suchasOpenBSD/FreeBSD/HP-UX)。

1. 减少PHP内置模块

  为了增强性能和安全性,强烈建议,减少PHP中的模块。来看看下面这个被执行命令安装的模块。

  # php –m你将会得到类似的结果:

  [PHP Modules] apc bcmath bz2 calendar Core ctype curl date dom ereg exif fileinfo filter ftp gd gettext gmp hash iconv imap json libxml mbstring memcache mysql mysqli openssl pcntl pcre PDO pdo_mysql pdo_sqlite Phar readline Reflection session shmop SimpleXML sockets SPL sqlite3 standard suhosin tokenizer wddx xml xmlreader xmlrpc xmlwriter xsl zip zlib [Zend Modules] Suhosin删除一个模块,并执行此命令。例如:删除模块sqlite3


?
1
# rm /etc/php.d/sqlite3.ini


  或者


?
1
# mv /etc/php.d/sqlite3.ini /etc/php.d/sqlite3.disableRestrict


2. 使PHP信息泄露最小化

  在默认PHP时在HTTP抬头处会生成一条线介于每个响应中,(比如X-Powered-By: PHP/5.2.10)。而这个在系统信息中为攻击者创建了一个非常有价值的信息。

  HTTP示例:

  HTTP/1.1 200 OK X-Powered-By: PHP/5.2.10 Content-type: text/html; charset=UTF-8 Vary: Accept-Encoding, COOKIE X-Vary-Options: Accept-Encoding;list-cOntains=gzip,COOKIE;string-cOntains=wikiToken; string-cOntains=wikiLoggedOut;string-cOntains=wiki_session Last-Modified: Thu, 03 Nov 2011 22:32:55 GMT……

  因此,我们强烈建议,禁止PHP信息泄露,想要要禁止它,我们要编辑/etc/php.d/secutity.ini,并设置以下指令:


?
1
expose_php=Off


3. 使PHP加载模块最小化

  在默认情况下,RHEL加载的所有模块可以在/etc/php.d/目录中找到。要禁用或启用一个特定的模块,只需要在配置文件/etc/php.d /目录中中注释下模块名称。而为了优化PHP性能和安全性,当你的应用程序需要时,我们强烈建议建议启用扩展功能。举个例子:当禁用GD扩展时,键入以下命令:

?
1
2
3
4
5
6
7
8
9
  # cd /etc/php.d/
  
  # mv gd.{ini,disable}
  
  # /etc/init.d/apache2 restart为了扩展PGP GD模块,然后键入以下命令:
  
  # mv gd.{disable,ini}
  
  # /sbin/service httpd restart

4. 记录PHP错误信息

  为了提高系统和Web应用程序的安全,PHP错误信息不能被暴露出。要做到这一点,需要编辑/etc/php.d/security.ini 文件,并设置以下指令:

?
1
2
3
4
5
  display_errors=Off为了便于开发者Bug修复,所有PHP的错误信息都应该记录在日志中。
  
  log_errors=On
  
  error_log=/var/log/httpd/php_scripts_error.log

5. 禁用远程执行代码

  如果远程执行代码,允许PHP代码从远程检索数据功能,如FTP或Web通过PHP来执行构建功能。比如:file_get_contents()。

  很多程序员使用这些功能,从远程通过FTP或是HTTP协议而获得数据。然而,此法在基于PHP应用程序中会造成一个很大的漏洞。由于大部分程序员在传递用户提供的数据时没有做到适当的过滤功能,打开安全漏洞并且创建了代码时注入了漏洞。要解决此问题,需要禁用_url_fopen in /etc/php.d/security.ini,并设置以下命令:

?
1
2
3
  allow_url_fopen=Off除了这个,我还建议禁用_url_include以提高系统的安全性。
  
  allow_url_include=Off
6. 禁用PHP中的危险函数

  PHP中有很多危险的内置功能,如果使用不当,它可能使你的系统崩溃。你可以创建一个PHP内置功能列表通过编辑/etc/php.d/security.ini来禁用它。


?
1
disable_functiOns=exec,passthru,shell_exec,system,proc_open,popen,curl_exec,curl_multi_exec,parse_ini_file,show_source


7. 资源控制

  为了提高系统的稳定性,强烈建议设置每个脚本解析请求数据所花费的时间和脚本可能消耗的最大内存量。正确的配置这些参数可以防止PHP任何脚本消耗太多的资源或是内存,从而避免系统不安全或降低安全系数。

?
1
2
3
4
5
6
7
  # set in seconds
  
  max_execution_time = 30
  
  max_input_time = 30
  
  memory_limit = 40M

8. 限制PHP访问文件系统

  该open_basedir指令指定的目录是允许PHP访问使用fopen()等功能。如果任何脚本试图访问超出open_basdir定义的路径文件,PHP将拒绝打开。值得注意的是,你不能使用一个符号链接作为一种变通方法。

?
1
2
3
  ; Limits the PHP process from accessing files outside; of specifically designated directories suchas/var/www/html/ open_basedir="/var/www/html/";
  
    ; Multiple dirs example; open_basedir="/home/httpd/vhost/cyberciti.biz/html/:/home/httpd/vhost /nixcraft.com/html/:/home/httpd/vhost/theos.in/html/";
9.限制文件/目录访问

  进行适当的安全设置:确保Apache作为非root用户运行,比如www-data或www.对于文件和目录在基于/var/www/下同样属于非root用户。想要更改所有者,执行以下命令:


?
1
#chown-R apache:apache /var/www/ 10.编译保护Apache,PHP和MySQL的配置文件


  使用charrt命令编译保护配置文件

?
1
2
3
4
5
6
7
8
9
10
11
12
13
  # chattr +i /etc/php.ini
  
  # chattr +i /etc/php.d/*
  
  # chattr +i /etc/my.ini
  
  # chattr +i /etc/httpd/conf/httpd.conf
  
  # chattr +i /etc/使用charrt命令可以编译保护PHP文件或者是文件中的/var/www/html的目录:
  
  # chattr +i /var/www/html/file1.php
  
  # chattr +i /var/www/html/


推荐阅读
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
  • 解决JAX-WS动态客户端工厂弃用问题并迁移到XFire
    在处理Java项目中的JAR包冲突时,我们遇到了JaxWsDynamicClientFactory被弃用的问题,并成功将其迁移到org.codehaus.xfire.client。本文详细介绍了这一过程及解决方案。 ... [详细]
  • 解决网站乱码问题的综合指南
    本文总结了导致网站乱码的常见原因,并提供了详细的解决方案,包括文件编码、HTML元标签设置、服务器响应头配置、数据库字符集调整以及PHP与MySQL交互时的编码处理。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 在哈佛大学商学院举行的Cyberposium大会上,专家们深入探讨了开源软件的崛起及其对企业市场的影响。会议指出,开源软件不仅为企业提供了新的增长机会,还促进了软件质量的提升和创新。 ... [详细]
  • 在Linux系统中配置并启动ActiveMQ
    本文详细介绍了如何在Linux环境中安装和配置ActiveMQ,包括端口开放及防火墙设置。通过本文,您可以掌握完整的ActiveMQ部署流程,确保其在网络环境中正常运行。 ... [详细]
  • 在Ubuntu 16.04 LTS上配置Qt Creator开发环境
    本文详细介绍了如何在Ubuntu 16.04 LTS系统中安装和配置Qt Creator,涵盖了从下载到安装的全过程,并提供了常见问题的解决方案。 ... [详细]
  • 在当前众多持久层框架中,MyBatis(前身为iBatis)凭借其轻量级、易用性和对SQL的直接支持,成为许多开发者的首选。本文将详细探讨MyBatis的核心概念、设计理念及其优势。 ... [详细]
  • PHP 5.5.0rc1 发布:深入解析 Zend OPcache
    2013年5月9日,PHP官方发布了PHP 5.5.0rc1和PHP 5.4.15正式版,这两个版本均支持64位环境。本文将详细介绍Zend OPcache的功能及其在Windows环境下的配置与测试。 ... [详细]
author-avatar
sweet佳楠名人博客
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有