<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://wiki.whatwg.org/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Jabley</id>
	<title>WHATWG Wiki - User contributions [en]</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.whatwg.org/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Jabley"/>
	<link rel="alternate" type="text/html" href="https://wiki.whatwg.org/wiki/Special:Contributions/Jabley"/>
	<updated>2026-04-05T17:38:54Z</updated>
	<subtitle>User contributions</subtitle>
	<generator>MediaWiki 1.39.3</generator>
	<entry>
		<id>https://wiki.whatwg.org/index.php?title=Sanitization_rules&amp;diff=2394</id>
		<title>Sanitization rules</title>
		<link rel="alternate" type="text/html" href="https://wiki.whatwg.org/index.php?title=Sanitization_rules&amp;diff=2394"/>
		<updated>2007-08-07T19:32:40Z</updated>

		<summary type="html">&lt;p&gt;Jabley: /* URI protocols */ Added wtai and tel protocols, on the presumption that phones will be capable of viewing html5&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;This page was initially seeded with the sanitization lists and rules implemented by the [http://code.google.com/p/html5lib/ html5lib] sanitizer, which in turn was based on [http://golem.ph.utexas.edu/instiki/show/HomePage Jacques Distler&#039;s branch of Instiki], which in turn was based on the sanitization logic in the [http://www.feedparser.org/ Universal Feed Parser].&lt;br /&gt;
&lt;br /&gt;
It is hoped that others will add, update, and extend this list based on their experiences in their own products, and furthermore that some will update their products based on these lists.&lt;br /&gt;
&lt;br /&gt;
As a suggestion but not as a requirement: people who do update their products to reflect information from this list are encouraged to add a link to this page as a comment in the hopes that it will encourage subsequent maintainers to keep this page up to date.&lt;br /&gt;
&lt;br /&gt;
=== Acceptable Elements ===&lt;br /&gt;
&lt;br /&gt;
* a&lt;br /&gt;
* abbr&lt;br /&gt;
* acronym&lt;br /&gt;
* address&lt;br /&gt;
* area&lt;br /&gt;
* b&lt;br /&gt;
* big&lt;br /&gt;
* blockquote&lt;br /&gt;
* br&lt;br /&gt;
* button&lt;br /&gt;
* caption&lt;br /&gt;
* center&lt;br /&gt;
* cite&lt;br /&gt;
* code&lt;br /&gt;
* col&lt;br /&gt;
* colgroup&lt;br /&gt;
* dd&lt;br /&gt;
* del&lt;br /&gt;
* dfn&lt;br /&gt;
* dir&lt;br /&gt;
* div&lt;br /&gt;
* dl&lt;br /&gt;
* dt&lt;br /&gt;
* em&lt;br /&gt;
* fieldset&lt;br /&gt;
* font&lt;br /&gt;
* form&lt;br /&gt;
* h1&lt;br /&gt;
* h2&lt;br /&gt;
* h3&lt;br /&gt;
* h4&lt;br /&gt;
* h5&lt;br /&gt;
* h6&lt;br /&gt;
* hr&lt;br /&gt;
* i&lt;br /&gt;
* img&lt;br /&gt;
* input&lt;br /&gt;
* ins&lt;br /&gt;
* kbd&lt;br /&gt;
* label&lt;br /&gt;
* legend&lt;br /&gt;
* li&lt;br /&gt;
* map&lt;br /&gt;
* menu&lt;br /&gt;
* ol&lt;br /&gt;
* optgroup&lt;br /&gt;
* option&lt;br /&gt;
* p&lt;br /&gt;
* pre&lt;br /&gt;
* q&lt;br /&gt;
* s&lt;br /&gt;
* samp&lt;br /&gt;
* select&lt;br /&gt;
* small&lt;br /&gt;
* span&lt;br /&gt;
* strike&lt;br /&gt;
* strong&lt;br /&gt;
* sub&lt;br /&gt;
* sup&lt;br /&gt;
* table&lt;br /&gt;
* tbody&lt;br /&gt;
* td&lt;br /&gt;
* textarea&lt;br /&gt;
* tfoot&lt;br /&gt;
* th&lt;br /&gt;
* thead&lt;br /&gt;
* tr&lt;br /&gt;
* tt&lt;br /&gt;
* u&lt;br /&gt;
* ul&lt;br /&gt;
* var&lt;br /&gt;
&lt;br /&gt;
==== mathml Elements ====&lt;br /&gt;
&lt;br /&gt;
* maction&lt;br /&gt;
* math&lt;br /&gt;
* merror&lt;br /&gt;
* mfrac&lt;br /&gt;
* mi&lt;br /&gt;
* mmultiscripts&lt;br /&gt;
* mn&lt;br /&gt;
* mo&lt;br /&gt;
* mover&lt;br /&gt;
* mpadded&lt;br /&gt;
* mphantom&lt;br /&gt;
* mprescripts&lt;br /&gt;
* mroot&lt;br /&gt;
* mrow&lt;br /&gt;
* mspace&lt;br /&gt;
* msqrt&lt;br /&gt;
* mstyle&lt;br /&gt;
* msub&lt;br /&gt;
* msubsup&lt;br /&gt;
* msup&lt;br /&gt;
* mtable&lt;br /&gt;
* mtd&lt;br /&gt;
* mtext&lt;br /&gt;
* mtr&lt;br /&gt;
* munder&lt;br /&gt;
* munderover&lt;br /&gt;
* none&lt;br /&gt;
&lt;br /&gt;
==== svg Elements ====&lt;br /&gt;
&lt;br /&gt;
* a&lt;br /&gt;
* animate&lt;br /&gt;
* animateColor&lt;br /&gt;
* animateMotion&lt;br /&gt;
* animateTransform&lt;br /&gt;
* circle&lt;br /&gt;
* defs&lt;br /&gt;
* desc&lt;br /&gt;
* ellipse&lt;br /&gt;
* font-face&lt;br /&gt;
* font-face-name&lt;br /&gt;
* font-face-src&lt;br /&gt;
* g&lt;br /&gt;
* glyph&lt;br /&gt;
* hkern&lt;br /&gt;
* image&lt;br /&gt;
* linearGradient&lt;br /&gt;
* line&lt;br /&gt;
* marker&lt;br /&gt;
* metadata&lt;br /&gt;
* missing-glyph&lt;br /&gt;
* mpath&lt;br /&gt;
* path&lt;br /&gt;
* polygon&lt;br /&gt;
* polyline&lt;br /&gt;
* radialGradient&lt;br /&gt;
* rect&lt;br /&gt;
* set&lt;br /&gt;
* stop&lt;br /&gt;
* svg&lt;br /&gt;
* switch&lt;br /&gt;
* text&lt;br /&gt;
* title&lt;br /&gt;
* tspan&lt;br /&gt;
* use&lt;br /&gt;
&lt;br /&gt;
=== Acceptable Attributes ===&lt;br /&gt;
&lt;br /&gt;
* abbr&lt;br /&gt;
* accept&lt;br /&gt;
* accept-charset&lt;br /&gt;
* accesskey&lt;br /&gt;
* action&lt;br /&gt;
* align&lt;br /&gt;
* alt&lt;br /&gt;
* axis&lt;br /&gt;
* border&lt;br /&gt;
* cellpadding&lt;br /&gt;
* cellspacing&lt;br /&gt;
* char&lt;br /&gt;
* charoff&lt;br /&gt;
* charset&lt;br /&gt;
* checked&lt;br /&gt;
* cite&lt;br /&gt;
* class&lt;br /&gt;
* clear&lt;br /&gt;
* cols&lt;br /&gt;
* colspan&lt;br /&gt;
* color&lt;br /&gt;
* compact&lt;br /&gt;
* coords&lt;br /&gt;
* datetime&lt;br /&gt;
* dir&lt;br /&gt;
* disabled&lt;br /&gt;
* enctype&lt;br /&gt;
* for&lt;br /&gt;
* frame&lt;br /&gt;
* headers&lt;br /&gt;
* height&lt;br /&gt;
* href&lt;br /&gt;
* hreflang&lt;br /&gt;
* hspace&lt;br /&gt;
* id&lt;br /&gt;
* ismap&lt;br /&gt;
* label&lt;br /&gt;
* lang&lt;br /&gt;
* longdesc&lt;br /&gt;
* maxlength&lt;br /&gt;
* media&lt;br /&gt;
* method&lt;br /&gt;
* multiple&lt;br /&gt;
* name&lt;br /&gt;
* nohref&lt;br /&gt;
* noshade&lt;br /&gt;
* nowrap&lt;br /&gt;
* prompt&lt;br /&gt;
* readonly&lt;br /&gt;
* rel&lt;br /&gt;
* rev&lt;br /&gt;
* rows&lt;br /&gt;
* rowspan&lt;br /&gt;
* rules&lt;br /&gt;
* scope&lt;br /&gt;
* selected&lt;br /&gt;
* shape&lt;br /&gt;
* size&lt;br /&gt;
* span&lt;br /&gt;
* src&lt;br /&gt;
* start&lt;br /&gt;
* style&lt;br /&gt;
* summary&lt;br /&gt;
* tabindex&lt;br /&gt;
* target&lt;br /&gt;
* title&lt;br /&gt;
* type&lt;br /&gt;
* usemap&lt;br /&gt;
* valign&lt;br /&gt;
* value&lt;br /&gt;
* vspace&lt;br /&gt;
* width&lt;br /&gt;
* xml:lang&lt;br /&gt;
&lt;br /&gt;
==== mathml Attributes ====&lt;br /&gt;
&lt;br /&gt;
* actiontype&lt;br /&gt;
* align&lt;br /&gt;
* columnalign&lt;br /&gt;
* columnalign&lt;br /&gt;
* columnalign&lt;br /&gt;
* columnlines&lt;br /&gt;
* columnspacing&lt;br /&gt;
* columnspan&lt;br /&gt;
* depth&lt;br /&gt;
* display&lt;br /&gt;
* displaystyle&lt;br /&gt;
* equalcolumns&lt;br /&gt;
* equalrows&lt;br /&gt;
* fence&lt;br /&gt;
* fontstyle&lt;br /&gt;
* fontweight&lt;br /&gt;
* frame&lt;br /&gt;
* height&lt;br /&gt;
* linethickness&lt;br /&gt;
* lspace&lt;br /&gt;
* mathbackground&lt;br /&gt;
* mathcolor&lt;br /&gt;
* mathvariant&lt;br /&gt;
* mathvariant&lt;br /&gt;
* maxsize&lt;br /&gt;
* minsize&lt;br /&gt;
* other&lt;br /&gt;
* rowalign&lt;br /&gt;
* rowalign&lt;br /&gt;
* rowalign&lt;br /&gt;
* rowlines&lt;br /&gt;
* rowspacing&lt;br /&gt;
* rowspan&lt;br /&gt;
* rspace&lt;br /&gt;
* scriptlevel&lt;br /&gt;
* selection&lt;br /&gt;
* separator&lt;br /&gt;
* stretchy&lt;br /&gt;
* width&lt;br /&gt;
* width&lt;br /&gt;
* xlink:href&lt;br /&gt;
* xlink:show&lt;br /&gt;
* xlink:type&lt;br /&gt;
* xmlns&lt;br /&gt;
* xmlns:xlink&lt;br /&gt;
&lt;br /&gt;
==== svg Attributes ====&lt;br /&gt;
&lt;br /&gt;
* accent-height&lt;br /&gt;
* accumulate&lt;br /&gt;
* additive&lt;br /&gt;
* alphabetic&lt;br /&gt;
* arabic-form&lt;br /&gt;
* ascent&lt;br /&gt;
* attributeName&lt;br /&gt;
* attributeType&lt;br /&gt;
* baseProfile&lt;br /&gt;
* bbox&lt;br /&gt;
* begin&lt;br /&gt;
* by&lt;br /&gt;
* calcMode&lt;br /&gt;
* cap-height&lt;br /&gt;
* class&lt;br /&gt;
* color&lt;br /&gt;
* color-rendering&lt;br /&gt;
* content&lt;br /&gt;
* cx&lt;br /&gt;
* cy&lt;br /&gt;
* d&lt;br /&gt;
* dx&lt;br /&gt;
* dy&lt;br /&gt;
* descent&lt;br /&gt;
* display&lt;br /&gt;
* dur&lt;br /&gt;
* end&lt;br /&gt;
* fill&lt;br /&gt;
* fill-rule&lt;br /&gt;
* font-family&lt;br /&gt;
* font-size&lt;br /&gt;
* font-stretch&lt;br /&gt;
* font-style&lt;br /&gt;
* font-variant&lt;br /&gt;
* font-weight&lt;br /&gt;
* from&lt;br /&gt;
* fx&lt;br /&gt;
* fy&lt;br /&gt;
* g1&lt;br /&gt;
* g2&lt;br /&gt;
* glyph-name&lt;br /&gt;
* gradientUnits&lt;br /&gt;
* hanging&lt;br /&gt;
* height&lt;br /&gt;
* horiz-adv-x&lt;br /&gt;
* horiz-origin-x&lt;br /&gt;
* id&lt;br /&gt;
* ideographic&lt;br /&gt;
* k&lt;br /&gt;
* keyPoints&lt;br /&gt;
* keySplines&lt;br /&gt;
* keyTimes&lt;br /&gt;
* lang&lt;br /&gt;
* marker-end&lt;br /&gt;
* marker-mid&lt;br /&gt;
* marker-start&lt;br /&gt;
* markerHeight&lt;br /&gt;
* markerUnits&lt;br /&gt;
* markerWidth&lt;br /&gt;
* mathematical&lt;br /&gt;
* max&lt;br /&gt;
* min&lt;br /&gt;
* name&lt;br /&gt;
* offset&lt;br /&gt;
* opacity&lt;br /&gt;
* orient&lt;br /&gt;
* origin&lt;br /&gt;
* overline-position&lt;br /&gt;
* overline-thickness&lt;br /&gt;
* panose-1&lt;br /&gt;
* path&lt;br /&gt;
* pathLength&lt;br /&gt;
* points&lt;br /&gt;
* preserveAspectRatio&lt;br /&gt;
* r&lt;br /&gt;
* refX&lt;br /&gt;
* refY&lt;br /&gt;
* repeatCount&lt;br /&gt;
* repeatDur&lt;br /&gt;
* requiredExtensions&lt;br /&gt;
* requiredFeatures&lt;br /&gt;
* restart&lt;br /&gt;
* rotate&lt;br /&gt;
* rx&lt;br /&gt;
* ry&lt;br /&gt;
* slope&lt;br /&gt;
* stemh&lt;br /&gt;
* stemv&lt;br /&gt;
* stop-color&lt;br /&gt;
* stop-opacity&lt;br /&gt;
* strikethrough-position&lt;br /&gt;
* strikethrough-thickness&lt;br /&gt;
* stroke&lt;br /&gt;
* stroke-dasharray&lt;br /&gt;
* stroke-dashoffset&lt;br /&gt;
* stroke-linecap&lt;br /&gt;
* stroke-linejoin&lt;br /&gt;
* stroke-miterlimit&lt;br /&gt;
* stroke-opacity&lt;br /&gt;
* stroke-width&lt;br /&gt;
* systemLanguage&lt;br /&gt;
* target&lt;br /&gt;
* text-anchor&lt;br /&gt;
* to&lt;br /&gt;
* transform&lt;br /&gt;
* type&lt;br /&gt;
* u1&lt;br /&gt;
* u2&lt;br /&gt;
* underline-position&lt;br /&gt;
* underline-thickness&lt;br /&gt;
* unicode&lt;br /&gt;
* unicode-range&lt;br /&gt;
* units-per-em&lt;br /&gt;
* values&lt;br /&gt;
* version&lt;br /&gt;
* viewBox&lt;br /&gt;
* visibility&lt;br /&gt;
* width&lt;br /&gt;
* widths&lt;br /&gt;
* x&lt;br /&gt;
* x-height&lt;br /&gt;
* x1&lt;br /&gt;
* x2&lt;br /&gt;
* xlink:actuate&lt;br /&gt;
* xlink:arcrole&lt;br /&gt;
* xlink:href&lt;br /&gt;
* xlink:role&lt;br /&gt;
* xlink:show&lt;br /&gt;
* xlink:title&lt;br /&gt;
* xlink:type&lt;br /&gt;
* xml:base&lt;br /&gt;
* xml:lang&lt;br /&gt;
* xml:space&lt;br /&gt;
* xmlns&lt;br /&gt;
* xmlns:xlink&lt;br /&gt;
* y&lt;br /&gt;
* y1&lt;br /&gt;
* y2&lt;br /&gt;
* zoomAndPan&lt;br /&gt;
&lt;br /&gt;
=== CSS Rules ===&lt;br /&gt;
&lt;br /&gt;
First &amp;lt;code&amp;gt;urls&amp;lt;/code&amp;gt; matching the following regular expression are removed:&lt;br /&gt;
  &amp;lt;pre&amp;gt;url\s*\(\s*[^\s)]+?\s*\)\s*&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
