Django-compressor: Das Parsen von URLs in Anführungszeichen kann zu falschen Anführungszeichen in compressor.filters.css_default.CssAbsoluteFilter führen

Erstellt am 13. Sept. 2017  ·  16Kommentare  ·  Quelle: django-compressor/django-compressor

Ich komprimiere bootstrap4 mit django-compress und es zitiert fälschlicherweise einen der SVG-Hintergründe.

Es dreht sich dies:
background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(255, 255, 255, 0.5)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 8h24M4 16h24M4 24h24'/%3E%3C/svg%3E"); }

das sehr gut finden:
background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(255, 255, 255, 0.5")' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 8h24M4 16h24M4 24h24'/%3E%3C/svg%3E"); }

Es ist ein bisschen schwer zu sehen, aber in rgba(255, 255, 255, 0.5") ist ein zusätzliches " eingefügt. Dieses zusätzliche Anführungszeichen macht den größten Teil des folgenden CSS ungültig (bis ein anderer SVG-Hintergrund ein weiteres Anführungszeichen einfügt und die CSS-Regeln neu startet).

Eine Problemumgehung besteht darin, compressor.filters.css_default.CssAbsoluteFilter zu deaktivieren.

Dieses Problem könnte mit # 485 zusammenhängen

bug needinfo

Alle 16 Kommentare

sieht aus wie ein Duplikat von https://github.com/django-compressor/django-compressor/issues/827. Das Update befindet sich in Django-Compressor 2.2. Bitte stellen Sie sicher, dass Sie die neueste Version verwenden. Wenn das Problem weiterhin besteht, werden wir es natürlich wieder öffnen :)

@karyon Ich habe genau das gleiche Problem und verwende den Django-Kompressor 2.2.

Nun, Scheiße :) Ich werde hoffentlich in den kommenden Tagen einen Blick darauf werfen.

@shezi , @ Hybridx24 , welche Version von Bootstrap genau? Beta1?

Ich verwende tatsächlich Bootstrap 3.3.6 - aber das Problem tritt bei mir auf, wenn ich mein eigenes benutzerdefiniertes SVG verwende (das perfekt vor der Komprimierung funktioniert). Es scheint, dass, wie das OP sagte, etwas innerhalb von background-image: url("data:image/svg+xml;...") bricht

Ich verwende Bootstrap v4.0.0-alpha.6 und habe das gleiche Problem. Es wäre schön, wenn Sie dies beheben könnten

@ Hybridx24 , @Renatello , bitte geben Sie mir Ihre Python-Version, Pip Freeze-Ausgabe, Eingabe-CSS, tatsächliche Ausgabe und erwartete Ausgabe. Ich habe das von @shezi gemeldete eingefügt und in diesem Test ändert der CSSAbsoluteFilter es überhaupt nicht.

@ Karyon

Python: 3.6.2
Django: 1.11.5

Anforderungen.txt:
appdirs==1.4.3 asn1crypto==0.23.0 bcrypt==3.1.3 boto==2.48.0 certifi==2017.7.27.1 cffi==1.11.1 chardet==3.0.4 cryptography==2.0.3 defusedxml==0.5.0 diff-match-patch==20121119 dj-database-url==0.4.2 Django==1.11.5 django-allauth==0.33.0 django-appconf==1.0.2 django-autoslug==1.9.3 django-axes==2.3.3 django-compressor==2.2 django-crispy-forms==1.6.1 django-debug-toolbar==1.8 django-extensions==1.9.1 django-imagekit==4.0.1 django-import-export==0.5.1 django-ipware==1.1.6 django-loginas==0.3.3 django-mptt==0.8.7 django-postman==3.5.1 django-reversion==2.0.10 django-smart-selects==1.5.2 django-storages==1.6.5 django-tz-detect==0.2.8 djrill==2.1.0 easypost==3.6.2 enum34==1.1.6 et-xmlfile==1.0.1 Fabric3==1.13.1.post1 geoip2==2.5.0 idna==2.6 igdb-api-python==1.0 ipaddress==1.0.18 jdcal==1.3 maxminddb==1.3.0 numpy==1.13.3 oauthlib==2.0.4 odfpy==1.3.5 olefile==0.44 openpyxl==2.4.8 packaging==16.8 pandas==0.20.3 paramiko==2.3.1 pilkit==2.0 Pillow==4.1.1 psycopg2==2.7.3.1 pyasn1==0.3.7 pycparser==2.18 PyNaCl==1.1.2 pyOpenSSL==17.3.0 pyparsing==2.2.0 python-dateutil==2.6.1 python-openid==2.2.5 python3-openid==3.1.0 pytz==2017.2 PyYAML==3.12 rcssmin==1.0.6 requests==2.18.4 requests-oauthlib==0.8.0 rjsmin==1.0.12 six==1.11.0 sorl-thumbnail==12.3 sqlparse==0.2.4 stripe==1.66.0 tablib==0.12.1 unicodecsv==0.14.1 Unidecode==0.4.21 urllib3==1.22 virtualenv==15.1.0 waitress==1.0.2 xlrd==1.1.0 xlwt==1.3.0 xmltodict==0.11.0

