PHP系统的安全配置初级

php中文网
发布: 2016-06-23 13:19:10
原创
1288人浏览过

php有很多的配置参数,可以直接访问系统和操作目录的。
比如system命令(该命令可以让php直接访问linux系统,做一些登录后的操作)在默认的php-fpm程序里,是默认关掉了的。
1.php-fpm的php.ini查看(默认的php目录)
切换到/usr/local/php/etc  目录下面,可以看到php的基本配置在该目录下
如果没有找到  可以用命令查找语句
find /usr/local/php  -name php.ini
会将对应的位置列出来
2.关闭掉正在运行的php-fpm(主要作用是重启php-fpm,解决一些崩溃bug)
 killall  php-fpm(关闭掉所有叫php-fpm的运行进程)
 如果要重新开始运行
 /usr/local/php/sbin/php-fpm(超级管理员命令)
 3.为了防止对面查看php版本
 expose_php=on (开启这个后,攻击者将无法查看php的版本信息)
 3.开启后  可以直接调用system(和system类似的包括exec命令,一个输出命令运行的结果,一个不输出运行的结果)
 system("pwd");  
 直接调用了linux的pwd命令。
 该命令默认情况是被禁止掉了的,在php.ini的
 disable_functions = 后面可以填写一大串的禁止使用函数,(多个禁用函数的时候,需要用逗号分割)比如
 禁止掉phpinfo() 函数,这样系统就无法查看phpinfo()的信息了。
 如果要用系统的命令,需要开放system命令(该命令不安全,但是在恰当的场合使用却能大幅度提升效率)
4.开启了一些不安全的指令,需要用一些配置来限制其访问目录权限
open_basedir= .:/home/www/
open_basedir 限定当前用户的访问目录 .代表当前目录 /home/www代表允许访问的所有目录  超过限定目录后,会直接报错
5.在正式的运行环境上,需要对php.ini的一些东西进行新配置(生效的作用范围仅仅是当前php脚本)
关闭错误显示  
error_reporting(e_all);
ini_set( 'display_errors', 'on' );

error_reporting(0);
ini_set( 'display_errors', 'off' );
6.当开启了safe_mode的时候 ini_set 也是没有用的
      ini_set('post_max_size','10m');
      ini_set('upload_max_filesize','8m');//文件上传最大  
需要在.htaccess进行配置(要求设置是 allowoverride all)
php_value upload_max_filesize 8m   
php_value post_max_size 10m
ps:在大型项目部署中,所有环境都是统一的,一般都是开启安全模式,这个时候是不允许单独改变php的某个配置参数(php的配置是运维部确定了配置,不允许程序员擅自改动运行环境,只能通过自己内部完成)要完成该功能就需要.htaccess 进行配置

琅琅配音
琅琅配音

全能AI配音神器

琅琅配音 208
查看详情 琅琅配音
PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号