首页 文章

资产坏css文件链接prod env

提问于
浏览
2

我正在尝试在 生产环境 环境中测试我的应用程序 . 问题是Assetic无法正常工作 .

没有加载css文件和js文件 .

这是我做的:

  • 我被设定: $kernel = new AppKernel('prod', true);

  • 我执行了命令:

php app / console cache:clear --env = prod --no-debug php app / console assetic:dump --env = prod --no-debug

到目前为止,没有问题,我的文件已经创建:

01:07:26 [file+] /var/www/visual-immersion/app/../web/js/b0c2086.js
01:07:26 [file+] /var/www/visual-immersion/app/../web/js/a49caf1.js
01:07:26 [file+] /var/www/visual-immersion/app/../web/css/a580ac9.css

但是当我启动我的网页时,没有css,没有js . 如果我检查我的源代码页,我可以看到:

<link rel="stylesheet" type="text/css"href="/css/a580ac9_part_1_home_1.css">

            <link rel="stylesheet" type="text/css" href="/css/a580ac9_layout_2.css">

            <link rel="stylesheet" type="text/css" href="/css/a580ac9_style_3.css">

            <link rel="stylesheet" type="text/css" href="/css/a580ac9_font_4.css">

            <link rel="stylesheet" type="text/css" href="/css/a580ac9_responsive_5.css">

            <link rel="stylesheet" type="text/css" href="/css/a580ac9_animations_6.css">

            <link rel="stylesheet" type="text/css" href="/css/a580ac9_personalized-responsive_7.css">

好像我在开发环境中!

所以我也在dev env中清理了我的缓存,并重新开始我的进程以刺激env ...没有成功 .

你知道什么是问题吗?

我添加我的config.yml:

imports:
    - { resource: parameters.yml }
    - { resource: security.yml }

framework:
    #esi:             ~
    #translator:      { fallback: %locale% }
    secret:          %secret%
    router:
        resource: "%kernel.root_dir%/config/routing.yml"
        strict_requirements: ~
    form:            ~
    csrf_protection: ~
    validation:      { enable_annotations: true }
    templating:
        engines: ['twig']
        #assets_version: SomeVersionScheme
    default_locale:  "%locale%"
    trusted_proxies: ~
    session:         ~
    fragments:       ~

# Twig Configuration
twig:
    debug:            %kernel.debug%
    strict_variables: %kernel.debug%

# Assetic Configuration
assetic:
    debug:          %kernel.debug%
    use_controller: false
    bundles:        [VisualImmersionAdminBundle, VisualImmersionSiteBundle]
    #java: /usr/bin/java
    filters:
        cssrewrite: ~
        #closure:
        #    jar: %kernel.root_dir%/Resources/java/compiler.jar
        #yui_css:
        #    jar: %kernel.root_dir%/Resources/java/yuicompressor-2.4.7.jar

# Doctrine Configuration
doctrine:
    dbal:
        driver:   %database_driver%
        host:     %database_host%
        port:     %database_port%
        dbname:   %database_name%
        user:     %database_user%
        password: %database_password%
        charset:  UTF8
        # if using pdo_sqlite as your database driver, add the path in parameters.yml
        # e.g. database_path: %kernel.root_dir%/data/data.db3
        # path:     %database_path%

    orm:
        auto_generate_proxy_classes: %kernel.debug%
        auto_mapping: true

# Swiftmailer Configuration
swiftmailer:
        transport: gmail
        username:  contact@visual-immersion.com
        password:  mypassword

编辑:

我用资产重试了这个程序:安装没有成功 .

编辑2:

在我的网页浏览器开发工具中,如果我添加该行:

<link rel="stylesheet" type="text/css" href="/css/a580ac9.css">

这是工作 . 我真的认为Assetic将文件加载为dev env而不是prod env . 任何的想法?

编辑3:

我添加布局或托管的css文件,如果它可以帮助...

{% stylesheets '@VisualImmersionSiteBundle/Resources/public/css/*'  filter='cssrewrite'
            'css/stylesheets/layout.css'
            'css/stylesheets/style.css'
            'css/stylesheets/font.css'
            'css/stylesheets/responsive.css'
            'css/stylesheets/animations.css'
            'css/stylesheets/personalized-responsive.css'
        %}
            <link rel="stylesheet" type="text/css" href="{{ asset_url }}">

        {% endstylesheets %}

编辑4:

我试图改变我的样式表过滤器像这样:

{% stylesheets filter='cssrewrite'
        'css/stylesheets/*'
        'bundles/visualimmersionsite/css/*'
    %}

但没有成功 .

3 回答

  • 1

    尝试使用:

    php app/console assets:install web --symlink
    

    这样,您将拥有一个符号链接,而不是拥有每个包的资源副本,因此不需要更新 .

    来自docs:

    使用cssrewrite过滤器时,请勿使用@AcmeFooBundle语法引用CSS文件 .

    试试这种方式:

    {% stylesheets 'bundles/acme_foo/css/*' filter='cssrewrite' %}
        <link rel="stylesheet" href="{{ asset_url }}" />
    {% endstylesheets %}
    
  • 2

    将prod设置为false并不是正在发生的事情 .

    您将环境设置为prod并调试为false:

    class Kernel ...
    
    public function __construct($environment, $debug)
    
  • 2

    我意外地偶然发现了它:

    Assetic not creating combined links

    它确实有效 . 我一点都不明白 . 对于prod工作,你必须将'prod'设置为false .

相关问题