mirror of
https://github.com/ezyang/htmlpurifier.git
synced 2024-11-14 17:28:40 +00:00
d3abcb90e3
The new logic is as follows: * Given a URL to insert into url(), check that it is properly URL encoded (in particular, a doublequote and backslash never occurs within it) and then place it as url("http://example.com"). * Given a font name, if it is strictly alphanumeric, it is safe to omit quotes. Otherwise, wrap in double quotes and replace '"' with '\22 ' (note trailing space) and '\' with '\5C ' (ditto). We introduce expandCSSEscape() which is a hack for common parsing idioms in CSS; this means that CSS escapes are now recognized inside URLs as well as unquoted font names. Signed-off-by: Edward Z. Yang <ezyang@mit.edu>
30 lines
893 B
PHP
30 lines
893 B
PHP
<?php
|
|
|
|
class HTMLPurifier_AttrDef_CSS_URITest extends HTMLPurifier_AttrDefHarness
|
|
{
|
|
|
|
function test() {
|
|
|
|
$this->def = new HTMLPurifier_AttrDef_CSS_URI();
|
|
|
|
$this->assertDef('', false);
|
|
|
|
// we could be nice but we won't be
|
|
$this->assertDef('http://www.example.com/', false);
|
|
|
|
$this->assertDef('url(', false);
|
|
$this->assertDef('url("")', true);
|
|
$result = 'url("http://www.example.com/")';
|
|
$this->assertDef('url(http://www.example.com/)', $result);
|
|
$this->assertDef('url("http://www.example.com/")', $result);
|
|
$this->assertDef("url('http://www.example.com/')", $result);
|
|
$this->assertDef(
|
|
' url( "http://www.example.com/" ) ', $result);
|
|
$this->assertDef("url(http://www.example.com/foo,bar\))",
|
|
'url("http://www.example.com/foo,bar)")');
|
|
}
|
|
|
|
}
|
|
|
|
// vim: et sw=4 sts=4
|