始创于2000年 股票代码:831685
咨询热线:0371-60135900 注册有礼 登录
  • 挂牌上市企业
  • 60秒人工响应
  • 99.99%连通率
  • 7*24h人工
  • 故障100倍补偿
您的位置: 网站首页 > 帮助中心>文章内容

Ubuntu下PHP配置与安全加强

发布时间:  2012/8/5 13:32:40

 Ubuntu下安装PHP支持
  $sudo apt-get install libapache2-mod-php5
  $sudo apt-get install php5
  如果想支持图形就加php5-gd,如果想支持Mysql就加php5-mysql,这里之所以要单独列出libapache2-mod-php5,主要是由于php5的依赖关系没有做好,有可能会安装上libapache-mod-php5的包,所以为了避免不必要的麻烦,干脆还是单独指定比较好。
  修改PHP配置文件,以限制内存和文件最大上传尺寸
  我们编辑/etc/php5/apache2/php.ini文件,先做一般配置,在改动之前,请先将该配置文件做个备份。以便在出错的时候可以恢复。
  >memory_limit = 8M =>修改成你所需的内存大小
  >upload_max_filesize = 2M =>修改文件最大上传尺寸
  =============
  >extension=mysql.so 支持Mysql服务
  >extension=gd.so 支持gd函数
  =============
  其实在Ubuntu下,如果你安装了php5-mysql和php5-gd之后,会自动修改以上二行的,我们做的只不过是确认一下它们前面的注释符是否去掉。
  bobyang 写道:
  补充:
  1。目前大多数php的open source都是用php4写的,为了兼容以前的php版本,有时需要将register_long_arrays打开,否则$HTTP_GET_VARS和$HTTP_POST_VARS等变量将无法使用,会出现一些莫名其妙的问题。
  2。另外,在装完php5后最好确认一下/etc/apache2/mods-enabled/下是否有链接:
  php5.load -> /etc/apache2/mods-available/php5.load
  加固PHP,以增强安全性。
  注意,下面的安全性要因情况而定,所以我已经把它们的功能写清楚了,如果有问题的话,看看是否由于下面哪种限制条件所造成,可相应将其注释掉。
  下面我们开始加固php,我们再次编辑/etc/php5/apache2/php.ini文件,之所以没有一次改完,主要是为了给大家一个清晰的思路。
  >#打开安全模式,打开他的好处就是PHP文件只能访问所有者和PHP文件所有着一样的文件,即使在chroot环境下也无法访问jail中属主不一样的文件,类似于php shell这样的后门就没用武之地了哦,phpshell是很流行的php后门,他可以执行系统命令,就象他的名字一样,和 shell很接近。
  >safe_mode = On
  >#下面的设置就限制了fopen(), file()等函数可以操作的目录范围,避免了入侵者非法读取文件,一定要在/var/www后面加" /",否则/var/wwww下的文件也能被访问 。该选项会禁止任何不在/var/www/目录下的PHP文件运行,包括任何以软链接方式链到/var /www/目录下的程序,如PhpMyAdmin包,就在该选项设定后无法正常运行。
  >open_basedir = /var/www/
  >#禁止使用phpinfo和get_cfg_var函数,这样可以避免泄露服务信息,一般在在确认PHP能正常工作之后再使之关闭
  >disable_functions = phpinfo,get_cfg_var
  >#设置php程序错误日志
  >error_reporting = E_ALL
  >log_errors = On
  >error_log = /var/log/php_err.log
  >#如果php程序没有指明需要register_globals的话,最好把register_globals设置为Off,这样可以避免很多安全问题的。注意,如果你的程序是需要register_globals的话,可千万别关。Ubuntu默认是关闭的。
  >register_globals = Off
  >#禁止打开远程地址,记得最近出的php include的那个漏洞吗?就是在一个php程序中include了变量,那么入侵者就可以利用这个控制服务器在本地执行远程的一个php程序,例如phpshell,所以我们关闭这个。
  >allow_url_fopen = Off
  测试PHP5是否安装成功
  sudo gedit /var/www/testphp.php
  在里面写入然后在Firefox中打开:http://localhost/testphp.php
  应该能看到下面的画面,很长的,俺截了一下php5.png
  看完后把testphp.php删掉,可能会有安全风险
  安装MySqlsudo apt-get install mysql-server********************上面的命令极有可能出现问题,就是告诉你有部分依赖的问题,这时千万别听信别人的信口乱说,follow me,否则你很有可能重装系统,信不信走着试试一句话,更新源有问题系统-》系统管理-》软件源,选择主服务器,再次运行上面的命令,OK了吗?go on......注意设置mysql root账号。
  MySql初始只允许本机(127.0.0.1)连接,如果想多台机子使用或者向Internet开放的话,
  编辑/etc/mysql/my.cnfsudo gedit /etc/mysql/my.cnf
  找到bind-address = 127.0.0.1
  用#注释掉,象这样#bind-address = 127.0.0.1
  MySql默认没有设置root密码,本机的root用户也没有密码,有风险是吧,这样
  mysqladmin -u root password your-new-password
  mysqladmin -h root@local-machine-name -u root -p password your-new-password(这里我怎么也连接不上mysql服务器,最后在mysql-admin里面改的)
  sudo /etc/init.d/mysql restart
  安装MYSQL Administrator
  sudo apt-get install mysql-admin
  安装好后在Gnome-应用程序-系统工具-MySQL Administrator这里俺遇到了一个问题,就是运行MySQL Administrator后,点击User Administrator后,整个MySQL Administrator挂死,最后还是解决了,方法见后面
  安装MYSQL for Apache HTTP Server
  sudo apt-get install libapache2-mod-auth-mysql
  sudo apt-get install php5-mysql
  sudo apt-get install phpmyadmin
  要让PHP与MySql一起工作,编辑
  sudo gedit /etc/php5/apache2/php.ini
  取消对;extension=mysql.so的注释,象这样
  …
  extension=mysql.so
  …
  保存文件,然后
  sudo /etc/init.d/apache2 restart
  测试:http://localhost/phpmyadmin 这里俺能修改用户,新增用户等

亿恩科技地址(ADD):郑州市黄河路129号天一大厦608室 邮编(ZIP):450008 传真(FAX):0371-60123888
   联系:亿恩小凡
   QQ:89317007
   电话:0371-63322206


本文出自:亿恩科技【www.enkj.com】

服务器租用/服务器托管中国五强!虚拟主机域名注册顶级提供商!15年品质保障!--亿恩科技[ENKJ.COM]

  • 您可能在找
  • 亿恩北京公司:
  • 经营性ICP/ISP证:京B2-20150015
  • 亿恩郑州公司:
  • 经营性ICP/ISP/IDC证:豫B1.B2-20060070
  • 亿恩南昌公司:
  • 经营性ICP/ISP证:赣B2-20080012
  • 服务器/云主机 24小时售后服务电话:0371-60135900
  • 虚拟主机/智能建站 24小时售后服务电话:0371-60135900
  • 专注服务器托管17年
    扫扫关注-微信公众号
    0371-60135900
    Copyright© 1999-2019 ENKJ All Rights Reserved 亿恩科技 版权所有  地址:郑州市高新区翠竹街1号总部企业基地亿恩大厦  法律顾问:河南亚太人律师事务所郝建锋、杜慧月律师   京公网安备41019702002023号
      0
     
     
     
     

    0371-60135900
    7*24小时客服服务热线