TinyMCE:
- Go back to encoding the editor content only when TinyMCE is used. - Add check and encode `</textarea>` if present. See #32425. git-svn-id: https://develop.svn.wordpress.org/trunk@33187 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
9f3cf9026d
commit
698faf3b17
@ -251,6 +251,11 @@ final class _WP_Editors {
|
||||
'<textarea' . $editor_class . $height . $tabindex . $autocomplete . ' cols="40" name="' . esc_attr( $set['textarea_name'] ) . '" ' .
|
||||
'id="' . $editor_id_attr . '">%s</textarea></div>' );
|
||||
|
||||
// Prepare the content for the Visual or Text editor
|
||||
if ( self::$this_tinymce ) {
|
||||
add_filter( 'the_editor_content', 'format_for_editor', 10, 2 );
|
||||
}
|
||||
|
||||
/**
|
||||
* Filter the default editor content.
|
||||
*
|
||||
@ -270,6 +275,10 @@ final class _WP_Editors {
|
||||
$content = apply_filters( 'richedit_pre', $content );
|
||||
}
|
||||
|
||||
if ( false !== stripos( $content, 'textarea' ) ) {
|
||||
$content = preg_replace( '%</textarea%i', '</textarea', $content );
|
||||
}
|
||||
|
||||
printf( $the_editor, $content );
|
||||
echo "\n</div>\n\n";
|
||||
|
||||
|
@ -203,9 +203,6 @@ add_filter( 'title_save_pre', 'trim' );
|
||||
|
||||
add_filter( 'http_request_host_is_external', 'allowed_http_request_hosts', 10, 2 );
|
||||
|
||||
// Prepare the content for the Visual or Text editor
|
||||
add_filter( 'the_editor_content', 'format_for_editor', 10, 2 );
|
||||
|
||||
// Actions
|
||||
add_action( 'wp_head', '_wp_render_title_tag', 1 );
|
||||
add_action( 'wp_head', 'wp_enqueue_scripts', 1 );
|
||||
|
@ -3087,10 +3087,7 @@ function ent2ncr( $text ) {
|
||||
* @return string The formatted text after filter is applied.
|
||||
*/
|
||||
function format_for_editor( $text, $default_editor = null ) {
|
||||
// Back-compat: check if any characters need encoding.
|
||||
if ( ! empty( $text ) && ( false !== strpos( $text, '<' ) || false !== strpos( $text, '>' ) ||
|
||||
preg_match( '/&(?!#(?:\d+|x[a-f0-9]+);|[a-z1-4]{1,8};)/i', $text ) ) ) {
|
||||
|
||||
if ( $text ) {
|
||||
$text = htmlspecialchars( $text, ENT_NOQUOTES, get_option( 'blog_charset' ) );
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user