2

我在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;
    }    
}
4

1 回答 1

0

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

在不知道你的 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;
    }
}
于 2016-07-21T05:45:17.157 回答