CSS eingeben:

background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='96' height='96' viewBox='0 0 96 96' xmlns:xlink='http://www.w3.org/1999/xlink'%3E%3Cdefs%3E%3Cfilter id='a'%3E%3CfeOffset dy='-96' in='SourceGraphic' result='b'%3E%3C/feOffset%3E%3CfeColorMatrix in='b' result='b' type='matrix' values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0'%3E%3C/feColorMatrix%3E%3CfeComposite in='SourceGraphic' in2='b' operator='in'%3E%3C/feComposite%3E%3C/filter%3E%3C/defs%3E%3Cimage width='100%' height='200%' xmlns:A='http://www.w3.org/1999/xlink' A:href='' filter='url(%23a)'%3E%3C/image%3E%3C/svg%3E");

CSS ausgeben:

background-image: url("data:image/svg+xml;charset=utf8,%3Csvgxmlns='http://www.w3.org/2000/svg'width='96'height='96'viewBox='009696'xmlns:xlink='http://www.w3.org/1999/xlink'%3E%3Cdefs%3E%3Cfilterid='a'%3E%3CfeOffsetdy='-96'in='SourceGraphic'result='b'%3E%3C/feOffset%3E%3CfeColorMatrixin='b'result='b'type='matrix'values='00000000000000000100'%3E%3C/feColorMatrix%3E%3CfeCompositein='SourceGraphic'in2='b'operator='in'%3E%3C/feComposite%3E%3C/filter%3E%3C/defs%3E%3Cimagewidth='100%'height='200%'xmlns:A='http://www.w3.org/1999/xlink'A:href=''filter='url(%23a)'%3E%3C/image%3E%3C/svg%3E)

Erwartete Ausgabe:
Unbekannt, aber Sie können testen, indem Sie CSS base64-Code in die URL-Leiste einfügen und prüfen, ob er ordnungsgemäß funktioniert.

das komprimiert auch für mich ganz gut :( Könnten Sie mir Ihre settings.py, etwas mehr Kontext der CSS-Datei (idealerweise die ganze) und die Vorlage, in die Sie diese aufnehmen, geben?

@karyon Das CSS ist eigentlich nur ein überschreibender nächster / vorheriger Pfeil für swiper.js, daher ist der Rest des Codes weitgehend irrelevant. Ich weiß nur, dass das CSS perfekt funktioniert, bis ich {% compress css %} Tags um meine swiper-overrides.css -Datei wickle. Der Fehler, den ich bekomme, ist:

Diese Seite beinhaltet die folgenden Fehler:
Fehler in Zeile 1 in Spalte 10: Fehler beim Parsen des Attributnamens
Unten finden Sie eine Darstellung der Seite bis zum ersten Fehler.

Wie für die settings.py:

import os
import sys
import dj_database_url

from django.contrib.messages import constants as messages

# Normally you should not import ANYTHING from Django directly
# into your settings, but ImproperlyConfigured is an exception.
from django.core.exceptions import ImproperlyConfigured


def get_env_variable(var_name):
    """Get the environment variable or return exception."""
    try:
        return os.environ[var_name]
    except KeyError:
        error_msg = "Set the {} environment variable".format(var_name)
        raise ImproperlyConfigured(error_msg)


# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
BASE_DIR = os.path.dirname(os.path.dirname(os.path.dirname(__file__)))

SECRET_KEY = get_env_variable('DJANGO_SECRET_KEY')

DEBUG = True

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'django.contrib.postgres',
    'django.contrib.sites',
    'django.contrib.humanize',

    # 3rd Party Packages
    'compressor',
    'storages',

   'main'
]

MIDDLEWARE = [
    'debug_toolbar.middleware.DebugToolbarMiddleware',  # Should be as high up as possible
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
    'tz_detect.middleware.TimezoneMiddleware',  # dj-tz-detect
    'django.middleware.security.SecurityMiddleware'  # Needed to make SECURE_SSL_REDIRECT work
]

ROOT_URLCONF = '<app>.urls'

WSGI_APPLICATION = '<app>.wsgi.application'

LANGUAGE_CODE = 'en-us'

TIME_ZONE = 'UTC'

USE_I18N = True

USE_L10N = True

USE_TZ = True

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [os.path.join(BASE_DIR, 'templates')],
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.contrib.auth.context_processors.auth',
                'django.template.context_processors.debug',
                'django.template.context_processors.i18n',
                'django.template.context_processors.media',
                'django.template.context_processors.static',
                'django.template.context_processors.tz',
                'django.contrib.messages.context_processors.messages',

                "django.template.context_processors.request",
            ],
            'debug': True,  # Note: Enabled on dev/staging sites only.
            'string_if_invalid': 'INVALID VARIABLE (Check Template): %s'  # Note: Enabled on dev/staging sites only.
        },
    },
]

