View Single Post
  #7  
Old 05-17-2005, 03:54 AM
Zero Tolerance's Avatar
Zero Tolerance Zero Tolerance is offline
 
Join Date: Feb 2004
Location: England
Posts: 813
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

filburt1 - Yeah parsing it properly out is not a concern, in the end it will just check for invalid entries and throw an error then stopping the data from saving, so people know they can't use nasty stuff, and because it will save a lot of processing time instead of trying to strip out some guys billion injection attempts everytime the page with the data is loaded.

Here's the source for the file:
PHP Code:
<font face='verdana'>
The script will parse out:
<ul>
<li>Bad tags (script etc..)</li>
<li>& -> &amp;amp;</li>
<li>\n -> br tag</li>
<li>Generic javascript injection (javascript(s)?:)</li>
<li>Style javascript injection (expression(script here))</li>
<li>Tag Event javascript injection (onload='script')</li>
</ul>

<form action='self.php' method='post'>
Insert html code:</font>
<br />
<textarea name='html' cols='90' rows='8'></textarea>
<br />
<input type='submit' />
</form>

<?php

    
function stripBadTags($Code){
    
$BadTag[] = "script";
    
$BadTag[] = "iframe";
    
$BadTag[] = "object";
    
$BadTag[] = "applet";
    
$BadTag[] = "frame";
    
$BadTag[] = "frameset";
    
$BadTag[] = "param";
    
$BadTag[] = "style";

        foreach(
$BadTag as $bt){
        
$Code preg_replace("/(<{$bt}|{$bt}>)/i",'',$Code);
        }

    return 
$Code;
    }

    function 
ParseHTML($Code){
    
// Strip out unwanted tags
    
$Code stripBadTags($Code);
    
    
// Generic find & replace parameters, such as bad letters/characters

    
$str_replace_find = array(
            
'&',
            
"\n",
            );

    
$str_replace_replace = array(
            
'&amp;',
            
'<br />',
            );

    
// Generic Javascript injection into tags

    
$strip[] = array(
            
'find'    => '/(javascript(s)?|vbscript(s)?|java(s)?)/i',
            
'replace' => 'Active Scripting Disabled',
        );

    
// Style javascript injection

    
$strip[] = array(
            
'find'    => '/expression((.+?))?\((.+?)\)/i',
            
'replace' => '',
        );

    
// Tag event javascript injection

    
$strip[] = array(
            
'find'    => '/on[a-zA-Z](.+?)=(\'|")?(.+?[^\'"])(\'|")?/i',
            
'replace' => '',
        );

    
/*
    $strip[] = array(
            'find'    => '',
            'replace' => '',
        );
    */

    
$Code str_replace($str_replace_find,$str_replace_replace,$Code);

        foreach(
$strip as $rem){
            while(
preg_match($rem['find'],$Code)){
            
$Code preg_replace($rem['find'],$rem['replace'],$Code);
            }
        }

    return 
$Code;
    }

    if(@
trim($_POST['html']) != ''){
    echo 
ParseHTML(stripslashes($_POST['html']));
    }

?>


- Zero Tolerance
Reply With Quote
 
X vBulletin 3.8.12 by vBS Debug Information
  • Page Generation 0.01235 seconds
  • Memory Usage 1,807KB
  • Queries Executed 11 (?)
More Information
Template Usage:
  • (1)SHOWTHREAD_SHOWPOST
  • (1)ad_footer_end
  • (1)ad_footer_start
  • (1)ad_header_end
  • (1)ad_header_logo
  • (1)ad_navbar_below
  • (1)bbcode_php
  • (1)footer
  • (1)gobutton
  • (1)header
  • (1)headinclude
  • (6)option
  • (1)post_thanks_box
  • (1)post_thanks_button
  • (1)post_thanks_javascript
  • (1)post_thanks_navbar_search
  • (1)post_thanks_postbit_info
  • (1)postbit
  • (1)postbit_onlinestatus
  • (1)postbit_wrapper
  • (1)spacer_close
  • (1)spacer_open 

Phrase Groups Available:
  • global
  • postbit
  • reputationlevel
  • showthread
Included Files:
  • ./showpost.php
  • ./global.php
  • ./includes/init.php
  • ./includes/class_core.php
  • ./includes/config.php
  • ./includes/functions.php
  • ./includes/class_hook.php
  • ./includes/modsystem_functions.php
  • ./includes/functions_bigthree.php
  • ./includes/class_postbit.php
  • ./includes/class_bbcode.php
  • ./includes/functions_reputation.php
  • ./includes/functions_post_thanks.php 

Hooks Called:
  • init_startup
  • init_startup_session_setup_start
  • init_startup_session_setup_complete
  • cache_permissions
  • fetch_postinfo_query
  • fetch_postinfo
  • fetch_threadinfo_query
  • fetch_threadinfo
  • fetch_foruminfo
  • style_fetch
  • cache_templates
  • global_start
  • parse_templates
  • global_setup_complete
  • showpost_start
  • bbcode_fetch_tags
  • bbcode_create
  • postbit_factory
  • showpost_post
  • postbit_display_start
  • post_thanks_function_post_thanks_off_start
  • post_thanks_function_post_thanks_off_end
  • post_thanks_function_fetch_thanks_start
  • post_thanks_function_fetch_thanks_end
  • post_thanks_function_thanked_already_start
  • post_thanks_function_thanked_already_end
  • fetch_musername
  • postbit_imicons
  • bbcode_parse_start
  • bbcode_parse_complete_precache
  • bbcode_parse_complete
  • postbit_display_complete
  • post_thanks_function_can_thank_this_post_start
  • showpost_complete