Heim >Backend-Entwicklung >PHP-Tutorial >Lassen Sie uns über PHP-Routing und pseudostatische Anwendungen sprechen

Lassen Sie uns über PHP-Routing und pseudostatische Anwendungen sprechen

WBOY
WBOYnach vorne
2023-01-03 15:01:014177Durchsuche

Dieser Artikel vermittelt Ihnen relevantes Wissen über PHP und stellt hauptsächlich den relevanten Inhalt zu Routing und pseudostatischen Anwendungen vor. Routing bezieht sich auf die Leitungsverteilung, und pseudostatisch besteht darin, dynamische URL-Adressen wie statische Adressen aussehen zu lassen Wenn ich es zusammenstelle, hoffe ich, dass es für alle hilfreich sein wird.

Lassen Sie uns über PHP-Routing und pseudostatische Anwendungen sprechen

Route

Straße ist im wahrsten Sinne des Wortes eine Linie, eine Straße, die nach Regeln oder Bedeutungen weist.

Routing bezieht sich also auf die Zeilenverteilung. Im Back-End-Web bezieht es sich im Allgemeinen auf die Zuordnungsregeln für den Zugriff auf URLs, z. B. welche Art von URL-Zugriff, welches Modul, welcher Controller, welche Methode oder Klasse zugeordnet werden durch die Routing-Regeln, oder es ist ein Abschluss, oder etwas anderes, kurz gesagt, es spielt die Rolle der Verteilung.

Pseudostatisch

Pseudostatisch bedeutet wörtlich falsch, statisch.

(Ergänzung: Pseudostatisch soll die dynamische URL-Adresse wie eine statische Adresse aussehen lassen. Pseudostatisch ist das ultimative Ziel, nicht die Technologie. Es gibt viele Möglichkeiten, Pseudostatizität zu erreichen. Dies kann durch erreicht werden Verwenden der URL-Umschreibung des Hosts Dies kann auch durch die Verwendung der Routing-Konfiguration des Programms selbst erreicht werden. Beispielsweise können URL-Regeln in tp5 und WordPress frei konfiguriert werden. Ersteres erfordert die Berechtigung zum Verwalten des Hosts, während letzteres flexibler ist. aber es erfordert Pathinfo- oder URL-Rewriting-Unterstützung, um den Eingang zu verbergen)

In der Welt von Web 2.0 sind viele Seiten dynamisch, wie zum Beispiel viele index.php/a/... oder index.php?a=1&. .. Solche dynamischen Adressen sehen nicht sehr gut aus und sind schädlich für Suchmaschinen. Sie müssen einige technische Mittel verwenden, um diese dynamischen URL-Adressen in statische URL-Adressen zu verwandeln, die pseudostatisch sind.

Pseudostatisch bezieht sich also auf eine Lösung, die einige Technologien verwendet, um dynamische Adressen in statische Adressen umzuwandeln, auf die wie gewohnt zugegriffen werden kann. Es bezieht sich nicht auf eine bestimmte Technologie.

Werfen wir also einen Blick darauf, welche Technologien erforderlich sind, um Pseudostatik zu erreichen:

  • Webhost-Rewrite-Modul (URL-Rewriting, Rewrite wird ins Chinesische als Rewriting übersetzt, aber viele Leute nennen es auch oft pseudostatisch )

  • pathinfo (eine vom Host unterstützte Technologie, index.php/path, und dann URL-Umschreiben verwenden, um den Eingang zu verbergen)

  • Routing des Programms (kann die URL verschönern, verkürzen, humaner und semantischer werden)

Zusätzlich: Ein weiterer sehr wichtiger Punkt, der nicht erwähnt wurde, ist [Suffix hinzufügen], daher ist es nicht in der obigen Technologieliste aufgeführt kann in jedem Schritt oben verwendet werden. Im Programm müssen Sie lediglich das Suffix beim Generieren der URL steuern. Und Suffixe sind manchmal beim Entwerfen von APIs nützlich. Das Suffix muss das zurückgegebene Datenformat darstellen (Referenz: REST-Designstil).

