-
Notifications
You must be signed in to change notification settings - Fork 108
Expand file tree
/
Copy pathapache.xml
More file actions
56 lines (55 loc) · 2.73 KB
/
apache.xml
File metadata and controls
56 lines (55 loc) · 2.73 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
<?xml version="1.0" encoding="utf-8"?>
<!-- $Revision$ -->
<!-- $Author$ -->
<!-- EN-Revision: ab6785b01ce1006e3a9761988575289f40c9b678 Maintainer: lm92 Status: ready -->
<!-- CREDITS: dallas -->
<chapter xml:id="security.apache" xmlns="http://docbook.org/ns/docbook">
<title>以 Apache 模块安装时</title>
<simpara>
当 <acronym>PHP</acronym> 以 Apache 模块方式安装时,它将继承 Apache
用户(通常为“nobody”)的权限。这对安全和认证有一些影响。比如,如果用 <acronym>PHP</acronym>
来访问数据库,除非数据库有自己的访问控制,否则就要使“nobody”用户可以访问数据库。这意味着恶意的脚本在不用提供用户名和密码时就可能访问和修改数据库。一个
web Spider 也完全有可能偶然发现数据库的管理页面,并且删除所有的数据库。可以通过
Apache 认证来避免此问题,或者用 LDAP、.htaccess
等技术来设计自己的访问模型,并把这些代码作为 <acronym>PHP</acronym> 脚本的一部份。
</simpara>
<simpara>
通常,一旦安全性达到可以使 <acronym>PHP</acronym> 用户(这里也就是 Apache
用户)承担的风险极小的程度时候,可能 <acronym>PHP</acronym>
已经到了阻止向用户目录写入任何文件或禁止访问和修改数据库的地步了。这就是说,无论是正常的文件还是非正常的文件,无论是正常的数据库事务还是恶意的请求,都会被拒之门外。
</simpara>
<simpara>
一个常犯的对安全性不利的错误就是让 Apache 拥有 root 权限,或者通过其它途径赋予 Apache 更强大的功能。
</simpara>
<simpara>
把 Apache 用户的权限提升为 root
是极度危险的做法,而且可能会危及到整个系统的安全。所以除非是安全专家,否则决不要考虑使用
su,chroot 或者以 root 权限运行。
</simpara>
<simpara>
除此之外还有一些比较简单的解决方案。比如说可以使用
<link linkend="ini.open-basedir">open_basedir</link> 来限制哪些目录可以被
<acronym>PHP</acronym> 使用。也可以设置
Apache 的专属区域,从而把所有的 web 活动都限制到非用户和非系统文件之中。
</simpara>
</chapter>
<!-- Keep this comment at the end of the file
Local variables:
mode: sgml
sgml-omittag:t
sgml-shorttag:t
sgml-minimize-attributes:nil
sgml-always-quote-attributes:t
sgml-indent-step:1
sgml-indent-data:t
indent-tabs-mode:nil
sgml-parent-document:nil
sgml-default-dtd-file:"~/.phpdoc/manual.ced"
sgml-exposed-tags:nil
sgml-local-catalogs:nil
sgml-local-ecat-files:nil
End:
vim600: syn=xml fen fdm=syntax fdl=2 si
vim: et tw=78 syn=sgml
vi: ts=1 sw=1
-->