Сохранение тегов SCRIPT (и более) в CKEditor
Можно ли создать блок кода внутри CKEditor, который не будет затронут самим редактором и будет поддерживаться в его предполагаемом состоянии до тех пор, пока пользователь не будет явно изменен пользователем? Я пытаюсь ввести переменные javascript (привязанные к тегам script) и следующий флеш-ролик, но CKEditor продолжает переписывать мой вставленный код/разметку и при этом разбивать мой код.
Я работаю со следующей настройкой:
<script type="text/javascript">
var editor = CKEDITOR.replace("content", {
height : "500px",
width : "680px",
resize_maxWidth : "680px",
resize_minWidth : "680px",
toolbar :
[
['Source','-','Save','Preview'],
['Cut','Copy','Paste','PasteText','PasteFromWord','-','Print', 'SpellChecker', 'Scayt'],
['Undo','Redo','-','Find','Replace','-','SelectAll','RemoveFormat'],
['Bold','Italic','Underline','Strike','-','Subscript','Superscript'],
['NumberedList','BulletedList','-','Outdent','Indent','Blockquote'],
['JustifyLeft','JustifyCenter','JustifyRight','JustifyBlock'],
['Link','Unlink','Anchor'],
['Image','Table','HorizontalRule','SpecialChar']
]
});
CKFinder.SetupCKEditor( editor, "<?php print url::base(); ?>assets/ckfinder" );
</script>
Я полагаю, что самым идеальным решением было бы сохранить содержимое любого тега, содержащего class="preserve"
, позволяющего гораздо больше, чем ограниченные эксклюзивы.
Обновление. Я думаю, что решение этой проблемы находится в CKEDITOR.config.protectedSource()
, но мой обычный -expression опыт оказывается слишком несовершеннолетним, чтобы справиться с этой проблемой. Как я могу исключить все теги, которые содержат "сохраненный" класс от касания CKEditor?
Ответы
Ответ 1
Проблема не с CKEditor. Вместо этого проблема заключалась в том, что MVC-Engine запускает сам сайт. Kohana имеет global_xss_filtering
в своей конфигурации, которая включена по умолчанию. Это предотвращает отправку тегов script, чтобы предотвратить атаки на вашем сайте. Изменение этого значения до false
позволит отправлять теги <script>
в формах, но также открывает сайт для потенциальных проблем безопасности, которые могут быть очень серьезными. Желательно, чтобы вы не отключили global_xss_filtering
.
/* /(system|application)/config/config.php - line 66 */
/**
* Enable or disable global XSS filtering of GET, POST, and SERVER data. This
* option also accepts a string to specify a specific XSS filtering tool.
*/
$config['global_xss_filtering'] = FALSE;
Ответ 2
Предложение 1: Создайте отдельный текстовый ящик для администратора, чтобы ввести скрипты/код HTML.
Предложение 2: Представьте bbcode, например [script][/script]
или [html][/html]
, которые администраторы могут использовать для размещения сценариев/кода HTML, и их серверная версия переводит их в <script></script>
и HTML-код. Убедитесь, что при показе сохраненного содержимого в CKEditor вам нужно сначала перевести их на серверный bbcode (или CKEditor отключит их). Или менее сложным способом является сохранение представленного содержимого в базе данных по мере его ввода и только перевод при отображении страницы.
Предложение 3. Поскольку вы хотите использовать class="preserve"
для отметки тэгов, вы не хотите, чтобы CKEditor отключился, добавьте следующие строки JavaScript при инициализации редактора:
// protect <anytag class="preserve"></anytag>
CKEDITOR.config.protectedSource.push( /<([\S]+)[^>]*class="preserve"[^>]*>.*<\/\1>/g );
// protect <anytag class="preserve" /><
CKEDITOR.config.protectedSource.push( /<[^>]+class="preserve"[^>\/]*\/>/g );
Ответ 3
В папке CKEDITOR есть файл config.js. Откройте его и вставьте код:
CKEDITOR.editorConfig = function( config ) {
config.allowedContent = {
script: true,
$1: {
// This will set the default set of elements
elements: CKEDITOR.dtd,
attributes: true,
styles: true,
classes: true
}
};
};
Это позволит тегам <script>...</script>
в режиме источника.