Analyse:

  • Der Vorteil der ersten Lösung besteht darin, dass sie leistungsstark ist (unter Verwendung der Regeln des Rewrite-Moduls zur Unterstützung des regulären Abgleichs und anderer Funktionen) und ein beliebiges Umschreiben von URLs erreichen kann Zum Schreiben von Regeln müssen viele komplexe URL-Umschreibungen konfiguriert werden (das Duoduo-Rabattprogramm verwendet diese Methode, um pseudostatisch zu sein). Wenn pseudostatisch aktiviert ist, generiert das Programm URLs für pseudostatische Regeln und der Host muss diese manuell konfigurieren Wenn Sie gleichzeitig die entsprechenden URL-Rewriting-Regeln ausführen, benötigen Sie Host-Verwaltungsberechtigungen. Wenn die Konfiguration auf dem Host geändert wird, müssen Sie den Webserver neu starten (wenn er .htaccess unterstützt, ist kein Neustart erforderlich).

  • Dies erfordert die Unterstützung des Webhosts. Der Host, der PATHINFO unterstützt, kann URL-Zugriff wie index.php/home/index/index unterstützen, sodass der Wert in der Websprache abgerufen werden kann (z. B PHP-Programm erhalten kann $_SERVER['PATH_INFO'] = '/home/index/index' ). Gemäß dieser Funktion ist für die Verwendung der URL-Umschreibung nur eine einfache URL-Umschreibungsregel erforderlich, um alle Parameter nach der Eintragsdatei neu zu schreiben, sodass die Eintragsdatei in thinkphp nur ausgeblendet werden kann Der Host unterstützt PATHINFO nicht (z. B. eine niedrige Version von Nginx). Mithilfe des Kompatibilitätsmodus (?s=/m/c/a) kann auch die Implementierung von Pathinfo simuliert werden, um die Eintragsdatei index.php auszublenden

  • Man kann sagen, dass es sich um ein Programm handelt. Das darin enthaltene URL-Umschreiben (das oben erwähnte Umschreiben ist das URL-Umschreiben des Hosts) wurde unter Bezugnahme auf das URL-Umschreiben des Hosts entwickelt, sodass die Routing-Regeln den Regeln zum Umschreiben der Host-URL ähneln. Die Vorteile sind leistungsstarke Funktionen und eine flexible Regelkonfiguration; der Nachteil ist die Leistung des Parsens (dies ist der einzige Nachteil, die anderen sind Vorteile). (Die benutzerdefinierte WordPress-URL verwendet tatsächlich benutzerdefiniertes Routing)
Zusammenfassung:

一般主机都能开启rewrite模块/功能支持URL重写,这很关键,这样实现隐藏入口文件了,这是第一步,再利用pathinfo(或者兼容模式),还有程序的路由,这样配合起来就能够实现简洁明了的URL地址了,也就是实现我们所说的伪静态。

扩展知识

原始的 index.php?m=home&c=index&a=index 实在是太难看了,所以即使不全伪静态,不用路由,也最好抛弃这种原始的地址,因为有些接口开发中已经不支持使用这类url地址了,所以务必使用 pathinfo 的形式:index.php/home/index/index,在隐藏入口,再加个后缀 home/index/index.html 就完美了,如果是做API或者有特殊用途的话还可以带上特定的后缀,比如看云、github仓库克隆时代.git后缀的仓库地址。

其实如果你的入口是index.php,使用兼容模式也可以隐藏入口的,直接?s=/m/c/a,?m=home&c=index&a=index 因为大多主机默认配置的有默认访问文件/入口。

下面分析nginx的部分配置:

主配置:/usr/local/nginx/conf/nginx.conf

user www www;worker_processes auto;error_log /data/wwwlogs/error_nginx.log crit;pid /var/run/nginx.pid;worker_rlimit_nofile 51200;events {
    use epoll;
    worker_connections 51200;
    multi_accept on;
    }

