-
Notifications
You must be signed in to change notification settings - Fork 538
/
mirroring-troubles.php
113 lines (100 loc) · 3.88 KB
/
mirroring-troubles.php
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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
<?php
$_SERVER['BASE_PAGE'] = 'mirroring-troubles.php';
include_once __DIR__ . '/include/prepend.inc';
$SIDEBAR_DATA = '
<h3>Other mirror information</h3>
<p>
See also the instructions for <a href="/mirroring.php">setting up a mirror</a>.
</p>
';
site_header("The PHP mirrors problem and troubleshooting guide", ["current" => "help"]);
?>
<h1>Common troubles that mirrors of PHP.net face</h1>
<p>
Mirroring the PHP.net website requires a few specific settings and
considerations, and this document provides a list of problems with possible
solutions. The [<strong>?</strong>] link within each title may be used to
test this mirror.
</p>
<a name="multiviews"></a>
<h3>MultiViews are on [<a href="/functions">?</a>]</h3>
<p>
Because the 'Options' directive may be ignored in VirtualHost, a
solution is to move the MultiViews option into a specific
directory and disable it from there. For example:
</p>
<pre class="info">
<VirtualHost *:80>
<Directory /path/to/phpweb>
Options -Indexes -MultiViews
</Directory>
DocumentRoot /path/to/phpweb
ServerName ....
....
</VirtualHost>
</pre>
<p>
The <a href="mirroring.php#settings">mirror settings</a> example also
demonstrates this use. See also the Apache documentation that describes
<a href="http://httpd.apache.org/docs/content-negotiation.html">
Content Negotiation</a>.
</p>
<a name="content-type"></a>
<h3>Improper Content-Type [<a href="/manual/en/faq.html.php">?</a>]</h3>
<p>
Some pages are returning incorrect <code>Content-Type</code> headers. For example,
xx.php.net/manual/en/faq.html.php should be returning <code>text/html</code>
instead of <code>application/x-httpd-php</code>. See also the Apache
documentation describing
<a href="http://httpd.apache.org/docs/content-negotiation.html">Content
Negotiation</a>. This problem might be specific to
<a href="http://apache.lexa.ru/">Russian Apache</a>.
</p>
<a name="manual-redirect"></a>
<h3>Manual redirects [<a href="/manual/">?</a>]</h3>
<p>
By default, Apache inserts an alias for <code>/manual/</code> in the configuration
and this causes problems for mirrors. So for example if you find that
the manuals are listed on the documentation page but all of the links
open up a search page, you probably suffer from this problem and must
remove that alias.
</p>
<a name="shortcuts"></a>
<h3>Broken manual shortcuts [<a href="/echo">?</a>]</h3>
<p>
If the shortcut features [e.g. xx.php.net/echo] are not working, be sure
the manual files are really under <code>DOCUMENT_ROOT</code> and that the English
manual files are present. Also make sure that you have a correct
ErrorDocument setting.
</p>
<a name="invalid-data"></a>
<h3>Invalid data types [<a href="/testing">?</a>]</h3>
<p>
Invalid data is being received, and this is probably caused by improper error
handler settings. See the <a href="mirroring.php">mirror guidelines</a>
for how to setup the ErrorDocument.
</p>
<a name="var"></a>
<h3>A misguided var handler [<a href="/manual/en/ref.var.php">?</a>]</h3>
<p>
The <a href="mirroring.php">mirroring guidelines</a> mention that Apache2
enables a 'var' handler by default and this may be disabled by using
<code>RemoveHandler var</code> in the configuration file.
</p>
<a name="msi"></a>
<h3>Mishandling of .msi files</h3>
<p>
When improperly set, users are not given a "download this file" prompt
when attempting to download the PHP Installer (a .msi file). Your web
server configuration should be adjusted to force .msi files as
'application/octet-stream'. In Apache this may be done by using:
<code>AddType application/octet-stream .msi</code>
</p>
<a name="outbound"></a>
<h3>Unable to do external searches [<a href="results.php?q=curl&p=manual&l=en">?</a>]</h3>
<p>
Several searches require outbound connections to www.php.net, so this is
a test for that. The www.php.net box then connects to a third-party search engine.
</p>
<?php
site_footer();