Why is cross-domain JSONP safe, but cross-domainJSON not?

前端 未结 2 744
庸人自扰
庸人自扰 2021-02-01 04:01

I\'m having trouble connecting some dots having recently learned of JSONP. Here\'s my understanding:

  • Cross-domain XmlHttpRequests for any content (including JSON)
相关标签:
2条回答
  • 2021-02-01 04:24

    I understand this question to be about why the browser considers JSONP safe, not about whether it is safe (which it isn't). I will address this question step by step.

    Regular ol' AJAX

    To perform a regular AJAX request, the browser creates an XHR object, points it at the URL and pulls the data. The XHR object will only trust data from the same domain. This is a hard limitation. There is no getting round it in current browsers (edit - you can now use CORS).

    Solution - Don't use XHR

    Since XHR is subject to the same domain poilicy, we can't use XHR to do cross domain AJAX. Luckily, there are other ways to hit a remote server. We could append an image tag to the page for example. We can also append a script tag and give it a src attribute that points to the remote server. We can pull JQuery from a CDN for example and expect it to work.

    How JSONP works.

    When we make a JSONP request, our code dynamically appends a script tag to the page. The script tag has a source attribute which points to the remote JSONP API url, just as though you were inserting a script from a CDN.

    The JSONP script returned by the server is wrapped in a function call. When the script is downloaded, the function will be executed automatically.

    This is why we have to tell the JSONP the name of the callback function we want to wrap the script in. That function will be called once the script has downloaded.

    Security concerns

    There are some fairly big security concerns here. The script you are downloading could take control over your page and put your users at risk. JSONP is not safe for your users, it is just not blocked by the web browsers. JSONP really is a browser exploit which we are taking advantage of. Use with caution.

    Used wisely, JSONP is pretty awesome though.

    0 讨论(0)
  • 2021-02-01 04:40

    I don't know how the perception that JSONP is safe came up but see

    JSON-P is, for that reason, seen by many as an unsafe and hacky approach to cross-domain Ajax, and for good reason. Authors must be diligent to only make such calls to remote web services that they either control or implicitly trust, so as not to subject their users to harm.

    and

    The most critical piece of this proposal is that browser vendors must begin to enforce this rule for script tags that are receiving JSON-P content, and throw errors (or at least stop processing) on any non-conforming JSON-P content.

    both quotes from http://json-p.org/ .

    other links with some useful information about JSONP/security:

    • http://beebole.com/en/blog/general/sandbox-your-cross-domain-jsonp-to-improve-mashup-security/
    • Cross Domain Limitations With Ajax - JSON
    • JSONP Implications with true REST

    all these tell 2 things - basically it is not considered "safe" but there are ideas on how to make it "safer"... though most ideas rely on standardization AND specific check logic to be built into browsers etc.

    0 讨论(0)
提交回复
热议问题