午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術(shù)文章
文章詳情頁

隱秘的“腳本錯誤”在Chrome和Firefox中以Javascript報告

瀏覽:165日期:2024-05-10 10:26:48
(adsbygoogle = window.adsbygoogle || []).push({}); 如何解決隱秘的“腳本錯誤”在Chrome和Firefox中以Javascript報告?

“腳本錯誤”。當異常違反了瀏覽器的同源策略時,即在錯誤發(fā)生在Firefox,Safari和Chrome中時,即當錯誤發(fā)生在托管于當前頁面域之外的域中的腳本中時。

此行為是有意的,以防止腳本將信息泄漏到外部域。有關為何有此必要的示例,請想象一下意外訪問evilsite.com,其中包含的頁面<scriptsrc='yourbank.com/index.html'>。(是的,我們將腳本標記指向html而不是JS)。這將導致腳本錯誤,但是該錯誤很有趣,因為它可以告訴我們是否已登錄。如果您已登錄,則錯誤可能是’WelcomeFred...’ is undefined,而如果您未登錄,則可能是’Please Login ...’ is undefined。遵循這些原則。

如果evilsite.com是針對排名前20位的銀行機構(gòu)這樣做的,那么他們會非常了解您訪問的銀行站點,并且可以提供更具針對性的網(wǎng)絡釣魚頁面。(當然,這只是一個例子。但是它說明了為什么瀏覽器不應允許任何 數(shù)據(jù)跨越域邊界。)

我已經(jīng)在Safari,Chrome和Firefox的最新版本中對此進行了測試-他們都這樣做。IE9不會-它將x起源異常與同起源異常相同。(而且Opera不支持onerror。)

從馬口說起:在將異常傳遞給onerror()時檢查來源的WebKit源。并檢查Firefox源。

:跟蹤此問題的Firefox錯誤包括指向啟發(fā)此行為的博客文章的鏈接。

:現(xiàn)在,您可以通過在腳本標簽上指定crossorigin屬性,并讓服務器發(fā)送適當?shù)腃ORS HTTP響應標頭,在某些瀏覽器上啟用完整的跨域錯誤報告。

解決方法

我有一個腳本,該腳本可以在我的網(wǎng)站上檢測Javascript錯誤并將其發(fā)送到我的后端進行報告。它報告遇到的第一個錯誤,假定的行號和時間。

編輯以包含doctype:

<!DOCTYPE html PUBLIC '-//W3C//DTD XHTML 1.0 Transitional//EN' 'http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd'><html xmlns='http://www.w3.org/1999/xhtml' xml:lang='en' lang='en' xmlns:fb='http://www.facebook.com/2008/fbml'>

<script type='text/javascript'>//<![CDATA[// for debugging javascript!(function(window){ window.onerror = function(msg,url,ln) {//transform errorsif (typeof(msg) === ’object’ && msg.srcElement && msg.target) { if(msg.srcElement == ’[object HTMLScriptElement]’ && msg.target == ’[object HTMLScriptElement]’){msg = ’Error loading script’; }else{msg = ’Event Error - target:’ + msg.target + ’ srcElement:’ + msg.srcElement; }}msg = msg.toString();//ignore errorsif(msg.indexOf('Location.toString') > -1){ return;}if(msg.indexOf('Error loading script') > -1){ return;}//report errorswindow.onerror = function(){};(new Image()).src = 'http://www.leifengta.com.cn/jserror.php?msg=' + encodeURIComponent(msg) + '&url=' + encodeURIComponent(url || document.location.toString().replace(/#.*$/,'')) + '&ln=' + parseInt(ln || 0) + '&r=' + (+new Date()); };})(window);//]]></script>

由于有了這個腳本,我很清楚自己的網(wǎng)站上發(fā)生的任何JavaScript錯誤。 最大的違規(guī)者之一是“腳本錯誤”。 在Chrome10以上版本和Firefox 3以上版本中, 位于第0行 。此錯誤在Internet Explorer中不存在(或可能稱為其他錯誤?)。

更正(5/23/2013):現(xiàn)在,此“腳本錯誤,第0行”錯誤正在IE7和其他版本的IE中顯示。可能是由于最近的IE安全修補程序引起的,因為以前沒有此行為。

有誰知道這個錯誤是什么意思或者是什么原因?qū)е碌模克l(fā)生在我的總頁面加載量的0.25%左右,占報告的錯誤的一半。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 性生活免费观看视频 | 欧美亚洲日本国产 | 中文字幕日本 | 久久国产免费观看 | 日韩欧美精品在线 | 亚洲福利影院 | 狠狠插狠狠插 | 国产精品伊人久久 | 欧美另类一区二区 | 日韩字幕在线观看 | 亚洲国产经典 | 久久久精品网 | 欧美成人午夜免费视在线看片 | 免费在线你懂的 | 自拍毛片 | 性一交一乱一乱一视频 | 精品一区二三区 | 五月婷婷视频在线观看 | 天天插天天 | 国产传媒一区二区 | 在线中文字幕第一页 | 久久午夜剧场 | 丁香激情网 | 五月激情婷婷丁香 | 久久免费看 | 国产精品色在线 | 日韩啊啊啊 | 激情五月色婷婷 | 97在线免费视频 | 成人视屏在线观看 | 国产欧美日产 | 精品久久久久久久久久久久久 | 99热这里只有精品首页 | 国产69精品久久久久久久久久 | 久久精品夜色噜噜亚洲a∨ 极品av在线 | 国产成人免费视频 | 在线超碰| 国产黄色免费观看 | 欧美激情一区 | 在线观看国产黄色 | 欧美有码在线 |