web-dev-qa-db-ja.com

シンボリックリンクとLAMPPhtdocs

Symlinkディレクトリをlampphtdocsの外部で使用するために、これらの手順を実行しました。

$ mkdir test
$ chmod 777 test
//test is now in /home/Dropbox/test/
//I put an index.html with 777 perms in it.
$ cd /opt/lampp/htdocs/
$ Sudo ln -s /home/Dropbox/test/ /opt/lampp/htdocs/$USER
//my user appears as symlink directory in htdocs.
$ /opt/lampp/lampp stop
$ /opt/lampp/lampp start
//lampp is now restarted

Localhost/myusernameと入力すると、404エラーが発生します...オブジェクトが見つかりません。

Htdocsディレクトリに通常のディレクトリと.html/.phpファイルを作成できますが、シンボリックリンクディレクトリまたは.html /.phpファイルを作成できません。これらは読み込まれません。

ご入力ありがとうございます!

httpd conf(SymLinksに関連する部分のみ)

<Directory />
    Options FollowSymLinks
    AllowOverride None
    #XAMPP
    #Order deny,allow
    #Deny from all
</Directory>

<Directory "/opt/lampp/htdocs/">
    #
    # Possible values for the Options directive are "None", "All",
    # or any combination of:
    #   Indexes Includes FollowSymLinks SymLinksifOwnerMatch ExecCGI MultiViews
    #
    # Note that "MultiViews" must be named *explicitly* --- "Options All"
    # doesn't give it to you.
    #
    # The Options directive is both complicated and important.  Please see
    # http://httpd.Apache.org/docs/2.2/mod/core.html#options
    # for more information.
    #
    #Options Indexes FollowSymLinks
    # XAMPP
    Options Indexes FollowSymLinks ExecCGI Includes


    #
    # AllowOverride controls what directives may be placed in .htaccess files.
    # It can be "All", "None", or any combination of the keywords:
    #   Options FileInfo AuthConfig Limit
    #
    #AllowOverride None
    # since XAMPP 1.4:
    AllowOverride All


    #
    # Controls who can get stuff from this server.
    #
    Order allow,deny
    Allow from all

</Directory>



エラーログ

$ tail -f error_log 
[Fri Dec 23 13:55:50 2011] [error] [client 127.0.0.1] Symbolic link not allowed or link target not accessible: /opt/lampp/htdocs/*myusername*
[Fri Dec 23 13:56:02 2011] [notice] caught SIGTERM, shutting down
[Fri Dec 23 13:56:08 2011] [notice] suEXEC mechanism enabled (wrapper: /opt/lampp/bin/suexec)
[Fri Dec 23 13:56:08 2011] [warn] RSA server certificate is a CA certificate (BasicConstraints: CA == TRUE !?)
[Fri Dec 23 13:56:08 2011] [warn] RSA server certificate CommonName (CN) `localhost' does NOT match server name!?
[Fri Dec 23 13:56:08 2011] [notice] Digest: generating secret for digest authentication ...
[Fri Dec 23 13:56:08 2011] [notice] Digest: done
[Fri Dec 23 13:56:09 2011] [warn] RSA server certificate is a CA certificate (BasicConstraints: CA == TRUE !?)
[Fri Dec 23 13:56:09 2011] [warn] RSA server certificate CommonName (CN) `localhost' does NOT match server name!?
[Fri Dec 23 13:56:09 2011] [notice] Apache/2.2.21 (Unix) DAV/2 mod_ssl/2.2.21 OpenSSL/1.0.0c PHP/5.3.8 mod_apreq2-20090110/2.7.1 mod_Perl/2.0.5 Perl/v5.10.1 configured -- resuming normal operations



access_log

$ tail -f access_log 
127.0.0.1 - - [23/Dec/2011:13:41:27 -0500] "GET /work HTTP/1.1" 403 1111
127.0.0.1 - - [23/Dec/2011:13:41:27 -0500] "GET /work HTTP/1.1" 403 1111
127.0.0.1 - - [23/Dec/2011:13:41:28 -0500] "GET /work HTTP/1.1" 403 1111
127.0.0.1 - - [23/Dec/2011:13:55:47 -0500] "GET / HTTP/1.1" 302 -
127.0.0.1 - - [23/Dec/2011:13:55:47 -0500] "GET /xampp/ HTTP/1.1" 200 588
127.0.0.1 - - [23/Dec/2011:13:55:47 -0500] "GET /xampp/head.php HTTP/1.1" 200 1362
127.0.0.1 - - [23/Dec/2011:13:55:47 -0500] "GET /xampp/navi.php HTTP/1.1" 200 2290
127.0.0.1 - - [23/Dec/2011:13:55:47 -0500] "GET /xampp/start.php HTTP/1.1" 200 786
127.0.0.1 - - [23/Dec/2011:13:55:47 -0500] "GET /favicon.ico HTTP/1.1" 200 30894
127.0.0.1 - - [23/Dec/2011:13:55:50 -0500] "GET /work HTTP/1.1" 403 1111



/ opt/lampp/htdocs /の権限

drwxr-xr-x 4 nobody root 4096 2011-12-23 13:32 htdocs



/ opt/lampp/htdocs/* myusername *の権限

lrwxrwxrwx1ルートルート392011-12-23 13:12 myusername



/ home/Dropbox/test /の権限

drwxr-xr-x 2 work work 4096 2011-12-23 13:10 myusername

3
user1062058

これは、FollowSymLinksがスタンザ内に存在しないことを示唆します。これは ここ から取られた例です:

<Directory /usr/local/httpd/htdocs>
Options Indexes FollowSymLinks
</Directory>

Apache構成の検証が保留されているため(貼り付ける必要があると思います)、これが最も可能性の高い答えです。

編集:emboboへの応答を読んだ後、私は行ってサーバーで問題を再現しました:

[Fri Dec 23 23:03:58 2011] [error] [client 192.168.15.20] Symbolic link not allowed or link target not accessible: /var/www/html/testsym

テストの親で次の設定をお勧めします

chmod go+x /home/Dropbox

Dropboxディレクトリがグループやその他の実行権限を持つことができるようにします。

3
Rilindo

そのパッケージのデフォルト設定についてはよくわかりませんが、通常、セキュリティ上の理由から、Apacheではシンボリックリンクのフォローがデフォルトで無効になっています。

シンボリックリンクが存在する場所に適用されるコンテキストで、これを構成に追加します。

Options +FollowSymLinks
2
Shane Madden