http {
    include mime.types;
    default_type application/octet-stream;
    server_names_hash_bucket_size 128;
    client_header_buffer_size 32k;
    large_client_header_buffers 4 32k;
    client_max_body_size 1024m;
    sendfile on;
    tcp_nopush on;
    keepalive_timeout 120;
    server_tokens off;
    tcp_nodelay on;

    fastcgi_connect_timeout 300;
    fastcgi_send_timeout 300;
    fastcgi_read_timeout 300;
    fastcgi_buffer_size 64k;
    fastcgi_buffers 4 64k;
    fastcgi_busy_buffers_size 128k;
    fastcgi_temp_file_write_size 128k;

    #Gzip Compression
    gzip on;
    gzip_buffers 16 8k;
    gzip_comp_level 6;
    gzip_http_version 1.1;
    gzip_min_length 256;
    gzip_proxied any;
    gzip_vary on;
    gzip_types
        text/xml application/xml application/atom+xml application/rss+xml application/xhtml+xml image/svg+xml
        text/javascript application/javascript application/x-javascript
        text/x-json application/json application/x-web-app-manifest+json
        text/css text/plain text/x-component
        font/opentype application/x-font-ttf application/vnd.ms-fontobject
        image/x-icon;
    gzip_disable "MSIE [1-6].(?!.*SV1)";

    #If you have a lot of static files to serve through Nginx then caching of the files' metadata (not the actual files' contents) can save some latency.
    open_file_cache max=1000 inactive=20s;
    open_file_cache_valid 30s;
    open_file_cache_min_uses 2;
    open_file_cache_errors on;######################## default ############################
    server {
    listen 80;
    server_name _;
    access_log /data/wwwlogs/access_nginx.log combined;
    root /data/wwwroot/default;
    index index.html index.htm index.php;
    location /nginx_status {
        stub_status on;
        access_log off;
        allow 127.0.0.1;
        deny all;
        }
    location ~ [^/].php(/|$) {        #fastcgi_pass remote_php_ip:9000;
        fastcgi_pass unix:/dev/shm/php-cgi.sock;
        fastcgi_index index.php;
        include fastcgi.conf;
        }
    location ~ .*.(gif|jpg|jpeg|png|bmp|swf|flv|ico)$ {
        expires 30d;
        access_log off;
        }
    location ~ .*.(js|css)?$ {
        expires 7d;
        access_log off;
        }
    }########################## vhost #############################
    include vhost/*.conf;}

每一个虚拟主机在虚拟主机配置目录都有一个对应的配置文件

[root@iZuf6fvttmu9vkdbnencgpZ vhost]# lsdingtalk.uogo8.com.conf  lipin.uogo8.com.conf  tv.uogo8.com.conf
gj.uogo8.com.conf        test.uogo8.com.conf   www.uogo8.com.conf

虚拟主机配置文件:/usr/local/nginx/conf/vhost/www.uogo8.com.conf

server {
listen 80;
server_name www.uogo8.com uogo8.com;
access_log /data/wwwlogs/www.uogo8.com_nginx.log combined;
index index.html index.htm index.php;
include /usr/local/nginx/conf/rewrite/www.uogo8.com.conf;
root /data/wwwroot/www.uogo8.com;if ($host != www.uogo8.com) {
    rewrite ^/(.*)$ $scheme://www.uogo8.com/$1 permanent;
    }

location ~ .php {    #fastcgi_pass remote_php_ip:9000;
    fastcgi_pass unix:/dev/shm/php-cgi.sock;
    fastcgi_index index.php;
    include fastcgi_params;    set $real_script_name $fastcgi_script_name;        if ($fastcgi_script_name ~ "^(.+?.php)(/.+)$") {        set $real_script_name $1;        #set $path_info $2;
        }
    fastcgi_param SCRIPT_FILENAME $document_root$real_script_name;
    fastcgi_param SCRIPT_NAME $real_script_name;    #fastcgi_param PATH_INFO $path_info;
    }
location ~ .*.(gif|jpg|jpeg|png|bmp|swf|flv|ico)$ {
    expires 30d;
    access_log off;
    }
location ~ .*.(js|css)?$ {
    expires 7d;
    access_log off;
    }
}

伪静态单独放一个目录,需要时被虚拟主机配置文件引入,这样方便管理

[root@iZuf6fvttmu9vkdbnencgpZ vhost]# cd ../rewrite/[root@iZuf6fvttmu9vkdbnencgpZ rewrite]# lsnone.conf  thinkphp.conf  www.uogo8.com.conf

伪静态是一种效果,准确的说这是主机的URL重写规则/配置文件。但一般大家也习惯性称之为伪静态配置、伪静态文件,开启伪静态,伪静态模块,伪静态功能了,其实伪静态只是最终实现的效果。

thinkphp程序的伪静态配置文件:/usr/local/nginx/conf/rewrite/thinkphp.conf

location / {
    if (!-e $request_filename) {        # 不支持pathinfo,那就使用url重写,重写成兼容模式,来达到隐藏入口的效果
        rewrite ^(.*)$ /index.php?s=$1 last;
        break;
    }
}

thinkphp伪静态配置文件.htaccess(Apache环境)

<IfModule mod_rewrite.c>
  Options +FollowSymlinks -Multiviews
  RewriteEngine On

  RewriteCond %{REQUEST_FILENAME} !-d
  RewriteCond %{REQUEST_FILENAME} !-f  # 直接利用url重写,重写成 pathinfo 模式
  RewriteRule ^(.*)$ index.php/$1 [QSA,PT,L]
</IfModule>

uogo8的伪静态配置文件:/usr/local/nginx/conf/rewrite/www.uogo8.com.conf

location / {    if (!-e $request_filename) {
        rewrite  ^/(.*)$  /index.php/$1  last;        break;
    }
}
########################################################################       OneinStack for CentOS/RadHat 5+ Debian 6+ and Ubuntu 12+      ##       For more information please visit https://oneinstack.com      ########################################################################Your domain:                  www.uogo8.com
Virtualhost conf:             /usr/local/nginx/conf/vhost/www.uogo8.com.conf
Directory of:                 /data/wwwroot/www.uogo8.com
Rewrite rule:                 /usr/local/nginx/conf/rewrite/thinkphp.conf

推荐学习:《PHP视频教程

Das obige ist der detaillierte Inhalt vonLassen Sie uns über PHP-Routing und pseudostatische Anwendungen sprechen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:juejin.im. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen