


ファイルをアップロードすることによって返された json データは、問題解決_javascript スキルをダウンロードするように求められます。
最近のプロジェクトでは、ファイルをアップロードすると返される json データをダウンロードするように求められます。この問題は IE10 でのみ発生します。フロントエンドは jQuery プラグイン ajaxForm を使用してフォームを送信し、バックグラウンドから返されるデータ形式は json です。コードは次のとおりです:
バックエンド Python:
def jsonp(func):
"""JSONP リクエストの JSON 化された出力をラップします。"""
@wraps(関数)
def Decored_function(*args, **kwargs):
callback = request.args.get('callback', False)
temp_content = func(*args, **kwargs)
if isinstance(temp_content, dict):
temp_content.setdefault('success', True)
temp_content.setdefault('code', 200)
試してみてください:
temp_content = json.dumps(temp_content, indent=4)
UnicodeDecodeError を除く:
試してみてください:
temp_content = ujson.dumps(temp_content)
e:
としての StandardError を除く Logger.Exception(e)
temp_content = json.dumps({'success': False, 'code': 500, 'info': 'INVALID_CONTENT'})
temp_content = cgi.escape(temp_content)
コールバックの場合:
# http://evilcos.me/?p=425 に基づいて、jsonp は /**/頭が安全になります
内容 = '/**/' str(callback) '(' temp_content ')'
を追加します mimetype = 'application/javascript'
ヘッダー = {'charset':'utf-8'}
return current_app.response_class(content, mimetype=mimetype, headers=headers)
その他:
mimetype = 'application/json'
ヘッダー = {'charset':'utf-8'}
コンテンツ = temp_content
return current_app.response_class(content, mimetype=mimetype, headers=headers)
elif isinstance(temp_content, Basestring):
temp_content = cgi.escape(temp_content)
return temp_content
その他:
return temp_content
装飾された関数を返します
@mod.route('/patch/install.json',methods=['POST'])
@jsonp
def patch_install():
戻り値 {'データ': 'データ'}
フロントエンド JS コード:
$('#form').ajaxSubmit({
URL : '/patch/install.json',
タイプ: '投稿'、
データ型: 'json'、
iframe : true、
成功: function(res) {
// コード
}
});
解決策:
次のように、バックエンドによって返されるデータ形式を text/html 形式に変更する必要があります:
def plain(func):
"""テキスト/HTML 応答をラップ"""
@wraps(関数)
def _inner(*args, **kwargs):
resp = func(*args, **kwargs)
if isinstance(resp, dict):
resp.setdefault('success', True)
resp.setdefault('code', 200)
resp = json.dumps(resp)
resp = cgi.escape(resp)
return current_app.response_class(resp, mimetype='text/html', headers={'charset': 'utf-8'})
elif isinstance(resp、basestring):
resp = cgi.escape(resp)
return current_app.response_class(resp, mimetype='text/html', headers={'charset': 'utf-8'})
その他:
return resp
_inner を返す @mod.route('/patch/install.json',methods=['POST'])
@プレーン
def patch_install():
戻り値 {'データ': 'データ'}
実際にこの問題を解決するには、一言でまとめると、「バックエンドから返されるデータ形式を text/html 形式に変更する」

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











JavaScript文字列置換法とFAQの詳細な説明 この記事では、javaScriptの文字列文字を置き換える2つの方法について説明します:内部JavaScriptコードとWebページの内部HTML。 JavaScriptコード内の文字列を交換します 最も直接的な方法は、置換()メソッドを使用することです。 str = str.replace( "find"、 "置換"); この方法は、最初の一致のみを置き換えます。すべての一致を置き換えるには、正規表現を使用して、グローバルフラグGを追加します。 str = str.replace(/fi

単純なJavaScript関数は、日付が有効かどうかを確認するために使用されます。 関数isvaliddate(s){ var bits = s.split( '/'); var d = new Date(bits [2] '/' bits [1] '/'ビット[0]); return !!(d &&(d.getmonth()1)== bits [1] && d.getdate()== number(bits [0])); } //テスト var

この記事では、jQueryを使用して、DOM要素の内側のマージン値とマージン値、特に外側の縁と要素の内側の縁の特定の位置を取得して設定する方法について説明します。 CSSを使用して要素の内側と外側の縁を設定することは可能ですが、正確な値を取得するのは難しい場合があります。 // 設定 $( "div.header")。css( "margin"、 "10px"); $( "div.header")。css( "padding"、 "10px"); このコードはそうだと思うかもしれません

この記事では、10個の例外的なjQueryタブとアコーディオンについて説明します。 タブとアコーディオンの重要な違いは、コンテンツパネルの表示方法と非表示にあります。これらの10の例を掘り下げましょう。 関連記事:10 jQueryタブプラグイン

ウェブサイトのダイナミズムと視覚的な魅力を高めるために、10の例外的なjQueryプラグインを発見してください!このキュレーションされたコレクションは、画像アニメーションからインタラクティブなギャラリーまで、多様な機能を提供します。これらの強力なツールを探りましょう。 関連投稿: 1

HTTP-Consoleは、HTTPコマンドを実行するためのコマンドラインインターフェイスを提供するノードモジュールです。 Webサーバー、Web Servに対して作成されているかどうかに関係なく、HTTPリクエストで何が起こっているかをデバッグして正確に確認するのに最適です

このチュートリアルでは、カスタムGoogle検索APIをブログまたはWebサイトに統合する方法を示し、標準のWordPressテーマ検索関数よりも洗練された検索エクスペリエンスを提供します。 驚くほど簡単です!検索をyに制限することができます

次のjQueryコードスニペットを使用して、Divコンテンツがコンテナ要素領域を超えたときにスクロールバーを追加できます。 (デモンストレーションはありません、それを直接firebugにコピーしてください) // d =ドキュメント // w =ウィンドウ // $ = jQuery var contentarea = $(this)、 wintop = contentarea.scrolltop()、 docheight = $(d).height()、 winheight = $(w).height()、 divheight = $( '#c
