Created
July 18, 2011 15:54
-
-
Save farazdagi/1089923 to your computer and use it in GitHub Desktop.
JSONP in Flask
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import json | |
from functools import wraps | |
from flask import redirect, request, current_app | |
def support_jsonp(f): | |
"""Wraps JSONified output for JSONP""" | |
@wraps(f) | |
def decorated_function(*args, **kwargs): | |
callback = request.args.get('callback', False) | |
if callback: | |
content = str(callback) + '(' + str(f().data) + ')' | |
return current_app.response_class(content, mimetype='application/json') | |
else: | |
return f(*args, **kwargs) | |
return decorated_function | |
# then in your view | |
@default.route('/test', methods=['GET']) | |
@support_jsonp | |
def test(): | |
return jsonify({"foo":"bar"}) |
fantastic! nicely done =)
@aisipos
Based on your gist, I edit some place to make json response can contain status code, please see my fork https://gist.github.com/JiaKunUp/a9df722bad15c61ea555fa860997edc9
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
For views that take arguments, you need to pass args and kwargs to f(). See my fork https://gist.github.com/1094140
Also, according to http://stackoverflow.com/questions/111302/best-content-type-to-serve-jsonp , application/javascript is a more correct content-type for JSONP