PythonプロジェクトでApp Engineモジュールを使用しています。 https://developers.google.com/appengine/docs/python/channel/App Engine Pythonモジュールとチャネルサービス
私は/( '/ _ah /チャンネル/接続/'、「/ _ah /チャネル接続/切断/切断後のメッセージを指示したい:私もMプロジェクト内のチャネルを使用しています(https://developers.google.com/appengine/docs/python/modules/#Python_Background_threads)
')を私のapiモジュールに渡します。今、私は彼らが任意のモジュール(デフォルトまたはAPI)に表示することができません
app.yamlを
api_version: 1
application: integrate
version: 1-0-0
runtime: python27
threadsafe: true
builtins:
- deferred: on
libraries:
- name: pycrypto
version: "2.6"
handlers:
- url: /favicon\.ico
static_files: static/favicon.ico
upload: static/favicon\.ico
- url: /admin/.+
script: src.default.main.app
login: admin
- url: /.*
script: src.default.main.app
api.yaml
api_version: 1
application: integrate
module: api
version: 1-0-0
runtime: python27
threadsafe: true
inbound_services:
- channel_presence
builtins:
- deferred: on
libraries:
- name: pycrypto
version: "2.6"
handlers:
- url: /admin/.+
script: src.api.main.app
login: admin
- url: /.*
script: src.api.main.app
dispatch.yaml
application: integrate
dispatch:
- url: "*/_ah/channel/*"
module: api
注:これはすべて、devモードのローカルでのみ有効です。
api.main.app
app = webapp2.WSGIApplication(debug=True)
_routes = [
:
ChannelDisconnectedHandler.mapping(),
ChannelConnectHandler.mapping()
]
for r in self._routes:
app.router.add(r)
ChannelDisconnectHandler
CHANNEL_DISCONNECTED_URL_PATTERN = '/_ah/channel/disconnected/'
class ChannelDisconnectedHandler(RequestHandler):
@classmethod
def mapping(cls):
return CHANNEL_DISCONNECTED_URL_PATTERN, cls
def post(self):
"""
Channel Presence handler. Will be called when a client disconnects.
"""
channel_id = self.request.get('from')
logging.info("Channel Disconnect. Id: %s" % channel_id)
ChannelConnectHandler
CHANNEL_CONNECT_URL_PATTERN = '/_ah/channel/connected/'
class ChannelConnectHandler(RequestHandler):
@classmethod
def mapping(cls):
return CHANNEL_CONNECT_URL_PATTERN, cls
def post(self):
"""
Channel Presence handler. Will be called when a client connects.
"""
channel_id = self.request.get('from')
logging.info("Channel Connect. Id: %s" % channel_id)
だから私のクライアントは私のAPIモジュールへの投稿(JavaScriptで書かれた)とチャネルを開きます。
var open_channel = function(tokenResponse) {
console.log("Open Channel. token Response: " + tokenResponse)
token = tokenResponse.token;
var channel = new goog.appengine.Channel(token);
if (socket != null) {
socket.close();
}
socket = channel.open();
socket.onopen = onOpened;
socket.onmessage = onMessage;
socket.onerror = onError;
socket.onclose = onClose;
};
onOpened = function() {
console.info("Channel API Connection is open.");
};
onError = function(e) {
console.info("CHANNEL Error. Code: " + e.code + ", Description: " + e.description);
};
onClose = function() {
console.info("Close Channel");
};
onMessage = function(msg) {
console.info("Message Received: " + msg + ", Data: " + msg.data);
};
このコールバック関数には有効なトークンが設定されています。私は正常にソケットを作成し、期待どおりこの機能を完了します。ローカルシステム上でonOpened関数が呼び出され、サーバーからメッセージが受信されます。プロダクションでは、onOpenedは決して呼び出されず、メッセージを受け取ることはありません。/_ah/channel/connected /も決して呼び出されません。
チャネルサービスはモジュールでサポートされていませんか?私が見逃していることについての考えは?
おかげで私はそれがここでの問題ではないかと思います。私はここにコードを掲載しませんでしたが、ルートを追加しました。もし私がいなければ、devモードでは動作しません。 –
私はそのコードを追加して、私が何を意味するのかを示します。 –