mirror of
https://github.com/yiisoft/yii.git
synced 2026-03-12 02:56:55 +01:00
89 lines
2.7 KiB
Plaintext
89 lines
2.7 KiB
Plaintext
Apache- und Nginx-Konfigurationen
|
|
=================================
|
|
|
|
Apache
|
|
------
|
|
|
|
Yii kann bereits mit einem standardmäßig konfigurierten Apache Webserver
|
|
betrieben werden. Die `.htaccess`-Dateien in Yii-Framework- und
|
|
Anwendungsverzeichnissen sperren den Zugriff auf vertrauliche Dateien. Um das
|
|
Starscript (normalerweise `index.php`) in URLs zu unterdrücken, kann man
|
|
`mod_rewrite`-Anweisungen in die `.htaccess`-Datei im Webverzeichnis oder in
|
|
die Virtual-Host-Konfiguration einfügen:
|
|
|
|
~~~
|
|
RewriteEngine on
|
|
|
|
# Existierende Verzeichnisse oder Dateien direkt ausliefern
|
|
RewriteCond %{REQUEST_FILENAME} !-f
|
|
RewriteCond %{REQUEST_FILENAME} !-d
|
|
# ansonsten zu index.php weiterleiten
|
|
RewriteRule . index.php
|
|
~~~
|
|
|
|
|
|
Nginx
|
|
-----
|
|
|
|
Man kann Yii auch mit [Nginx](http://wiki.nginx.org/) und PHP mit [FPM
|
|
SAPI](http://php.net/install.fpm) verwenden. Hier eine beispielhafte
|
|
Host-Konfiguration. Sie legt das Startscript fest und leitet alle Anfragen an
|
|
nicht existente Dateien an Yii um. Damit erhält man lesbare URLs.
|
|
|
|
~~~
|
|
server {
|
|
set $host_path "/www/mysite";
|
|
access_log /www/mysite/log/access.log main;
|
|
|
|
server_name mysite;
|
|
root $host_path/htdocs;
|
|
set $yii_bootstrap "index.php";
|
|
|
|
charset utf-8;
|
|
|
|
location / {
|
|
index index.html $yii_bootstrap;
|
|
try_files $uri $uri/ /$yii_bootstrap?$args;
|
|
}
|
|
|
|
location ~ ^/(protected|framework|themes/\w+/views) {
|
|
deny all;
|
|
}
|
|
|
|
# Vermeidet die verarbeitung von statischen, nicht existenten Dateien
|
|
location ~ \.(js|css|png|jpg|gif|swf|ico|pdf|mov|fla|zip|rar)$ {
|
|
try_files $uri =404;
|
|
}
|
|
|
|
# Leitet PHP Scripts an den FastCGI server unter 127.0.0.1:9000 weiter
|
|
#
|
|
location ~ \.php {
|
|
fastcgi_split_path_info ^(.+\.php)(.*)$;
|
|
|
|
# Yii soll Aufrufe von nicht existierenden PHP-Dateien abfangen
|
|
set $fsn /$yii_bootstrap;
|
|
if (-f $document_root$fastcgi_script_name){
|
|
set $fsn $fastcgi_script_name;
|
|
}
|
|
|
|
fastcgi_pass 127.0.0.1:9000;
|
|
include fastcgi_params;
|
|
fastcgi_param SCRIPT_FILENAME $document_root$fsn;
|
|
|
|
# PATH_INFO und PATH_TRANSLATED müssen nicht angegeben werden,
|
|
# sind aber in RFC 3875 für CGI definiert:
|
|
fastcgi_param PATH_INFO $fastcgi_path_info;
|
|
fastcgi_param PATH_TRANSLATED $document_root$fsn;
|
|
}
|
|
|
|
location ~ /\.ht {
|
|
deny all;
|
|
}
|
|
}
|
|
~~~
|
|
|
|
Mit dieser Konfiguration kann man dann in der `php.ini` `cgi.fix_pathinfo=0`
|
|
setzen, um unnötige `stat()`-Aufrufe des Systems zu vermeiden.
|
|
|
|
<div class="revision">$Id: quickstart.apache-nginx-config.txt 3512 2011-12-27 16:50:03Z haertl.mike $</div>
|