Django-compressor: يمكن أن ينتج عن تحليل عناوين URL للبيانات المقتبسة اقتباس خاطئ في compressor.filters.css_default.CssAbsoluteFilter

تم إنشاؤها على ١٣ سبتمبر ٢٠١٧  ·  16تعليقات  ·  مصدر: django-compressor/django-compressor

أنا أقوم بضغط bootstrap4 باستخدام django-compress ، وهو يقتبس خطأً إحدى خلفيات svg.

يتحول هذا:
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"); }

في هذا:
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"); }

من الصعب بعض الشيء رؤيته ، ولكن هناك مبلغ إضافي " إدخاله في rgba(255, 255, 255, 0.5") . هذا الاقتباس الإضافي يبطل معظم CSS التالي (حتى تقوم خلفية SVG أخرى بإدراج اقتباس آخر ، وإعادة تشغيل قواعد CSS).

أحد الحلول هو تعطيل compressor.filters.css_default.CssAbsoluteFilter .

يمكن أن تكون هذه المشكلة متعلقة بالرقم 485

bug needinfo

ال 16 كومينتر

يبدو كنسخة مكررة من https://github.com/django-compressor/django-compressor/issues/827. الإصلاح في django-compressor 2.2 ، يرجى التأكد من أنك تستخدم أحدث إصدار. إذا استمرت المشكلة ، فسوف نعيد فتحها بالطبع :)

karyon أواجه نفس المشكلة بالضبط ، وأنا أستخدم django-compressor 2.2.

حسنًا ، اللعنة :) سألقي نظرة في الأيام القادمة على أمل.

shezi ، @ Hybridx24 ، أي إصدار من bootstrap بالضبط؟ beta1؟

أنا أستخدم Bootstrap 3.3.6 بالفعل - ولكن المشكلة تحدث لي عندما أستخدم SVG المخصص الخاص بي (والذي يعمل بشكل مثالي على الضغط المسبق). يبدو أنه كما قال OP ، هناك شيء ما ينكسر داخل background-image: url("data:image/svg+xml;...")

أنا أستخدم Bootstrap v4.0.0-alpha.6 ولدي نفس المشكلة. سيكون من الجيد أن تتمكن من إصلاح هذا

@ Hybridx24 ، Renatello ، من فضلك أعطني إصدار python الخاص بك ، إخراج تجميد النقطة ، إدخال css ، الإخراج الفعلي والإخراج المتوقع. لقد قمت بلصق ملف css الذي أبلغت عنه

@ karyon

بايثون: 3.6.2
جانغو: 1.11.5

المتطلبات. 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:

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:

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)

الناتج المتوقع:
غير معروف ، ولكن يمكنك الاختبار عن طريق لصق رمز CSS base64 في شريط عنوان url ومعرفة ما إذا كان يعمل بشكل صحيح.

هذا يضغط جيدًا بالنسبة لي أيضًا: (هل يمكنك أن تعطيني إعداداتك. py ، بعض السياق الإضافي لملف css (من الناحية المثالية الملف الكامل) والقالب الذي تقوم بتضمينه فيه؟

karyon إن css هو في الحقيقة مجرد تجاوز للسهم التالي / السابق لـ swiper.js ، لذا فإن باقي الكود غير ذي صلة إلى حد كبير. كل ما أعرفه هو أن CSS يعمل بشكل مثالي حتى أقوم بلف علامات {% compress css %} حول ملف swiper-overrides.css . الخطأ الذي أحصل عليه هو:

هذه الصفحة تحتوي على الأخطاء التالية:
خطأ في السطر 1 في العمود 10: خطأ في تحليل اسم السمة
يوجد أدناه عرض للصفحة حتى الخطأ الأول.

بالنسبة للإعدادات 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 أيضًا بتشكيل نفس القاعدة من Bootstrap 4 ، وإن كان بطريقة مختلفة عما أعتقده CssAbsoluteFilter فعل ؛ يزيل المصغر المسافات من البيانات: URL. لذلك إذا كنت تواجه مشكلة في إصدار django-compressor الذي تم إصلاح هذا الخطأ فيه بالفعل ، فقد تضرب ndparker / rcssmin # 8 بدلاً من ذلك.

إعادة قراءة هذا و # 910 يبدو لي أن المشكلة الأصلية (اقتباس خاطئ) قد تم إصلاحها بالفعل وأن المشكلة المتبقية (إزالة المسافة البيضاء) موصوفة في # 910. شكرا @ Hybridx24 و jsma وjameysharp.

لما يستحق الأمر ، لقد واجهت نفس المشكلة عندما تم تمكين compressor.filters.css_default.CssAbsoluteFilter ، وضغط Bootstrap 4.

dwasyl هل تم تمكين RCSSmin أيضًا؟ هل يمكنك لصق ناتج تجميد النقطة وإدخال css والإخراج الفعلي والإخراج المتوقع؟

karyon معذرة ، لم

ما أراه كقيمة غير مضغوطة هو هذا:
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)

ثم بعد الضغط:
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)

في الإعدادات ، لدي:

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

بقدر تجميد PIP:

django-compressor==2.2
rcssmin==1.0.6

شكر. الذي يشبه بالفعل # 910.

هل كانت هذه الصفحة مفيدة؟
0 / 5 - 0 التقييمات