2

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

未加载 css 文件和 js 文件。

这是我所做的:

  • 我被设置:$kernel = new AppKernel('prod', true);
  • 我执行了以下命令:

    php 应用程序/控制台缓存:清除 --env=prod --no-debug php 应用程序/控制台资产:转储 --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">

就好像我在开发环境中一样!

所以我也在开发环境中清理了我的缓存,并重新启动了我的进程来生产环境......没有成功。

你知道什么是问题吗?

我添加我的 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/*'
    %}

但没有成功。

4

3 回答 3

2

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

您将环境设置为 prod 和 debug 为 false:

class Kernel ...

public function __construct($environment, $debug)
于 2014-04-15T02:38:29.920 回答
2

尝试使用:

php app/console assets:install web --symlink

这样,您将拥有一个符号链接,而不是拥有每个捆绑资源的副本,因此无需更新。

来自文档:

使用 cssrewrite 过滤器时,不要使用 @AcmeFooBundle 语法引用您的 CSS 文件。

试试这个方法:

{% stylesheets 'bundles/acme_foo/css/*' filter='cssrewrite' %}
    <link rel="stylesheet" href="{{ asset_url }}" />
{% endstylesheets %}
于 2013-11-15T01:27:06.297 回答
1

我偶然发现了它:

Assetic 未创建组合链接

它确实有效。我一点都不明白。对于 prod 工作,您必须将“prod”设置为 false。

于 2013-11-17T13:52:59.963 回答