青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Benjamin

靜以修身,儉以養德,非澹薄無以明志,非寧靜無以致遠。
隨筆 - 398, 文章 - 0, 評論 - 196, 引用 - 0
數據加載中……

python websocket使用


  1 # coding: utf-8
  2 import struct
  3 import time
  4 import weakref
  5 from hashlib import md5
  6 
  7 from tornado.websocket import WebSocketHandler, WebSocketClosedError
  8 
  9 from core.player_mgr import player_mgr
 10 from settings import crypt, update_header, sign
 11 from core.session_mgr import session_mgr
 12 from core.logger import logger
 13 from core.blacklist import blacklist
 14 
 15 
 16 # noinspection PyAbstractClass
 17 class WSHandler(WebSocketHandler):
 18 
 19     uuid = None
 20     app_id = None
 21     game_id = None
 22     ver = None
 23     timestamp = None
 24     key = None
 25     last_time = 0
 26     stick_package_stack = None
 27     token = None
 28     player = None
 29     receive_id = 0
 30     send_id = 0
 31 
 32     def bind(self, player):
 33         if player.session:
 34             player.session.close(2)
 35             player.logger("player {0} cancel old session".format(self.uuid))
 36         self.player = weakref.proxy(player)
 37         self.player.session = self
 38         player_mgr.add_player(player)
 39 
 40     def check_origin(self, origin):
 41         return True
 42 
 43     @staticmethod
 44     def str2bytes(string):
 45         return bytes(string.encode("utf8"))
 46 
 47     def xor(self, string):
 48         if not crypt:
 49             return string
 50         value = bytearray()
 51         step = len(self.token)
 52         for i in range(0, len(string), step):
 53             for j in range(step):
 54                 if i + j >= len(string):
 55                     break
 56                 value.append(string[i + j] ^ self.token[j])
 57         return bytes(value)
 58 
 59     def encrypt(self, ostream):
 60         return self.xor(ostream)
 61 
 62     def decrypt(self, istream):
 63         return self.xor(istream)
 64 
 65     def verify_args(self):
 66         try:
 67             #self.app_id = int(self.get_argument("app_id"))
 68             #self.game_id = int(self.get_argument("game_id"))
 69             # self.uuid = self.get_argument("uuid")
 70             # self.ver = [int(i) for i in self.get_argument("version").split(".")]
 71             # self.timestamp = int(self.get_argument("timestamp"))
 72             self.key = self.get_argument("key")
 73         except Exception as e:
 74             logger.error("session argument type incorrect {0} {1}".format(self.request.uri, e))
 75             return False
 76         try:
 77             assert self.key #self.app_id and self.game_id and self.uuid and self.ver and self.timestamp and self.key
 78             return True
 79         except AssertionError:
 80             logger.error("session miss arguments {0}".format(self.request.uri))
 81             return False
 82 
 83     def auth(self):
 84         uri = self.request.uri
 85         last_index = len(uri)#uri.rindex("&")
 86         body = uri[uri.index("?")+1: last_index]
 87         key = uri[last_index+5:]
 88         self.timestamp = 0
 89         t = abs((time.time() * 1000 - self.timestamp) / 1000)
 90         if t > 30 and self.timestamp:
 91             logger.info("session close: auth failed, timestamp expired {0}".format(t))
 92             blacklist(self.request.host_name, self.request.remote_ip, 2)
 93             # return False
 94         md5_key = md5((body+"52LYD50YDs57jmy52Bc49").encode("utf-8")).hexdigest()
 95         # print("key", key, "md5", md5_key)
 96         #if key == md5_key:
 97         if uri.find(md5_key):
 98             return True
 99         else:
