- Добавляем GET-параметр orm=y, то есть до # и после ?lang=ru добавляем &orm=y.
- Пример: https://site.ru/bitrix/admin/perfmon_tables.php?lang=ru&orm=y#iblock_element
- После в контекстном меню таблицы появится дополнительный пункт — ORM.
Битрикс
Добавить CANONICAL в битрикс
Идем по пути /bitrix/php_interface/init.php
Вставляем запись:
AddEventHandler('main', 'OnEpilog', 'setCanonical', 1); function setCanonical() { global $APPLICATION; if (strpos($APPLICATION->GetCurPageParam(), '?') !== false) { if ($APPLICATION->GetPageProperty('canonical') == '') { CMain::IsHTTPS() ? $s = 's' : $s = ''; $url = 'http' . $s . '://' . SITE_SERVER_NAME . $APPLICATION->GetCurPage(); $APPLICATION->SetPageProperty("canonical", $url); } } }
Отправить новость в рассылке сразу после публикации (Битрикс)
Непонятно, почему такой функции нет в Битрикс из коробки, ведь реализуется не очень сложно и ОЧЕНЬ востребована.
Есть периодическая отправка рассылки новостей. В новостях для почты есть настройка минимального количества новостей, типа, если не будет столько НОВЫХ записей, то рассылка уйти не должна.
На практике так не получается, даже если поставить одну новость. Рассылка срабатывает всегда. Что странно, ведь в описании как раз указано, что если нет НОВЫХ записей с момента отправки — новость уходить не должна.
Поэтому после гугления нашел реализацию мгновенной УПРАВЛЯЕМОЙ отправки новостей, немного доработал и сделал клиентам. Все довольны )
Итак, что нужно:
1. Настроить рассылку в Маркетинг -> Рассылки.
2. В поле сообщения добавить код
#MESSAGE#
(само сообщение будет формироваться в внутри функции отправки)
3. Отправка — вручную позже.
4. Запомнить ID рассылки.
5. Добавить свойство в новости, которые будут рассылаться: Простой чекбокс(строка), значения по умолчанию, название — что-то типа «Отправить рассылку?» (галка будет автоматически сниматься после отправки новости в рассылке)
6. Вывести свойство в редактирование новости
7. Запомнить ID новостей.
8. Добавить код в /bitrix/php_interface/init.php, заменив
<АДРЕС ПОЧТЫ ОТ> -вставляете свой, ЛУЧШЕ, чтобы доменное имя было как у домена сайта. Тогда новость будет приходить от адекватной почты (по крайней мере, на BEGET), а не от «unverified».
Скачать скрипт
9. Создаете новость, и, если хотите отправить ее сразу в рассылке, ставите галку «отправить в рассылке».
Она отправится после публикации.
На этом — все, считаю, что это, возможно, не лучшая реализация и можно все причесать, но работает отлично.
Поддержка сайта НМК — производителя печей в Сибири (1С Битрикс)
Вот уже третий год поддерживаем сайт производителя банных печей в Сибири — завода НМК.
CMS сайта — 1С-Битрикс.
Вот что о себе говорит завод НМК:
НМК Сегодня
- В настоящее время в НМК трудятся несколько сотен квалифицированных сотрудников различных специальностей.
- Выпускаемые котлы и печи реализуются в большинстве регионов СНГ через развитую сеть дистрибьюторов.
- Современные автоматизированные линии вместе с автопарком располагаются на площади 12 000 м² собственных площадей.
- Ежегодная отгрузка в розничные дилерские сети — около 120 тысяч готовых изделий.
- В нашем арсенале имеется более 12 сертификатов, дипломов и благодарностей, а также 10 авторских патентов.
Качественным, красивым печам — приятный, красивый сайт!
Не работает Sypex Geo или MaxMind в Битрикс
Новость не очень хорошая — на 02.03.2022 по известным причинам сайт Sypex Geo лежит и сервис недоступен.
В связи с этим, пришлось перейти на MaxMind
Но решение из коробки Битрикс также не работает даже при заполненных полях регистрации (логина и ключа).
В итоге, решение простое — в классе MaxMind (файл /bitrix/modules/main/lib/service/geoip/maxmind.php) устаревшая ссылка запроса — ее надо заменить на рабочую с сайта.
Для GeoIP2 Lite — https://geolite.info/geoip/v2.1/city/{$ipAddress}?pretty
И все заработает в штатном режиме.
Посмотреть сработавшие исходящие почтовые события в Битрикс
Как посмотреть сработавшие исходящие почтовые события в Битрикс
При конфигурации и начале работы в 1С Битрикс Управление сайтом возникает вопрос: как посмотреть отправленные письма в Битрикс?
Стандартные компоненты 1С Битрикс отправляют письма через свои события: при отправке письма с формы обратной связи, или заказы из магазины, или служебные нотификации — все эти письма попадают в очередь почтового сервера сайта и далее отправляется при следующем просмотре страницы сайта посетителем или роботом (по умолчанию в Битрикс отправка сообщений настроена на хитах), либо по крону (если администратор перенастроил отправку сообщений).
Здесь очень важный момент – по способу отправки. При установке многих модулей и далее отправке сайт начинает падать с 50X ошибками.
И при переключении между страницами сайт постоянно тормозит и падает.
Это происходит по той причине, что модуль осуществляет сетевые подключения к «вашему SMTP» серверу что в случае работы «Агентов на хитах» может увеличивать время генерации страниц и приводить к ошибкам 50X.
В случае возникновения проблем рекомендуется перевести Агент на Cron либо уменьшить интенсивность отправки писем в настройках соответствующих модулей.
Мы же можем посмотреть все события на отправку писем и их статусы специальным запросом к MySQL в консоли либо через GUI-интерфейс Битрикса: Рабочий стол > Настройки > Инструменты > SQL запрос:
select * from b_event order by id desc
Данный запрос покажет список всех сообщений и статусы отправки. Если сообщение не отправлено — можно определить причину.
1) В результатах запросы разбираем столбец SUCCESS_EXEC
SUCCESS_EXEC = Y — значит все в порядке, сообщение отправлено (если не пришло на почту, проблема с сервером)
SUCCESS_EXEC = N — не обработано событие (значит не отправлено)
SUCCESS_EXEC = 0 — не найден шаблон (указан не верный шаблон)
Соответственно, просмотрев код, вы можете убедиться что со стороны битрикса почта ушла хорошо (Y, 0) или же узнать по какой причине этого не произошло. Если стоит код Y, однако письма не доходят, с большой вероятностью надо проконсультироваться с системным администратором сервера, скорее всего дело в настройке почтового сервера.
2) Далее смотрим: EVENT_NAME
Это тип почтового события, т.е. по сути метка о том какого типа было это сообщение. Все типы (а собственно узнать их по кодам) можно увидеть по пути /bitrix/admin/type_admin.php?lang=ru
3) Поле: DATE_EXEC
Это дата, когда была осуществлена попытка отправки. Если там пусто, значит письмо ещё не отправлялось.
Битрикс отправляет почту на любом хите. Сколько писем может быть отправлено за один хит настраивается в главном модуле.
Также, важно отслеживать, чтобы почта уходила, по-возможности, с доменом сайта. Многие хостинги не пропускают почту не от сайта.
Убрать PAGEN_ из адресной строки (сайт на битрикс)
Часто SEO просит убрать PAGEN_1 и все остальные из адреса пагинации битрикс. Попробуйте этот вариант в .htaccess:
#Beautiful paginations php_value auto_prepend_file "/home/d/УЧЕТНАЯ_ЗАПИСЬ_ХОСТИНГА/ВАШ_САЙТ/public_html/bitrix/pagen.php" RewriteRule ^(.*)/pagen([\d]+)/ /$1/?PAGEN_1=$2 [L,QSA]
Содержимое файла pagen.php:
<?php function __isPathTraversalUri($uri) { if (($pos = strpos($uri, '?')) !== false) { $uri = substr($uri, 0, $pos); } $uri = trim($uri); return preg_match("#(?:/|2f|^|\\\\|5c)(?:(?:%0*(25)*2e)|\\.){2,}(?:/|%0*(25)*2f|\\\\|%0*(25)*5c|$)#i", $uri) ? true : false; } $newUri = preg_replace('#(pagen[\d]+/)#is', '', $_SERVER['REQUEST_URI']); if (!__isPathTraversalUri($newUri)) { $_SERVER['REQUEST_URI'] = $newUri; }
Универсальный .htaccess для всех 301 редиректов сразу — http на https, www на без www и т.д.
Чисто памятка для универсального .htaccess для всех редиректов сразу — http на https, www на без www, со слешем, без слеша, с поддоменов одного домена на поддомены другого и т.д.
Используется на на сайтах на Битриксе, в целом, должен работать и на любых других.
Options -Indexes ErrorDocument 404 /404.php RewriteEngine On RewriteCond %{SERVER_PORT} 80 RewriteRule ^(.*)$ https://site.ru/$1 [R=301,L] #ROBOTS.TXT RewriteCond %{HTTPS} off RewriteCond %{HTTP:X-Forwarded-Proto} !https RewriteCond %{REQUEST_URI} !robots.txt RewriteRule ^(.*)$ https://site.ru/$1 [R=301,L] #DOMAIN AND SUBDOMAIN REDIRECTION RewriteBase / RewriteCond %{HTTP_HOST} !^(www\.)?old-site\.ru$ RewriteCond %{HTTP_HOST} ^(.+)\.old-site\.ru$ RewriteRule (.*) https://%1.new-site.ru/$1 [R=301,L] RewriteCond %{HTTP_HOST} ^old-site.ru$ [NC] RewriteRule ^(.*)$ https://new-site.ru/$1 [R=301,L] RewriteCond %{SERVER_PORT} !^443$ RewriteRule .* https://%{SERVER_NAME}%{REQUEST_URI} [L,R=301] #one-to-301-wo-www-and-slash RewriteCond %{REQUEST_URI} !\? RewriteCond %{REQUEST_URI} !\& RewriteCond %{REQUEST_URI} !\= RewriteCond %{REQUEST_URI} !\. RewriteCond %{REQUEST_URI} !\/$ RewriteCond %{HTTP_HOST} ^www\.(.*)$ RewriteRule ^(.*)$ https://%1/$1/ [L,R=301] RewriteCond %{REQUEST_URI} !\? RewriteCond %{REQUEST_URI} !\& RewriteCond %{REQUEST_URI} !\= RewriteCond %{REQUEST_URI} !\. RewriteCond %{REQUEST_URI} ![^\/]$ RewriteCond %{HTTP_HOST} ^www\.(.*)$ RewriteRule ^(.*)$ https://%1/$1 [L,R=301] RewriteCond %{REQUEST_URI} !\? RewriteCond %{REQUEST_URI} !\& RewriteCond %{REQUEST_URI} !\= RewriteCond %{REQUEST_URI} !\. RewriteCond %{REQUEST_URI} !\/$ RewriteCond %{HTTP_HOST} ^([^www].*)$ RewriteRule ^(.*)$ https://%1/$1/ [L,R=301] RewriteCond %{REQUEST_URI} !\& RewriteCond %{REQUEST_URI} !\= RewriteCond %{REQUEST_URI} !\. RewriteCond %{REQUEST_URI} !\/$ RewriteCond %{HTTP_HOST} ^([^www].*)$ RewriteRule ^(.*)$ https://%1/$1/ [L,R=301] #RewriteCond %{HTTPS} =off #RewriteRule (.*) https://%{HTTP_HOST}%{REQUEST_URI} [QSA,L] php_flag session.use_trans_sid off #php_flag default_charset UTF-8 #php_value display_errors 1 php_flag session.use_trans_sid off php_flag default_charset UTF-8 #php_value display_errors 1 Options +FollowSymLinks RewriteEngine On RewriteCond %{REQUEST_FILENAME} !-f RewriteCond %{REQUEST_FILENAME} !-l RewriteCond %{REQUEST_FILENAME} !-d RewriteCond %{REQUEST_FILENAME} !/bitrix/urlrewrite.php$ RewriteRule ^(.*)$ /bitrix/urlrewrite.php [L] RewriteRule .* - [E=REMOTE_USER:%{HTTP:Authorization}] DirectoryIndex index.php index.html ExpiresActive on ExpiresByType image/jpeg "access plus 3 day" ExpiresByType image/gif "access plus 3 day" ExpiresByType image/png "access plus 3 day" ExpiresByType text/css "access plus 3 day" ExpiresByType application/javascript "access plus 3 day"
Убрать index.php (при .html — заменить .php в записи) в конце адреса
# remove index.php from the end of URI RewriteEngine On RewriteRule ^index\.php$ / [R=301,L] RewriteRule ^(.*)/index\.php$ /$1/ [R=301,L]
Редирект GET параметров
Например, сделать редирект со страницы /?act=page&id=2 на /page-2/
RewriteCond %{QUERY_STRING} act=page [NC] RewriteCond %{QUERY_STRING} id=(\d+) [NC] RewriteRule .* /page/%1/? [R=301,L]]
Как убрать все get запросы htaccess redirect
RewriteRule ^(.*)$ /$1? [R=301,L]
Настройка таких редиректов бывает необходимо после заражения сайта вирусами, когда идет очень много обращений к страницам файла с GET запросами.
Однако если административная панель сайта использует GET запросы, необходимо исключить из этой конструкции папку административной панели сайта, и переделать ее в следующий вид:
RewriteCond %{REQUEST_URI} !^/admin/
RewriteCond %{QUERY_STRING} ^(.+) [NC]
RewriteRule ^(.*)$ /$1? [R=301,L]