# dj-tz-detect
TZ_DETECT_COUNTRIES = ('US',)

SITE_ID = 1

DATABASES = {'default': dj_database_url.config()}

ALLOWED_HOSTS = ['*']

AWS_S3_SECURE_URLS = True
AWS_QUERYSTRING_AUTH = False
AWS_ACCESS_KEY_ID = get_env_variable('AWS_ACCESS_KEY_ID')
AWS_SECRET_ACCESS_KEY = get_env_variable('AWS_SECRET_ACCESS_KEY')
AWS_STORAGE_BUCKET_NAME = '<app>'
AWS_S3_CUSTOM_DOMAIN = "s3.amazonaws.com/{0}".format(AWS_STORAGE_BUCKET_NAME)

STATICFILES_FINDERS = (
    'django.contrib.staticfiles.finders.FileSystemFinder',
    'django.contrib.staticfiles.finders.AppDirectoriesFinder',
    'compressor.finders.CompressorFinder',  # django-compressor
)

STATICFILES_DIRS = (
    os.path.join(BASE_DIR, "staticfiles"),
)

STATIC_ROOT = os.path.join(BASE_DIR, 'static')
MEDIA_ROOT = os.path.join(BASE_DIR, 'media')

MEDIA_URL = "https://{0}/media/".format(AWS_S3_CUSTOM_DOMAIN)
STATIC_URL = "https://{0}/static/".format(AWS_S3_CUSTOM_DOMAIN)

DEFAULT_FILE_STORAGE = '<app>.s3utils.MediaS3BotoStorage'
STATICFILES_STORAGE = '<app>.s3utils.CachedS3BotoStorage'

COMPRESS_STORAGE = STATICFILES_STORAGE
COMPRESS_URL = STATIC_URL
COMPRESS_ROOT = STATIC_ROOT

COMPRESS_ENABLED = True
COMPRESS_CSS_FILTERS = ['compressor.filters.css_default.CssAbsoluteFilter', 'compressor.filters.cssmin.rCSSMinFilter']
COMPRESS_JS_FILTERS = ['compressor.filters.jsmin.JSMinFilter']

RCSSmin verstümmelt auch die gleiche Regel aus Bootstrap 4, obwohl auf eine andere Weise als ich denke, CssAbsoluteFilter ; Der Minifier entfernt die Leerzeichen aus den Daten: URL. Wenn Sie also Probleme mit einer Django-Kompressor-Version haben, bei der dieser Fehler bereits behoben ist, schlagen Sie möglicherweise stattdessen ndparker / rcssmin # 8.

Wenn ich dies und # 910 noch einmal lese, scheint es mir, dass das ursprüngliche Problem (falsches Zitat) tatsächlich behoben wurde und das verbleibende Problem (entferntes Leerzeichen) in # 910 beschrieben ist. danke @ Hybridx24 , @jsma und @jameysharp.

Für das, was es wert ist, bin ich auf dasselbe Problem gestoßen, als compressor.filters.css_default.CssAbsoluteFilter aktiviert war und Bootstrap 4 komprimiert wurde.

@dwasyl war RCSSmin auch aktiviert? Können Sie bitte die Ausgabe von Pip Freeze, die Eingabe CSS, die tatsächliche Ausgabe und die erwartete Ausgabe einfügen?

@karyon Entschuldigung, ich war seit

Was ich als meinen unkomprimierten Wert sehe, ist Folgendes:
url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(255, 255, 255, 0.5)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e)

Dann nach der Komprimierung:
url("data:image/svg+xml,%3csvgxmlns='http://www.w3.org/2000/svg'width='30'height='30'viewBox='003030'%3e%3cpathstroke='rgba(255,255,255,0.5)'stroke-linecap='round'stroke-miterlimit='10'stroke-width='2'd='M47h22M415h22M423h22'/%3e%3c/svg%3e)

In den Einstellungen habe ich:

COMPRESS_CSS_FILTERS = [
    'compressor.filters.css_default.CssAbsoluteFilter',
    'compressor.filters.cssmin.CSSMinFilter'
]

Soweit PIP einfrieren:

django-compressor==2.2
rcssmin==1.0.6

Vielen Dank. das sieht ja aus wie # 910.

War diese Seite hilfreich?
0 / 5 - 0 Bewertungen