100             logger.info("session close: auth failed, key incorrect")
101             blacklist(self.request.host_name, self.request.remote_ip, 3)
102             return False
103 
104     def open(self, *args, **kwargs):
105         if not self.verify_args():
106             blacklist(self.request.host_name, self.request.remote_ip, 1)
107             self.close(8)
108             return
109         if not self.auth():
110             self.close(7)
111             return
112         session_mgr.add(self)
113         logger.debug("proxy {0} remote ip {1}".format(self.request.host_name, self.request.remote_ip))
114 
115     def close(self, code=None, reason=None):
116         #主動斷開
117         super().close(code, reason)
118         if self.player:
119             self.player.session = None
120             session_mgr.delete(self)
121             self.player.online_state = 0
122 
123     def on_close(self):
124         #收到客戶端斷開連接觸發事件
125         session_mgr.delete(self)
126         logger.debug("session {0} close {1}".format(self.uuid, self.close_code))
127         try:
128             if self.player and self.player.session:
129                 self.player.online_state = 0
130                 self.player.offline()
131                 self.player.session = None
132                 self.player = None
133         except (ReferenceError, AttributeError):
134             pass
135         if isinstance(self.close_code, int) and self.close_code >= 1000:
136             logger.warn("{0} close code {1} bad".format(self.uuid, self.close_code))
137 
138     def unpack_header(self, raw):
139         from protocol.deserialize import parse
140         if update_header:
141             size, seq, app_id, game_id, t, v1, v2, v3, sign1, sign2, sign3, sign4, sign5, sign6, sign7, sign8, sign9, cmd, = struct.unpack('>iihhibbbbbbbbbbbbb', raw[:29])
142             string, = struct.unpack('>{0}s'.format(size - 29), raw[29:size])
143             # print("receive_id", seq, self.receive_id)
144             client_sign = chr(sign1) + chr(sign2) + chr(sign3) + chr(sign4) + chr(sign5) + chr(sign6) + chr(sign7) + chr(sign8) + chr(sign9)
145             if seq == self.receive_id and client_sign == sign:
146                 self.receive_id += 1
147                 parse(cmd, string, self)
148             else:
149                 self.close(3)
150         else:
151             size, = struct.unpack('>H',raw[0:2])
152             cmd, = struct.unpack('>H', raw[2:4])
153             string, = struct.unpack('>{0}s'.format(size - 4), raw[4:size])
154 
155             # size, seq, self.game_id, cmd, = struct.unpack('>ihh', raw[:0])
156             # string, = struct.unpack('>{0}s'.format(size - 1), raw[1:size])
157             # size = len(raw)
158             # cmd = int(raw[0])#struct.unpack('>ihh', raw[:0])
159             # string = raw[2:size]#struct.unpack('>{0}s'.format(size - 1), raw[1:size])
160 
161             #協議處理
162             parse(cmd, string, self)
163 
164     def send(self, cmd, proto, serialize=True):
165         if serialize:
166             result = proto.SerializeToString()
167         else:
168             result = proto
169         result = self.encrypt(result)
170         if update_header:
171             fmt = ">iihhibbbb{0}s".format(len(result))
172             args = (len(result) + 20, self.send_id, self.app_id, self.game_id, int(time.time()), *self.ver, cmd, result)
173         #else:
174             # fmt = ">ii{0}s".format(len(result))
175             # args = (len(result) + 8, cmd, result)
176         fmt = ">HH{0}s".format(len(result))
177         args = (len(result), cmd,result)
178         data = struct.pack(fmt, *args)
179         # data = struct.pack('>BB{0}s',len(result),cmd,len(result),result)
180         try:
181             self.write_message(data, True)
182             if len(data) > 1024:
183                 logger.debug("{0} send message size {1}".format(self.uuid, len(data)))
184         except WebSocketClosedError:
185             pass
186         self.send_id += 1
187 
188     def on_message(self, buf):
189         self.last_time = time.time()
190         """解析數據流(半包,全包,粘包),并將命令和協議數據解開"""
191         if isinstance(buf, str):
192             buf = buf.encode(encoding='utf-8')
193             self.unpack_header(buf)
194             return
195             #buf = buf.encode(encoding='utf-8')
196             #self.unpack_header(buf)
197 
198         try:
199             if len(buf) > 1024:
200                 logger.debug("{0} receive message size {1}".format(self.uuid, len(buf)))
201             if self.stick_package_stack:
202                 buf = self.stick_package_stack + buf
203                 self.stick_package_stack = None
204             #size, = struct.unpack('>i', buf[:4])
205             size, = struct.unpack('>H',buf[0:2])
206             #size = buf[0]
207             raw_size = len(buf)
208             if raw_size > size:  # 至少有一個包
209                 self.unpack_header(buf)
210                 rest = buf[size:]
211                 self.on_message(rest)
212             elif size > raw_size:  # 半包
213                 self.stick_package_stack = buf
214                 logger.warn("{0} stick package {1}".format(self.uuid, len(buf)))
215             else:
216                 self.unpack_header(buf)
217         except Exception as e:
218             logger.exception("message parse failed {0}".format(str(e)))
219 
封裝微博socket操作,包括解包、發包等,這里采用谷歌protobuf協議格式,具體的解包、組包格式在另外一篇中介紹

