From: Richard Gibson Date: Wed, 12 Dec 2018 16:21:24 +0000 (-0500) Subject: Manipulation: Only evaluate HTTP-successful script src X-Git-Tag: 3.4.0~28 X-Git-Url: https://source.dussan.org/?a=commitdiff_plain;h=c2026b117d1ca5b2e42a52c7e2a8ae8988cf0d4b;p=jquery.git Manipulation: Only evaluate HTTP-successful script src Fixes gh-4126 Closes gh-4243 --- diff --git a/src/manipulation/_evalUrl.js b/src/manipulation/_evalUrl.js index f9ec7027c..1ed033673 100644 --- a/src/manipulation/_evalUrl.js +++ b/src/manipulation/_evalUrl.js @@ -10,11 +10,16 @@ jQuery._evalUrl = function( url ) { // Make this explicit, since user can override this through ajaxSetup (#11264) type: "GET", - dataType: "script", + dataType: "text", cache: true, async: false, global: false, - "throws": true + "throws": true, + + // Only evaluate the response if it is successful (gh-4126) + success: function( text ) { + jQuery.globalEval( text ); + } } ); }; diff --git a/test/unit/manipulation.js b/test/unit/manipulation.js index ddb04c7d6..300add5ec 100644 --- a/test/unit/manipulation.js +++ b/test/unit/manipulation.js @@ -2818,3 +2818,20 @@ QUnit.test( "Insert script with data-URI (gh-1887)", 1, function( assert ) { done(); }, 100 ); } ); + +QUnit.test( "Ignore content from unsuccessful responses (gh-4126)", 1, function( assert ) { + var globalEval = jQuery.globalEval; + jQuery.globalEval = function( code ) { + assert.ok( false, "no attempt to evaluate code from an unsuccessful response" ); + }; + + try { + jQuery( "#qunit-fixture" ).append( + "