Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Mari kita bincangkan tentang penghalaan PHP dan aplikasi pseudo-statik

Mari kita bincangkan tentang penghalaan PHP dan aplikasi pseudo-statik

WBOY
WBOYke hadapan
2023-01-03 15:01:014141semak imbas

Artikel ini membawa anda pengetahuan yang berkaitan tentang PHP, yang terutamanya memperkenalkan kandungan yang berkaitan tentang penghalaan dan aplikasi pseudo-statik merujuk kepada pengedaran baris, dan pseudo-statik adalah untuk menjadikan alamat URL dinamik kelihatan statik alamat di bawah semoga dapat membantu semua.

Mari kita bincangkan tentang penghalaan PHP dan aplikasi pseudo-statik

Laluan

Dijelaskan secara literal, jalan adalah garis, jalan oleh, sebab, maksud , mewakili peraturan; jadi ia bermakna di mana ia ditetapkan mengikut peraturan, atau makna.

Jadi penghalaan merujuk kepada pengedaran baris Dalam web bahagian belakang, ia secara amnya merujuk kepada peraturan pemetaan URL akses, seperti jenis akses URL, modul apa dan pengawal yang dipetakan. melalui peraturan penghalaan, Beberapa kaedah, atau kelas, atau penutupan, atau sesuatu yang lain, ringkasnya, ia memainkan peranan pengedaran.

Pseudo-statik

Pseudo-statik secara literal bermaksud palsu, statik.

(Tambahan: Pseudo-statik ialah untuk menjadikan alamat URL dinamik kelihatan seperti alamat statik. Pseudo-statik ialah matlamat utama, bukan teknologi. Terdapat banyak cara untuk mencapai pseudo -statik. Ini boleh dicapai dengan menggunakan penulisan semula URL bagi hos, atau dengan menggunakan konfigurasi penghalaan program itu sendiri Sebagai contoh, peraturan URL boleh dikonfigurasikan secara bebas dalam tp5 dan wordpress. manakala yang terakhir adalah lebih fleksibel tetapi memerlukan info laluan untuk menyembunyikan pintu masuk Atau sokongan penulisan semula url)

Dalam dunia web2.0, banyak halaman adalah dinamik, seperti banyak index.php/a/. ... atau index.php?a=1&... Dengan cara ini, alamat dinamik sedemikian tidak begitu menarik dan tidak mesra enjin carian Beberapa cara teknikal diperlukan untuk menyamarkan alamat URL dinamik ini kepada alamat URL statik. Ini adalah pseudo-statik.

Jadi pseudo-statik merujuk kepada penyelesaian yang menggunakan beberapa teknologi untuk menukar alamat dinamik kepada alamat statik dan boleh diakses seperti biasa.

Jadi mari kita lihat apa teknologi yang diperlukan untuk mencapai pseudo-statik:

  • modul tulis semula hos web (menulis semula URL, menulis semula diterjemahkan ke dalam bahasa Cina Untuk menulis semula, tetapi ramai orang juga sering memanggilnya pseudo-statik)

  • pathinfo (teknologi yang disokong oleh hos, index.php/path, dan kemudian gunakan semula Penulisan url boleh menyembunyikan pintu masuk)

  • peraturan program (boleh mencantikkan, memendekkan url, menjadi lebih berperikemanusiaan dan semantik)

Tambahan: Satu lagi perkara penting yang belum disebutkan ialah [Tambah akhiran]. setiap langkah di atas boleh dilakukan Dalam program, anda hanya perlu mengawal akhiran semasa menjana URL. Dan akhiran kadangkala berguna apabila mereka bentuk API Akhiran mesti mewakili format data yang dikembalikan (rujukan: gaya reka bentuk REST).

Analisis:

  • Penyelesaian pertama mempunyai kelebihan sebagai berkuasa (menggunakan peraturan modul penulisan semula untuk menyokong pemadanan biasa dan ciri lain ), Penulisan semula url sewenang-wenangnya boleh dicapai, tetapi kelemahannya ialah banyak peraturan penulisan semula url yang kompleks perlu dikonfigurasikan (program rebat Duoduo menggunakan kaedah ini untuk membuat pseudo-statik. Jika pseudo-statik dihidupkan, program akan menjana URL dengan peraturan pseudo-statik dan memerlukan hos Pada masa yang sama, konfigurasikan peraturan penulisan semula URL yang sepadan secara manual), anda perlu mempunyai kebenaran pengurusan hos Jika konfigurasi diubah suai pada hos, anda perlu memulakan semula pelayan web (menyokong .htaccess tidak memerlukan dimulakan semula).

  • Ini memerlukan sokongan hos web Hos yang menyokong PATHINFO boleh menyokong akses url seperti index.php/home/index/index, supaya nilai boleh diperolehi dalam. bahasa web (seperti PHP Program ini boleh mendapatkan $_SERVER['PATH_INFO'] = '/home/index/index' ). Menurut ciri ini, menggunakan penulisan semula URL, yang hanya memerlukan peraturan penulisan semula URL yang mudah untuk menulis semula semua parameter selepas fail masukan, supaya fail masukan boleh disembunyikan Sudah tentu, ini hanya menyembunyikan fail Kemasukan , dalam thinkphp, jika hos tidak menyokong PATHINFO (seperti versi nginx yang lebih rendah), maka menggunakan mod keserasian (?s=/m/c/a) juga boleh mensimulasikan pelaksanaan pathinfo untuk menyembunyikan indeks fail kemasukan .php

  • Boleh dikatakan bahawa ia adalah penulisan semula url dalam program (penulisan semula yang dinyatakan di atas ialah penulisan semula URL bagi hos). , jadi peraturan penghalaan juga sama dengan peraturan penulisan semula url hos. Kelebihannya ialah fungsi yang berkuasa dan konfigurasi peraturan yang fleksibel, kelemahannya ialah prestasi penghuraian (ini adalah satu-satunya kelemahan, yang lain adalah kelebihan). (URL tersuai WordPress sebenarnya adalah laluan tersuai)

Ringkasan:

一般主机都能开启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视频教程

Atas ialah kandungan terperinci Mari kita bincangkan tentang penghalaan PHP dan aplikasi pseudo-statik. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:juejin.im. Jika ada pelanggaran, sila hubungi admin@php.cn Padam