The style strings that don&#039;t match the following are deemed obfuscated, and ignored entirely:&lt;br /&gt;
  &amp;lt;pre&amp;gt;^([:,;#%.\sa-zA-Z0-9!]|\w-\w|&#039;[\s\w]+&#039;|&amp;quot;[\s\w]+&amp;quot;|\([\d,\s]+\))*$&amp;lt;/pre&amp;gt;&lt;br /&gt;
  &amp;lt;pre&amp;gt;^(\s*[-\w]+\s*:\s*[^:;]*(;|$))*$&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==== style Properties ====&lt;br /&gt;
&lt;br /&gt;
* azimuth&lt;br /&gt;
* background-color&lt;br /&gt;
* border-bottom-color&lt;br /&gt;
* border-collapse&lt;br /&gt;
* border-color&lt;br /&gt;
* border-left-color&lt;br /&gt;
* border-right-color&lt;br /&gt;
* border-top-color&lt;br /&gt;
* clear&lt;br /&gt;
* color&lt;br /&gt;
* cursor&lt;br /&gt;
* direction&lt;br /&gt;
* display&lt;br /&gt;
* elevation&lt;br /&gt;
* float&lt;br /&gt;
* font&lt;br /&gt;
* font-family&lt;br /&gt;
* font-size&lt;br /&gt;
* font-style&lt;br /&gt;
* font-variant&lt;br /&gt;
* font-weight&lt;br /&gt;
* height&lt;br /&gt;
* letter-spacing&lt;br /&gt;
* line-height&lt;br /&gt;
* overflow&lt;br /&gt;
* pause&lt;br /&gt;
* pause-after&lt;br /&gt;
* pause-before&lt;br /&gt;
* pitch&lt;br /&gt;
* pitch-range&lt;br /&gt;
* richness&lt;br /&gt;
* speak&lt;br /&gt;
* speak-header&lt;br /&gt;
* speak-numeral&lt;br /&gt;
* speak-punctuation&lt;br /&gt;
* speech-rate&lt;br /&gt;
* stress&lt;br /&gt;
* text-align&lt;br /&gt;
* text-decoration&lt;br /&gt;
* text-indent&lt;br /&gt;
* unicode-bidi&lt;br /&gt;
* vertical-align&lt;br /&gt;
* voice-family&lt;br /&gt;
* volume&lt;br /&gt;
* white-space&lt;br /&gt;
* width&lt;br /&gt;
&lt;br /&gt;
==== style Property Values ====&lt;br /&gt;
&lt;br /&gt;
* auto&lt;br /&gt;
* aqua&lt;br /&gt;
* black&lt;br /&gt;
* block&lt;br /&gt;
* blue&lt;br /&gt;
* bold&lt;br /&gt;
* both&lt;br /&gt;
* bottom&lt;br /&gt;
* brown&lt;br /&gt;
* center&lt;br /&gt;
* collapse&lt;br /&gt;
* dashed&lt;br /&gt;
* dotted&lt;br /&gt;
* fuchsia&lt;br /&gt;
* gray&lt;br /&gt;
* green&lt;br /&gt;
* !important&lt;br /&gt;
* italic&lt;br /&gt;
* left&lt;br /&gt;
* lime&lt;br /&gt;
* maroon&lt;br /&gt;
* medium&lt;br /&gt;
* none&lt;br /&gt;
* navy&lt;br /&gt;
* normal&lt;br /&gt;
* nowrap&lt;br /&gt;
* olive&lt;br /&gt;
* pointer&lt;br /&gt;
* purple&lt;br /&gt;
* red&lt;br /&gt;
* right&lt;br /&gt;
* solid&lt;br /&gt;
* silver&lt;br /&gt;
* teal&lt;br /&gt;
* top&lt;br /&gt;
* transparent&lt;br /&gt;
* underline&lt;br /&gt;
* white&lt;br /&gt;
* yellow&lt;br /&gt;
&lt;br /&gt;
==== svg sytle Properties ====&lt;br /&gt;
&lt;br /&gt;
* fill&lt;br /&gt;
* fill-opacity&lt;br /&gt;
* fill-rule&lt;br /&gt;
* stroke&lt;br /&gt;
* stroke-width&lt;br /&gt;
* stroke-linecap&lt;br /&gt;
* stroke-linejoin&lt;br /&gt;
* stroke-opacity&lt;br /&gt;
&lt;br /&gt;
=== URIs ===&lt;br /&gt;
==== Attributes whose value is a URI ====&lt;br /&gt;
&lt;br /&gt;
* href&lt;br /&gt;
* src&lt;br /&gt;
* cite&lt;br /&gt;
* action&lt;br /&gt;
* longdesc&lt;br /&gt;
* xlink:href&lt;br /&gt;
* xml:base&lt;br /&gt;
&lt;br /&gt;
==== URI protocols ====&lt;br /&gt;
&lt;br /&gt;
* afs&lt;br /&gt;
* aim&lt;br /&gt;
* callto&lt;br /&gt;
* ed2k&lt;br /&gt;
* feed&lt;br /&gt;
* ftp&lt;br /&gt;
* gopher&lt;br /&gt;
* http&lt;br /&gt;
* https&lt;br /&gt;
* irc&lt;br /&gt;
* mailto&lt;br /&gt;
* news&lt;br /&gt;
* nntp&lt;br /&gt;
* rsync&lt;br /&gt;
* rtsp&lt;br /&gt;
* sftp&lt;br /&gt;
* ssh&lt;br /&gt;
* tag&lt;br /&gt;
* tel&lt;br /&gt;
* telnet&lt;br /&gt;
* urn&lt;br /&gt;
* webcal&lt;br /&gt;
* wtai&lt;br /&gt;
* xmpp&lt;/div&gt;</summary>
		<author><name>Jabley</name></author>
	</entry>
</feed>