Ignore:
Timestamp:
10/06/10 12:00:56 (14 years ago)
Author:
alexandrecorreia
Message:

Ticket #986 - Tratado as mensagens com tags em html para evitar ataques de XSS.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • branches/2.2/jabberit_messenger/jmessenger/js/trophyim.js

    r3325 r3332  
    851851                        _text = _text.replace(/style/gi,"EVENT_DENY"); 
    852852 
     853                        // Tags HTML 
     854                        _text = _text.replace(/img /gi,"IMG_DENY "); 
     855                         
     856                        _text = _text.replace(/script /gi,"SCRIPT_DENY "); 
     857                         
     858                        _text = _text.replace(/div /gi,"DIV_DENY "); 
     859                         
     860                        _text = _text.replace(/span /gi,"SPAN_DENY "); 
     861                         
     862                        _text = _text.replace(/iframe /gi,"IFRAME_DENY "); 
     863                         
    853864                        _message.innerHTML = _text; 
    854865                         
    855866                        ////////// BEGIN XSS ////////////////////////////////////////////////// 
    856867                        // Delete Tags <SCRIPT> 
    857                         var scripts = _message.getElementsByTagName('script'); 
     868                        var scripts = _message.getElementsByTagName('script_deny'); 
    858869                        for (var i = 0; i < scripts.length; i++){ _message.removeChild(scripts[i--]); } 
    859870                        //////////////////////////////////////////////////// 
    860871                         
    861872                        // Delete Tags <IMG> 
    862                         var _imgSrc = _message.getElementsByTagName('img'); 
    863                         for (var i = 0; i < _imgSrc.length; i++){ _message.removeChild( _imgSrc[i--] ); } 
     873                        var _imgSrc = _message.getElementsByTagName('img_deny'); 
     874                        for (var i = 0; i < _imgSrc.length; i++){ _imgSrc[i].parentNode.removeChild( _imgSrc[i--] ); } 
    864875                        //////////////////////////////////////////////////// 
    865876                         
    866877                        // Delete Tags <DIV> 
    867                         var _Div = _message.getElementsByTagName('div'); 
    868                         for (var i = 0; i < _Div.length; i++){ _message.removeChild( _Div[i--] ); } 
     878                        var _Div = _message.getElementsByTagName('div_deny'); 
     879                        for (var i = 0; i < _Div.length; i++){ _Div[i].parentNode.removeChild( _Div[i--] ); } 
    869880                        //////////////////////////////////////////////////// 
    870881                         
    871882                        // Delete Tags <SPAN> 
    872                         var _Span = _message.getElementsByTagName('span'); 
    873                         for (var i = 0; i < _Span.length; i++){ _message.removeChild( _Span[i--] ); } 
     883                        var _Span = _message.getElementsByTagName('span_deny'); 
     884                        for (var i = 0; i < _Span.length; i++){ _Span[i].parentNode.removeChild( _Span[i--] ); } 
    874885                        //////////////////////////////////////////////////// 
    875886 
    876887                        // Delete Tags <IFRAME> 
    877                         var _Iframe = _message.getElementsByTagName('iframe'); 
    878                         for (var i = 0; i < _Iframe.length; i++){ _message.removeChild( _Iframe[i--] ); } 
     888                        var _Iframe = _message.getElementsByTagName('iframe_deny'); 
     889                        for (var i = 0; i < _Iframe.length; i++){ _Iframe[i].parentNode.removeChild( _Iframe[i--] ); } 
    879890 
    880891                        // Delete Tags <A HREF> 
    881892                        var _aHref = _message.getElementsByTagName('a'); 
    882                         for (var i = 0; i < _aHref.length; i++){ _message.removeChild( _aHref[i--] ); } 
    883  
     893                        for (var i = 0; i < _aHref.length; i++){ _aHref[i].parentNode.removeChild( _aHref[i--] ); } 
    884894                         
    885895                        _message.innerHTML = _message.innerHTML.replace(/^\s+|\s+$|^\n|\n$/g, ""); 
Note: See TracChangeset for help on using the changeset viewer.