Web Мастерская
Установка библиотеки Imagick
Библиотека Imagick является PHP-интерфейсом к ImageMagick, мощному инструменту обработки изображений. Она позволяет разработчикам легко манипулировать изображениями прямо из PHP-кода, выполняя операции вроде изменения размера, поворота, наложения фильтров и многое другое.
Прежде всего убедитесь, что на вашем сервере установлен пакет ImageMagick. Если у вас Linux-дистрибутив, выполните следующую команду для проверки:
Если вывод команды показывает версию ImageMagick, значит, всё установлено правильно. Если же пакета нет, установите его одной из команд ниже в зависимости от вашей системы:
Ubuntu / Debian:
CentOS / RHEL:
macOS (Homebrew):
Для установки самого PHP-расширения вам потребуется компилятор и некоторые...
Проверка наличия ImageMagick
Прежде всего убедитесь, что на вашем сервере установлен пакет ImageMagick. Если у вас Linux-дистрибутив, выполните следующую команду для проверки:
ВыделитьBash
convert -versionЕсли вывод команды показывает версию ImageMagick, значит, всё установлено правильно. Если же пакета нет, установите его одной из команд ниже в зависимости от вашей системы:
Ubuntu / Debian:
ВыделитьBash
sudo apt-get update && sudo apt-get install imagemagickCentOS / RHEL:
ВыделитьBash
sudo yum install epel-release
sudo yum install ImageMagick-develmacOS (Homebrew):
ВыделитьBash
brew install imagemagickУстановка расширения PECL Imagick
Для установки самого PHP-расширения вам потребуется компилятор и некоторые...
- Жалоба
Failed to execute 'appendChild' on 'Node': Unexpected identifier 'site'
Ошибка Uncaught SyntaxError: Failed to execute 'appendChild' on 'Node': Unexpected identifier 'site' возникает, когда JavaScript пытается вставить некий некорректный фрагмент кода в дерево документа, и встречает нечто, что нельзя интерпретировать как действительную инструкцию.
Обычно подобная ошибка проявляется, когда в коде присутствует неприемлемый или поврежденный JavaScript-код, который получается динамически, например, через AJAX-запрос или серверную генерацию.
Открытие вкладки Console в инструментах разработчика (DevTools): Первое, что нужно сделать, — это открыть консоль браузера и изучить детали ошибки. Консоль выдаст всю необходимую информацию, включая имя файла и номер строки, где произошла ошибка.
Определите происхождение JavaScript-кода: Если вы увидели, что ошибка возникает после AJAX-запроса, найдите точку, где этот запрос выполняется, и изучите ответ сервера. Возможно, в ответе содержится повреждённая или небезопасная...
Обычно подобная ошибка проявляется, когда в коде присутствует неприемлемый или поврежденный JavaScript-код, который получается динамически, например, через AJAX-запрос или серверную генерацию.
Шаги для нахождения и устранения проблемы
Открытие вкладки Console в инструментах разработчика (DevTools): Первое, что нужно сделать, — это открыть консоль браузера и изучить детали ошибки. Консоль выдаст всю необходимую информацию, включая имя файла и номер строки, где произошла ошибка.
Определите происхождение JavaScript-кода: Если вы увидели, что ошибка возникает после AJAX-запроса, найдите точку, где этот запрос выполняется, и изучите ответ сервера. Возможно, в ответе содержится повреждённая или небезопасная...
Cross site forgery request (CSFR) detected
Сообщение «Cross-site forgery request (CSRF) detected» означает, что система безопасности обнаружила попытку несанкционированного межсайтового запроса (CSRF), и заблокировала его. Такие попытки обычно происходят, когда злоумышленник пытается обмануть пользователя, заставив его совершить нежелательные действия на доверенном сайте путем подделывания запроса с другого домена.
CSRF (cross-site request forgery) — это уязвимость веб-приложений, позволяющая злоумышленнику заставить жертву отправить вредоносный запрос к сайту, которому жертва доверяет. Например, если вы вошли на банковский сайт и открыли другую вкладку с поддельным сайтом, мошенник может попытаться заставить вас выполнить транзакцию или удалить аккаунт на доверенном сайте, используя сессионные куки жертвы.
Что такое CSRF?
CSRF (cross-site request forgery) — это уязвимость веб-приложений, позволяющая злоумышленнику заставить жертву отправить вредоносный запрос к сайту, которому жертва доверяет. Например, если вы вошли на банковский сайт и открыли другую вкладку с поддельным сайтом, мошенник может попытаться заставить вас выполнить транзакцию или удалить аккаунт на доверенном сайте, используя сессионные куки жертвы.
Типичные сценарии атаки CSRF
- Удаление аккаунта или сброс пароля: Жертву заставляют подтвердить сброс пароля или удаление аккаунта через скрытые формы или гиперссылки.
- Перевод денег: Пользователь открывает
Content unavailable: Resource was not cached
Такая ошибка обычно возникает, когда вы пытаетесь получить доступ к контенту, который не был закэширован или недоступен в локальном кэше браузера. Эта ситуация характерна для случаев, когда запрашиваемые ресурсы (например, изображения, файлы CSS или JS) находятся на сервере, но не были ранее сохранены в кэше клиента.
Есть несколько возможных причин этой ошибки
- Политика кэширования: Ресурс может быть помечен как не подлежащий кэшированию (например, заголовок
Cache-Control: no-cache). Браузер не сможет сохранить такой ресурс в локальном кэше. - Режим очистки кэша: Если вы недавно очистили кэш браузера, ресурс, который был в нём ранее, перестанет быть доступным из кэша.
- Ошибки сетевого соединения: Иногда ошибки сети или сервера могут помешать успешной передаче ресурса клиенту, что приводит к отказу в доступе к кэшированным материалам.
- Истечение срока действия кэша: Даже если ресурс ранее был закэширован, срок его годности может истечь, и браузер прекратит предоставление его из кэша.
Что можно
...Synchronous XMLHttpRequest on the main thread is deprecated
Если вы столкнулись с предупреждением «Synchronous XMLHttpRequest on the main thread is deprecated», это значит, что ваш код совершает синхронные запросы на главную нить браузера. Подобная практика признана устаревшей и не рекомендуется из-за серьёзного негативного влияния на пользовательский опыт.
В этой статье мы расскажем, почему появились такие запросы, каковы последствия их использования и как можно исправить ситуацию.
Синхронный запрос — это когда выполнение программы блокируется до завершения сети. Другими словами, пока запрос не получит ответ от сервера, браузер не сможет продолжать обработку скриптов и реагировать на действия пользователя.
Например, возьмем такой JavaScript-код:
Параметр
В этой статье мы расскажем, почему появились такие запросы, каковы последствия их использования и как можно исправить ситуацию.
Что такое синхронные запросы?
Синхронный запрос — это когда выполнение программы блокируется до завершения сети. Другими словами, пока запрос не получит ответ от сервера, браузер не сможет продолжать обработку скриптов и реагировать на действия пользователя.
Например, возьмем такой JavaScript-код:
ВыделитьJavaScript
var xhr = new XMLHttpRequest();
xhr.open('GET', '/api/data', false); // Параметр false делает запрос синхронным
xhr.send();
console.log(xhr.responseText);Параметр
false в третьей позиции заставляет запрос ждать завершения передачи данных от сервера,...