Magento Wordpress Nginx Configuration



我在 http://example.com 有一家Magento商店,我想在 http://example.com/blog 保留一个Wordpress博客。我已经安装了博客,一切似乎都很好,但是当我登录到Wp-Admin时,由于仪表板看起来非常丑陋,css和js文件得到了404。我做错了吗?正在附加我的 nginx 配置文件

##################################################################################
#
#                       example.com
#
##################################################################################
server {
    listen       80;
    server_name  example.com ;
    #charset koi8-r;
        #access_log  /var/log/nginx/access.log;
        error_log  /var/log/nginx/error.log;
    location / {
        root   /usr/share/nginx/html/mebozo-magento.mebozo.com;
        try_files $uri $uri/ @handler; ## If missing pass the URI to Magento's front handler
        index  index.php index.html index.htm;
    }
        location /blog {
        root   /usr/share/nginx/html/mebozo-magento.mebozo.com/blog;
        try_files $uri $uri/ /blog/index.php;
        index  index.php index.html index.htm;
        rewrite ^.*/files/(.*) /wp-includes/ms-files.php?file=$2;
        rewrite ^.*/wp-admin(.*) $1wp-admin/;

    }
    location ~* ^.+.(html|jpg|jpeg|gif|png|ico|css|zip|tgz|gz|rar|bz2|doc|xls|exe|pdf|ppt|txt|tar|mid|midi|wav|bmp|rtf|js)$
        {
        root  /usr/share/nginx/html/mebozo-magento.mebozo.com/blog;
        rewrite ^/.*(/.*.(html|jpg|jpeg|gif|png|ico|css|zip|tgz|gz|rar|bz2|doc|xls|exe|pdf|ppt|txt|tar|mid|midi|wav|bmp|rtf|js))$ $1 last;
        rewrite ^.*/files/(/.*(html|jpg|jpeg|gif|png|ico|css|zip|tgz|gz|rar|bz2|doc|xls|exe|pdf|ppt|txt|tar|mid|midi|wav|bmp|rtf|js))$/wp-includes/ms-files.php?file=$1 last;
        expires 30d;
        break;
        }
## These locations would be hidden by .htaccess normally
#location ~* .(js|css|png|jpg|jpeg|gif|ico)$ {
#expires 1y;
#log_not_found off;
#}
        location ~ .php/ { 
        ## Forward paths like /js/index.php/x.js to relevant handler
        rewrite ^(.*.php)/ $1 last;
    }
################For Foomen Speedster###############
#rewrite ^/minify/([0-9]+)(/.*.(js|css))$ /lib/minify/m.php?f=$2&d=$1 last;
#    rewrite ^/skin/m/([0-9]+)(/.*.(js|css))$ /lib/minify/m.php?f=$2&d=$1 last;
#    location /lib/minify/ {
#        allow all;
#    }

error_page  404              /404.html;
    location = /404.html {
        root   /usr/share/nginx/html;
    }
#############gzip###########
        gzip on; # use gzip compression
        gzip_min_length 1100;
        gzip_buffers 4 8k; 
        gzip_proxied any; # enable proxy for the fcgi requests
        gzip_types text/plain text/css application/x-javascript text/javascript application/json; 
    # redirect server error pages to the static page /50x.html
    #
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }
    # proxy the PHP scripts to Apache listening on 127.0.0.1:80
    #
    #location ~ .php$ {
    #    proxy_pass   http://127.0.0.1;
    #}
    location @handler { ## Magento uses a common front handler
        rewrite / /index.php;
    }
    # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
    #
    location ~ .php$ {
        #      if (!-e $request_filename) { rewrite / /index.php last; } ## Catch 404s that try_files miss
        root           /usr/share/nginx/html/mebozo-magento.mebozo.com;
        fastcgi_pass   127.0.0.1:9000;
        fastcgi_index  index.php;
        fastcgi_param  SCRIPT_FILENAME  /usr/share/nginx/html/mebozo-magento.mebozo.com$fastcgi_script_name;
        include        fastcgi_params;
    }
    # deny access to .htaccess files, if Apache's document root
    # concurs with nginx's one
    #
    location ~ /.ht {
        deny  all;
    }    
}

我将尝试通过建议我们清理您的nginx配置文件来解决这个问题。你的*/文件/重写对我来说似乎是有问题的。

在不知道你的nginx.conf文件是什么样子或你的http {block}看起来像什么的情况下,我会假设它很干净,并且你正在处理你的全局设置,如gzip类型,ssl协议和密码,以及其他标头等。我知道您在文件中包含了您的 gzip,但有时会在服务器中复制它,却没有意识到它已经在上面设置了一层......如果没有,请根据需要重新添加 gzip。综上所述,在完全阅读您的 conf 文件后,我建议将其重写为如下所示的内容:

(注意:新的 URI 级别位置和@rewrites,以及删除冗余根路径定义。

server {
    listen 80;
    listen [::]:80;
    ## SSL CONFIGURATION (can be done here in same file)
    #listen 443 ssl http2;
    #listen [::]:443 ssl http2;
    #ssl_certificate     /etc/nginx/ssl/cert_chain.crt;
    #ssl_certificate_key     /etc/nginx/ssl/star_example.com.priv.key;
    # domain name
    server_name example.com www.example.com;
    # doc root
    root /usr/share/nginx/html/mebozo-magento.mebozo.com;
    ## Logs per vhost
    access_log      /var/log/nginx/example.com.access.log;
    error_log       /var/log/nginx/example.com.error.log warn;
    ## This can also be set in your http block and if it is, it's not needed here.
    index index.php index.html index.htm;
    # Adjust upload max file size settings
    # This value should match your PHP.ini config settings for upload_max_filesize
    client_max_body_size 50M; # allows file uploads up to 50 megabytes
    location = /favicon.ico {
        log_not_found off;
        access_log off;
    }
    location = /robots.txt {
        allow all;
        log_not_found off;
        access_log off;
    }
    ## Main Magento location
    location / {
        try_files $uri $uri/ @rewrite;
    }
    # Your blog location
    location /blog/ {
        try_files $uri $uri/ @rewrite_blog;
    }
    # redirect server error pages to the static page /50x.html
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root    /usr/share/nginx;
    }
    ## These locations are protected
    location ~ /(app|downloader|includes|pkginfo|var|errors/local.xml)/ {
        deny all;
    }
    ## Images
    location ~* .(js|css|png|jpg|jpeg|gif|ico)$ {
        expires max;
        log_not_found off;
        access_log off;
        add_header ETag "";
    }
    location =/js/index.php/x.js {
        rewrite ^(.*.php)/ $1 last;
    }
    # rewrites
    location @rewrite {
        rewrite / /index.php?$args;
    }
    location @rewrite_blog {
        rewrite /blog/ /blog/index.php?$args;
    }
    ## Execute PHP scripts
    location ~ .php$ {
        try_files $uri =404;
        fastcgi_split_path_info ^(.+.php)(/.+)$;
        fastcgi_pass   127.0.0.1:9000;
        fastcgi_index index.php;
        ## Store code with multi store/domain magento instance
        #fastcgi_param MAGE_RUN_CODE $mage_code;
        #fastcgi_param MAGE_RUN_TYPE $mage_type;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        include fastcgi_params;
    }
    # Banned locations (only reached if the earlier PHP entry point regexes don't match)
    location ~* (.php$|.sh$|.txt$|.htaccess$|.git|.sample$|mage$) {
        deny all;
    }
}

最新更新