[wp-trac] [WordPress Trac] #63162: Sanitizing styles doesn't work as expected in presence of semi-colon(; ) in CSS value

WordPress Trac noreply at wordpress.org
Tue Mar 25 12:06:51 UTC 2025


#63162: Sanitizing styles doesn't work as expected in presence of semi-colon(;) in
CSS value
--------------------------+-----------------------------
 Reporter:  karthikeya01  |      Owner:  (none)
     Type:  defect (bug)  |     Status:  new
 Priority:  normal        |  Milestone:  Awaiting Review
Component:  General       |    Version:
 Severity:  normal        |   Keywords:
  Focuses:                |
--------------------------+-----------------------------
 When looking into the issue created in the Gutenberg repo
 [https://github.com/WordPress/gutenberg/issues/69574] found that the
 presence of semicolon in CSS value doesn't split the inline-styles as
 expected when sanitizing the styles.

 See
 https://github.com/WordPress/wordpress-
 develop/blob/804ca756b1434e7dc4ce9a357ce3cb3846552d7c/src/wp-
 includes/kses.php#L2375-L2386

 In the issue #69574 of Gutenberg the plugin adds the style

 {{{
 background-image:
 url(
 uNTMtLjUyLTEuMjItLjI0LTEuMjItLjI0LS42MS4zLTUuNzYgMy40Ny03LjY3IDUuNTctLjg2Ljk2LTIuMDYgMy43OS0xLjA5IDQuODIuOTIgLjk4IDMuOTYtLjE3IDQuNzktMSAyLjA2LTIuMDYgNS4yMS03LjE3IDUuNS03Ljc5ek0zLjUzNSAxOS44NGMyLjM3LTEuNTYgMS40Ni0zLjQxIDMuMjMtNC42NC45My0uNjUgMi4yMi0uNjIgMy4wOC4yOSAuNjMuNjcgLjggMi41Ny0uMTYgMy40Ni0xLjU3IDEuNDUtNCAxLjU1LTYuMTUuODl6Ij48L3BhdGg+PC9zeW1ib2w+PHVzZSBocmVmPSIjcGF0aDVlNjY4MWE1LTFiMTMtNDZiMS05YjI5LWEyNzU0Nzk0NGExOSI+PC91c2U+PC9zdmc+),
 url();

 }}}


 Which in the frontend (after sanitization) results in


 {{{
 background-image: url('data:image/svg+xml;
 }}}


 In ideal case it should not add the backgroud-image style as `data`
 protocol isn't allowed by default in WP. If the protocol is allowed with
 the filter


 {{{
 add_filter( 'kses_allowed_protocols', function ( $protocols ) {
         return array_merge( $protocols, array( 'data' ) );
 } );
 }}}


 it should render properly but results in the same output


 {{{
 background-image: url('data:image/svg+xml;
 }}}

-- 
Ticket URL: <https://core.trac.wordpress.org/ticket/63162>
WordPress Trac <https://core.trac.wordpress.org/>
WordPress publishing platform


More information about the wp-trac mailing list