溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

deepin15.4配置nginx時(shí)出現(xiàn)主頁(yè)展現(xiàn),其他全部找不到的問(wèn)題

發(fā)布時(shí)間:2020-07-11 18:57:04 來(lái)源:網(wǎng)絡(luò) 閱讀:669 作者:wushan37 欄目:web開(kāi)發(fā)

在/etc/nginx/sites-enabled中編輯我的站點(diǎn)配置文件

從default文件復(fù)制一份重命名為www.example.com內(nèi)容如下:

##
# You should look at the following URL's in order to grasp a solid understanding
# of Nginx configuration files in order to fully unleash the power of Nginx.
# https://www.nginx.com/resources/wiki/start/
# https://www.nginx.com/resources/wiki/start/topics/tutorials/config_pitfalls/
# https://wiki.debian.org/Nginx/DirectoryStructure
#
# In most cases, administrators will remove this file from sites-enabled/ and
# leave it as reference inside of sites-available where it will continue to be
# updated by the nginx packaging team.
#
# This file will automatically load configuration files provided by other
# applications, such as Drupal or Wordpress. These applications will be made
# available underneath a path with that package name, such as /drupal8.
#
# Please see /usr/share/doc/nginx-doc/examples/ for more detailed examples.
##

# Default server configuration
#
server {
    listen 80 ;
    listen [::]:80;
     
    
    # SSL configuration
    #
    # listen 443 ssl default_server;
    # listen [::]:443 ssl default_server;
    #
    # Note: You should disable gzip for SSL traffic.
    # See: https://bugs.debian.org/773332
    #
    # Read up on ssl_ciphers to ensure a secure configuration.
    # See: https://bugs.debian.org/765782
    #
    # Self signed certs generated by the ssl-cert package
    # Don't use them in a production server!
    #
    # include snippets/snakeoil.conf;

    root /var/www/html/hdgf/public;#hdgf是我的項(xiàng)目文件夾名稱

    # Add index.php to the list if you are using PHP
    index index.php index.html index.htm index.nginx-debian.html;

    server_name www.example.com  example.com;

    location / {
        # First attempt to serve request as file, then
        # as directory, then fall back to displaying a 404.
        
        #try_files $uri $uri/ =404;
        
        if (!-e $request_filename) {  
            rewrite ^/index.php(.*)$ /index.php?s=$1 last;  
            rewrite ^(.*)$ /index.php?s=$1 last;  
            break;  
        } 
    }

    # pass PHP scripts to FastCGI server
    #
    #location ~ \.php$ {
    #    include snippets/fastcgi-php.conf;
    #
    #    # With php-fpm (or other unix sockets):
    #    fastcgi_pass unix:/var/run/php/php7.0-fpm.sock;
    #    # With php-cgi (or other tcp sockets):
    #    fastcgi_pass 127.0.0.1:9000;
    #}

    # deny access to .htaccess files, if Apache's document root
    # concurs with nginx's one
    #
    #location ~ /\.ht {
    #    deny all;
    #}

    location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|flv|ico)$ {  
        expires 30d;  
        access_log off;  
    }  
    location ~ .*\.(js|css)?$ {  
        expires 7d;  
        access_log off;  
    }  

    location ~ .php$ {
        try_files $uri =404; #增加
        fastcgi_split_path_info ^(.+.php)(/.+)$; #反注釋
        ## NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini
        #
        ## With php5-cgi alone:
        # fastcgi_pass 127.0.0.1:9000;
        ## With php5-fpm:
        fastcgi_pass unix:/var/run/php/php7.0-fpm.sock; #反注釋
        fastcgi_index index.php; #反注釋
        include fastcgi_params; #反注釋
    }
}


# Virtual Host configuration for example.com
#
# You can move that to a different file under sites-available/ and symlink that
# to sites-enabled/ to enable it.
#
#server {
#    listen 80;
#    listen [::]:80;
#
#    server_name example.com;
#
#    root /var/www/example.com;
#    index index.html;
#
#    location / {
#        try_files $uri $uri/ =404;
#    }
#}

因?yàn)閠hinkphp5中的偽靜態(tài),nginx找不到對(duì)應(yīng)的頁(yè)面,此時(shí)就會(huì)返回404,修改對(duì)404的處理,如下

#try_files $uri $uri/ =404;注釋此句,新增下面這段:

if (!-e $request_filename) {  
            rewrite ^/index.php(.*)$ /index.php?s=$1 last;  
            rewrite ^(.*)$ /index.php?s=$1 last;  
            break;  
}

然后重啟nginx

sudo /etc/init.d/nginx restart

這樣就可以訪問(wèn)其他頁(yè)面了,但404沒(méi)處理好,以后再說(shuō),暫時(shí)這樣處理。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI