python 序列化 通过网络发送_【python-网络通信】这是一个用socket实现的简单的python RPC服务器/客户端。* 通过客户端/服务器共用的密码认证客户端* 使用JSON序列化函数...

"""

This is a RPC server/client implementation using socket

* It authenticate the client with a secret shared by client/server

* It uses JSON to serialize the function call payload

"""

import socket

import random, string

import hmac

import json

import threading

secret = "SECRET"

class RPCHandler:

def __init__(self, secret):

self._secret = secret

self._register = {}

def register_func(self, func):

self._register[func.__name__] = func

def handle_call(self, sock):

keymsg = ''.join([random.choice(string.lowercase) for i in range(8)])

sock.sendall(keymsg)

hash = hmac.new(self._secret, keymsg)

digest = hash.digest()

response = sock.recv(512)

if response != digest:

sock.sendall("Authentication Failed!")

sock.close()

else:

sock.sendall("Authenticated!")

try:

while True:

req = sock.recv(512)

d = json.loads(req)

funcname = d["name"]

args = d["args"]

kwargs = d["kwargs"]

print("Client calling %s(%s, %s)" % (funcname, args, kwargs))

try:

ret = self._register[funcname](*args, **kwargs)

sock.sendall(json.dumps({"ret": ret}))

except Exception as e:

sock.sendall(json.dumps({"exception": str(e)}))

except EOFError:

print("Closing RPC Handler...")

handler = RPCHandler(secret)

class RPCServer:

def __init__(self, address):

self._sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

self._sock.bind(address)

def serve_forever(self):

self._sock.listen(0)

while True:

client_sock,_ = self._sock.accept()

thread = threading.Thread(target=handler.handle_call, args=(client_sock, ))

thread.daemon = True

thread.start()

class RPCProxy(object):

def __init__(self, address, secret):

self._sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

self._sock.connect(address)

msg = self._sock.recv(512)

h = hmac.new(secret, msg)

self._sock.sendall(h.digest())

print(self._sock.recv(512))

def __getattr__(self, name):

def proxy_func(*args, **kwargs):

payload = {

"name": name,

"args": args,

"kwargs": kwargs

}

self._sock.sendall(json.dumps(payload))

result = json.loads(self._sock.recv(512))

if "exception" in result:

raise Exception(result['exception'])

else:

return result['ret']

if name.startswith("_"):

return super(RPCProxy, self).__getattr__(name)

else:

return proxy_func

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值