Hi all!
what's the best way to get around the same original policy to fetch data from the toolserver with a XMLHTTPRequest in a Wikipedia gadget? Is there a best practice, a nice and easy, generally usable method? what would it take to make one?
I know that some gadgets have been doing this, but I also know that it's a bit tricky. I think a general solution to this, documented somewhere, would make life a lot easier... does something like this exist? if not, why not?
-- daniel
PS: while i'm at it, is there a wrapper function for XMLHTTPRequest in the standard MEdiaWiki JS? I don't want to re-invent a sucky wheel :)
On Tue, Feb 1, 2011 at 10:06 AM, Daniel Kinzler daniel@brightbyte.dewrote:
Hi all!
what's the best way to get around the same original policy to fetch data from the toolserver with a XMLHTTPRequest in a Wikipedia gadget? Is there a best practice, a nice and easy, generally usable method? what would it take to make one?
Easiest? Make an endpoint that returns data as JSONP (with a callback); these can be loaded via <script> tags to get around same-origin policy, but won't return good error information if a request fails. Best? Maybe output appropriate CORS headers: http://www.w3.org/TR/cors/
PS: while i'm at it, is there a wrapper function for XMLHTTPRequest in the standard MEdiaWiki JS? I don't want to re-invent a sucky wheel :)
jQuery is your friend. :) For the live sites I think you still have to manually include it, but once 1.17 hits jQuery itself will be standard all the time. You can use $.ajax or its simpler alias $.get.
[With the CORS headers, ISTR that IE 8 requires using a funny alternate XHR class for cross-domain requests (XCrossDomainRequest or something cleverly named -- this is Microsoft ;). I'm not sure offhand if jQuery can abstract that bit for you.]
-- brion
Use jQuery.ajax (or it's wrapper functions such as jQuery.getJSON) to cover all cross-browser issues.
And as indirectly suggested above. JSONP is the solution for cross- domain scripting. What it means is that that source (in this case toolserver) has a URL parameter (say &callback=), the script then returns the folllowing:
callback({ my: 'data' });
This is the exception / work-around to same origin policiy as it can be done through a simple script tag because there is a callback. This callback function can be dynamic and generated on the fly with jQuery by using a ? as callback
Example:
http://toolserver.org/~krinkle/tmp/jsonp_example.php?callback=myFunc
jQuery.getJSON( 'http://toolserver.org/~krinkle/tmp/jsonp_example.php?callback= ?', function(data){ alert(data.hello); } );
Op 1 feb 2011, om 19:06 heeft Daniel Kinzler het volgende geschreven:
Hi all!
what's the best way to get around the same original policy to fetch data from the toolserver with a XMLHTTPRequest in a Wikipedia gadget? Is there a best practice, a nice and easy, generally usable method? what would it take to make one?
I know that some gadgets have been doing this, but I also know that it's a bit tricky. I think a general solution to this, documented somewhere, would make life a lot easier... does something like this exist? if not, why not?
-- daniel
PS: while i'm at it, is there a wrapper function for XMLHTTPRequest in the standard MEdiaWiki JS? I don't want to re-invent a sucky wheel :)
Toolserver-l mailing list (Toolserver-l@lists.wikimedia.org) https://lists.wikimedia.org/mailman/listinfo/toolserver-l Posting guidelines for this list: https://wiki.toolserver.org/view/Mailing_list_etiquette
wikitech-l@lists.wikimedia.org