Defenses: The filter runs in a loop until no more changes occur. Strips: <script>, event handlers (on*=), javascript:, alert, eval, prompt, confirm, Function. Nesting tricks won't work here.
The filter loops until clean. No nesting tricks, no keyword games. Think outside the box.