本文實(shí)例講述了Python警察與小偷的實(shí)現(xiàn)之一客戶端與服務(wù)端通信,分享給大家供大家參考。具體方法分析如下:
該實(shí)例來源于ISCC 2012 破解關(guān)第四題
目的是通過逆向police,實(shí)現(xiàn)一個(gè)thief,能夠與police進(jìn)行通信
實(shí)際上就是一個(gè)RSA加密通信的例子,我們通過自己編寫客戶端和服務(wù)端來實(shí)現(xiàn)上面的thief和police的功能.
要通信,這們這次先通過python寫出可以進(jìn)行網(wǎng)絡(luò)連接的客戶端與服務(wù)端.
服務(wù)端代碼如下:
#!/usr/bin/env python import SocketServer from time import ctime HOST = '127.0.0.1' PORT = 2012 ADDR = (HOST, PORT) class MyRequestHandler(SocketServer.BaseRequestHandler): def handle(self): print '...connected from...', self.client_address while True: self.request.sendall('[%s] %s' % (ctime(),self.request.recv(1024))) tcpServ = SocketServer.ThreadingTCPServer(ADDR, MyRequestHandler) print 'waiting for connection...' tcpServ.serve_forever()
客戶端代碼如下:
#!/usr/bin/env python from socket import * HOST = '127.0.0.1' PORT = 2012 BUFSIZ = 1024 ADDR = (HOST, PORT) tcpCliSock = socket(AF_INET, SOCK_STREAM) tcpCliSock.connect(ADDR) while True: data = raw_input('>>>>>>>>>>>>') if not data: break tcpCliSock.send('%s/r/n' % data) data = tcpCliSock.recv(BUFSIZ) if not data: break print data.strip() #tcpCliSock.close()
這段代碼可參考《python核心編程》
如果報(bào)python errno 10053錯(cuò)誤,請確認(rèn)下客戶端的連接代碼一定要在循環(huán)外
也就是:
tcpCliSock = socket(AF_INET, SOCK_STREAM) tcpCliSock.connect(ADDR)
要在while True的外面。
下次解決RSA加密的問題。
希望本文所述對大家的Python程序設(shè)計(jì)有所幫助。
新聞熱點(diǎn)
疑難解答
圖片精選