PHP环境设置

Web、Mail、Ftp、DNS、Proxy、VPN、Samba、LDAP 等基础网络服务
头像
firehare
帖子: 2625
注册时间: 2005-04-10 16:54
来自: 温州大学
联系:

PHP环境设置

#1

帖子 firehare » 2005-08-21 22:10

1.将系统更新到最新状态,在做任何操作之前都要做这一步,以确保系统的稳定,同时也不会有一些莫名其妙的现象出现。
$sudo apt-get update
$sudo apt-get dist-upgrade

2、安装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的包,所以为了避免不必要的麻烦,干脆还是单独指定比较好。

3、修改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
4、加固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

5、OK,打完收功!
上次由 firehare 在 2005-12-14 20:57,总共编辑 4 次。
我心无畏,源自于我心无知。
图片
头像
kopera
帖子: 52
注册时间: 2005-06-14 1:25
来自: 南华大学

#2

帖子 kopera » 2005-09-10 15:23

问一下,这里设置的上传附件大小是不是不受所选论坛源程序限制??
头像
firehare
帖子: 2625
注册时间: 2005-04-10 16:54
来自: 温州大学
联系:

#3

帖子 firehare » 2005-09-10 18:06

受的,其实这里设置的是最大允许多大的文件上传,而在具体的应用程序中如果设置的文件大小小于该设置,则以具体应用程序中的设置为准,如果大于该设置就是以该设置为准,一句话概括就是两个值相比较,以小的那个值为准!
我心无畏,源自于我心无知。
图片
头像
kopera
帖子: 52
注册时间: 2005-06-14 1:25
来自: 南华大学

#4

帖子 kopera » 2005-09-10 20:25


在这个论坛里上上传的附件可达5000M,
他是用phpbb的,你用过没有?在怎样改呢,我不太懂,
只是我在局域网里架了论坛!朋友都说在再大点
我用的是PhpBB2.15,也没怎 么去研究代码
RedHat玩的久了,突然Ubuntu的魅力……
我就选它了!
我Down、Dwon……
不去网上订,为Ubuntu尽一份力!
头像
firehare
帖子: 2625
注册时间: 2005-04-10 16:54
来自: 温州大学
联系:

#5

帖子 firehare » 2005-09-10 20:43

这个我也不是很清楚,应该会在PHPBB的管理面板中可以修改吧!
我心无畏,源自于我心无知。
图片
头像
kopera
帖子: 52
注册时间: 2005-06-14 1:25
来自: 南华大学

#6

帖子 kopera » 2005-09-10 20:47

还是的谢谢你!!
RedHat玩的久了,突然Ubuntu的魅力……
我就选它了!
我Down、Dwon……
不去网上订,为Ubuntu尽一份力!
头像
firehare
帖子: 2625
注册时间: 2005-04-10 16:54
来自: 温州大学
联系:

#7

帖子 firehare » 2005-09-10 20:59

客气了,论坛这地方本来就是大家帮大家的地方!
我心无畏,源自于我心无知。
图片
frankdu
帖子: 10
注册时间: 2005-09-16 0:12

#8

帖子 frankdu » 2005-09-16 0:16

php安装盘里带吗?还是它自动到网上下?
头像
firehare
帖子: 2625
注册时间: 2005-04-10 16:54
来自: 温州大学
联系:

#9

帖子 firehare » 2005-09-16 12:58

请用apt-get 下载就可以了!

如果兄弟用php5的话,请手动先下载libapache2-mod-php5这个包,php5包的依赖关系好象没做好,如果是自动安装依赖关系的话,可能会安装libapache-mod-php5包!
我心无畏,源自于我心无知。
图片
suave
帖子: 34
注册时间: 2005-09-05 12:09
来自: Peking
联系:

#10

帖子 suave » 2005-10-03 20:25

楼上firehare的提示很关键!

的确是依赖关系有问题,默认apt-get install php5以后apache2无法解析php,重新安装libapache2-mod-php5之后重启apache2,就可以正确解析php了。
rApJtR
帖子: 221
注册时间: 2005-08-01 20:35
来自: Hong Kong

#11

帖子 rApJtR » 2005-10-14 14:09

firehare
$sudo apt-get install apache2-mod-php5

源里没有 apache2-mod-php5 的请更正
rApJtR
帖子: 221
注册时间: 2005-08-01 20:35
来自: Hong Kong

#12

帖子 rApJtR » 2005-10-14 14:17

我重装了好多回 现在不能解析php了……
头像
firehare
帖子: 2625
注册时间: 2005-04-10 16:54
来自: 温州大学
联系:

#13

帖子 firehare » 2005-10-14 15:12

rApJtR 写了:firehare
$sudo apt-get install apache2-mod-php5

源里没有 apache2-mod-php5 的请更正

代码: 全选

netmaster@netsvr02:~$ sudo apt-cache search apache2-mod-php5
libapache2-mod-php5 - server-side, HTML-embedded scripting language (apache 2.0 module)
php5-cgi - server-side, HTML-embedded scripting language (CGI binary)
请参见我上面的结果,楼上兄弟的源可能有问题!
我心无畏,源自于我心无知。
图片
rApJtR
帖子: 221
注册时间: 2005-08-01 20:35
来自: Hong Kong

#14

帖子 rApJtR » 2005-10-14 19:31

代码: 全选

haro@ubuntu-rApJtR:~$ sudo apt-cache search apache2-mod-php5
libapache2-mod-php5 - server-side, HTML-embedded scripting language (apache 2.0 module)
php5-cgi - server-side, HTML-embedded scripting language (CGI binary)
haro@ubuntu-rApJtR:~$ sudo apt-get install apache2-mod-php5
正在读取软件包列表... 完成
正在分析软件包的依赖关系树... 完成
E: 无法找到软件包 apache2-mod-php5
头像
firehare
帖子: 2625
注册时间: 2005-04-10 16:54
来自: 温州大学
联系:

#15

帖子 firehare » 2005-10-14 19:41

我明白了,是我错了
是libapache2-mod-php5!
多谢兄弟!
我心无畏,源自于我心无知。
图片
回复