posted on 2019-09-21 17:31 Benjamin 閱讀(818) 評論(0)  編輯 收藏 引用 所屬分類: python

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产精品久久久久9999| 亚洲人体影院| 亚洲欧美激情视频| 欧美不卡一卡二卡免费版| 日韩视频一区二区三区在线播放免费观看 | 久久一区二区精品| 一本色道久久综合亚洲精品高清| 亚洲日韩欧美视频一区| 亚洲日本成人网| 农村妇女精品| 欧美久久综合| 亚洲一区不卡| 亚洲福利国产精品| 亚洲综合精品自拍| 欧美一区二区三区免费观看| 国产精品亚洲美女av网站| 亚洲欧美欧美一区二区三区| 亚洲欧美色婷婷| 欧美在线视频日韩| 欧美一区二区日韩一区二区| 欧美日韩三级| 亚洲一区二区视频在线| 99国产精品久久| 亚洲欧美一级二级三级| 久久国产精品色婷婷| 午夜精品福利一区二区三区av| 欧美成人精品在线| 99国产精品久久久久久久| 久久久99免费视频| 免费成人黄色| 亚洲精选视频免费看| 欧美国产成人精品| 欧美日韩国产一区二区三区地区| 亚洲理论在线观看| 亚洲亚洲精品三区日韩精品在线视频 | 乱人伦精品视频在线观看| 伊人春色精品| 亚洲精品一级| 国产一区二区三区直播精品电影 | 亚洲国产精品久久久久秋霞影院| 欧美一级在线播放| 男女激情视频一区| 久久综合99re88久久爱| 欧美日本精品一区二区三区| 久久免费国产| 欧美顶级少妇做爰| 欧美一区二区在线播放| 久久免费99精品久久久久久| 久久国产精品一区二区| 樱桃成人精品视频在线播放| 欧美精品久久久久久久免费观看| 国产日韩欧美黄色| 欧美成人在线网站| 久久青草久久| 久久国产精品亚洲77777| 噜噜噜久久亚洲精品国产品小说| 亚洲伦理自拍| 国产精品视频免费在线观看| 欧美在线视频免费观看| 亚洲人成网站999久久久综合| 亚洲无线一线二线三线区别av| 国产亚洲精品一区二区| 嫩草国产精品入口| 欧美一区二区三区在线观看 | 亚洲一区三区电影在线观看| 久久精品国产亚洲一区二区| 亚洲人成网站色ww在线| 国产嫩草一区二区三区在线观看| 欧美激情亚洲视频| 久久久噜噜噜| 欧美在线观看网站| 欧美在线1区| 欧美亚洲视频在线看网址| 欧美在线地址| 亚洲国产精品一区二区www在线| 韩日视频一区| 免费在线成人av| 国产精品理论片在线观看| 欧美成人免费在线视频| 国产欧美一区二区精品仙草咪| 亚洲国产婷婷香蕉久久久久久99| 国内伊人久久久久久网站视频| 日韩一级网站| 日韩网站在线观看| 欧美成人日韩| 欧美激情一区二区久久久| 黄色免费成人| 性欧美xxxx视频在线观看| 午夜精品久久久久久久| 国产精品户外野外| 亚洲视频二区| 亚洲影视在线| 欧美日韩精品是欧美日韩精品| 亚洲欧洲在线观看| 亚洲精品影院| 欧美日韩国产免费| 亚洲精品中文字幕有码专区| 99热这里只有精品8| 欧美成人69av| 亚洲电影在线播放| 亚洲精品中文在线| 欧美日韩亚洲在线| 在线亚洲高清视频| 午夜在线一区二区| 国产亚洲一级| 久久久久欧美精品| 亚洲国产小视频在线观看| 日韩视频在线观看一区二区| 欧美全黄视频| 一区二区三区四区蜜桃| 欧美在线黄色| 在线不卡视频| 欧美精品三级日韩久久| 国产精品99久久久久久久女警| 性做久久久久久久免费看| 国产一区亚洲一区| 久久综合精品国产一区二区三区| 亚洲高清自拍| 亚洲综合色在线| 国内精品美女在线观看| 麻豆精品在线视频| 亚洲国产一区二区a毛片| 亚洲男人的天堂在线| 国产日韩欧美一区二区| 久久夜色撩人精品| 99国产精品| 久久精品国产在热久久| 亚洲日本aⅴ片在线观看香蕉| 欧美视频一区二区三区在线观看| 亚洲欧美国产77777| 欧美韩日精品| 欧美亚洲日本国产| 亚洲精品乱码久久久久久蜜桃麻豆| 欧美日韩国产电影| 欧美亚洲一区| 亚洲精品欧美一区二区三区| 久久精品国产亚洲aⅴ| 亚洲美女av黄| 国产一区二区三区观看| 欧美日韩国产欧| 欧美一区日本一区韩国一区| 亚洲国产精品一区二区www| 亚洲欧美一区二区在线观看| 久久狠狠亚洲综合| 欧美在线免费视屏| 影音先锋中文字幕一区| 欧美日韩在线电影| 久久久最新网址| 亚洲精品永久免费| 巨乳诱惑日韩免费av| 夜夜爽av福利精品导航 | 久久久久久久999精品视频| 亚洲欧洲精品成人久久奇米网| 午夜精品福利在线| 一本大道久久a久久综合婷婷| 精品动漫3d一区二区三区| 国产精品国产三级欧美二区| 欧美成人精品1314www| 久久国产福利| 亚洲欧美激情精品一区二区| 亚洲精品一区二区网址| 亚洲大片免费看| 美女视频黄免费的久久| 久久久国产精品亚洲一区| 亚洲欧洲av一区二区三区久久| 一区二区高清在线观看| 最新中文字幕亚洲| 亚洲国产综合91精品麻豆| 狠狠爱综合网| 激情欧美日韩一区| 国产一区二区剧情av在线| 欧美视频在线免费看| 欧美日韩黄色一区二区| 欧美久久久久久久久| 欧美黄免费看| 欧美jizzhd精品欧美巨大免费| 久久久久久9| 久久久人成影片一区二区三区| 欧美中文字幕精品| 久久国产免费| 久久久亚洲成人| 久久综合色影院| 麻豆免费精品视频| 欧美精品www在线观看| 欧美屁股在线| 欧美日韩在线免费| 国产精品99一区二区| 国产精品亚洲不卡a| 国产欧美欧美| 国产专区欧美精品| 亚洲成色www久久网站| 亚洲毛片在线观看.| 亚洲视频在线视频| 欧美一区影院| 麻豆精品一区二区综合av| 亚洲电影免费观看高清完整版在线观看| 欧美激情小视频| 一本色道久久综合亚洲精品不卡| 亚洲男女自偷自拍| 久久综合给合|