フラスコ プロジェクトに socketio を組み込もうとしています。現在、サーバーから単純な「接続済み」または「切断済み」の出力を取得しようとしています。ただし、「python app.py」を使用してアプリ スクリプトを実行すると、これらのメッセージもエラーも表示されず、どの方向にも表示されません。
エラーを見逃すとは思っていませんでした!
app.py
from flask import Flask, render_template, request, url_for, copy_current_request_context
from flask_socketio import SocketIO, emit
import logging
logging.basicConfig()
app = Flask(__name__)
app.config['SECRET_KEY'] = 'secret!'
app.config['DEBUG'] = True
socketio = SocketIO(app)
@app.route('/scan/')
def waitForRFID():
return render_template('scan.html')
@socketio.on('connect', namespace='/test')
def test_connect():
print('Client connected')
@socketio.on('disconnect', namespace='/test')
def test_disconnect():
print('Client disconnected')
if __name__ == '__main__':
socketio.run(app)
scan.html
<!doctype html>
<meta name="viewport" content="width=device-width, initial-scale=1">
<head>
<script src="//cdnjs.cloudflare.com/ajax/libs/socket.io/1.3.6/socket.io.min.js"></script>
<script src="{{ url_for('static', filename = 'js/scan.js') }}"></script>
<link rel=stylesheet type=text/css href="{{ url_for('static', filename='css/scan.css') }}" />
</head>
scan.js
$(document).ready(function(){
//connect to the socket server.
var socket = io.connect('http://' + document.domain + ':' + location.port + '/test');
});
app.py ファイルを実行して「127.0.0.1:5000/scan/」にアクセスすると、ターミナルに次の出力が表示されます。
127.0.0.1 - - [2018-02-11 16:42:10] "GET /scan/ HTTP/1.1" 200 812 0.010323
Web ページは適切に読み込まれ、これを仮想環境の内外で実行しても同じ出力が得られます。
このような単純なセットアップでは、何が間違っているのでしょうか? 前もって感謝します!