python下的socket





1、简单的server和client端的socket代码

server.py:





#!/usr/bin/env python

#_*_ coding:utf-8 _*_





import socket

ip_port = ('127.0.0.1',9999)





sk = socket.socket()

sk.bind(ip_port)

sk.listen(1)





while 1:

    print 'waiting'

    conn,addr = sk.accept()

    conn.sendall('welcome to 10086')

    conn.close()





client.py:





#!/usr/bin/env python

#_*_ coding:utf-8 _*_





import socket





ip_port = ('127.0.0.1',9999)





sk = socket.socket()

sk.connect(ip_port)





data = sk.recv(1024)

sk.close()





print data





分别在两个窗口运行:

# python server.py

# python client.py





2、多线程,阻塞模式

server.py:





#!/usr/bin/env python

#_*_ coding:utf-8 _*_





import socket

# 阻塞式

sk = socket.socket()

ip_port = ('192.168.8.51',50001)





sk.bind(ip_port)

sk.listen(2)





while True:

    conn,addr = sk.accept()

    print 'get a data from ',addr

    while True:

        

        data = conn.recv(1024)

        if not data : break

        conn.send(data.upper())

        print 'recevie:',data

sk.close()





client.py:





#!/usr/bin/env python

#_*_ coding:utf-8 _*_





import socket





ip_port = ('192.168.8.51',50001)

sk = socket.socket()

sk.connect(ip_port)





while True:

    input_data = raw_input('')

    sk.send(input_data)

    data = sk.recv(1024)

    print 'recevi:',data

    

sk.close()





3、模拟实现ssh





ssh_socket_server.py:





#!/usr/bin/env python

#_*_ coding:utf-8 _*_





import SocketServer

import commands,time





class MySocksServer(SocketServer.BaseRequestHandler):

    

    def handle(self):

        print 'get a new conn from ',self.client_address

        

        while True:

            cmd = self.request.recv(1024)

            if not cmd:

                print 'lost connetion with',self.client_address

                break

            cmd_result = commands.getstatusoutput(cmd)

            # send result size

            self.request.send(str(len(cmd_result[1])))

            #self.sleep(0.2)

            

            # send result

            self.request.sendall(cmd_result[1])

            

if __name__ == '__main__':

    h = '0.0.0.0'

    p = 50003

    s = SocketServer.ThreadingTCPServer((h,p),MySocksServer)





    s.serve_forever()





socket_client:





#!/usr/bin/env python

#_*_ coding:utf-8 _*_





import socket

from _mysql import result





ip_port = ('192.168.8.51',50003)





sk = socket.socket(socket.AF_INET,socket.SOCK_STREAM)





sk.connect(ip_port)





def recv_all(obj,msg_length):

    raw_result = ''

    while msg_length != 0:

        if msg_length <= 4096:

            data = obj.recv(msg_length)

            msg_length = 0

            

        else:

            data = obj.recv(4096)

            msg_length -= 4096

        raw_result += data

        

    return raw_result





while True:

    input_data = raw_input('')

    if len(input_data) == 0: break

    sk.sendall(input_data)

    

    # recv response size

    res_size = int(sk.recv(100))

    print 'data size from server',res_size

    

    result = recv_all(sk,res_size)

    print result





sk.close()





4、模拟实现ftp账号远程登录通过获取数据





ftp客户端

ftp_client.py:

#!/usr/bin/env python

#_*_ coding:utf-8 _*_





import socket

import MySQLdb

import os

import hashlib

from _mysql import result





ip_port = ('192.168.50.18',50004)

sk = socket.socket(socket.AF_INET,socket.SOCK_STREAM)

sk.connect(ip_port)





#连接数据库函数

def conn_db():

    try:

        return MySQLdb.connect(host='localhost',user='root',passwd='',port=3306)        

    except MySQLdb.Error,e:  

        print "Mysql Error %d: %s" % (e.args[0], e.args[1])

        

# md5加密的函数

def md5_create(name):

    code = hashlib.md5()

    code.update(name)

    return code.hexdigest()

     

#验证用户名密码是否正确

def login(username,password):

        #连接数据库

        conn = conn_db()

        

        cur = conn.cursor()

        conn.select_db('python')

        

        cur.execute('select password from user where username = "%s"' % username)

        result = cur.fetchone()

        md5code = md5_create(password)

        

        #验证密码是否正确

        if result[0] == md5code:

            return True

        else:

            return False





def recv_all(obj,msg_length):

    raw_result = ''

    while msg_length != 0:

        if msg_length <= 4096:

            data = obj.recv(msg_length)

            msg_length = 0

            

        else:

            data = obj.recv(4096)

            msg_length -= 4096

        raw_result += data

        

    return raw_result





#获取数据函数

def get_all(self,obj,msg_length,dst_file):

       

        while msg_length != 0:

            if msg_length <= 4096:

                data = obj.recv(msg_length)

                msg_length = 0

                print 'to less ',msg_length

            else:

                data = obj.recv(4096)

                msg_length -= 4096

                print 'else ',msg_length

            dst_file.write(data)

        

        return 'done'





while True:

    user_input = raw_input('please input your username and password eg: user pwd ')

    if len(user_input) == 0:

        print 'your username or password is error'

        break

    

    username,password = user_input.split()

    #验证用户密码是否正确

    login_rs = login(username,password)

    

    if login_rs:

        while True:

            user_input = raw_input('msg to send::')

            if len(user_input) == 0: continue

            

            user_cmd = user_input.split()

            

            #如果命令为put则进行传输数据

            if user_cmd[0] == 'put':

                if len(user_cmd) == 2:

                    f = file(user_cmd[1] , 'rb')

                    f_size = os.stat(user_cmd[1]).st_size

                    sk.send("%s %s %s" %(user_cmd[0],user_cmd[1],f_size))

                    

                    print 'going to send...'

                    sk.sendall(f.read())

                    print sk.recv(1024)

                    

            else:

                sk.sendall(user_cmd[0])

                print 'else',user_cmd[0]

                res_size = int(sk.recv(100))

                print 'data size from server',res_size

                

                result = recv_all(sk,res_size)

                print result

                





sk.close()





服务器端:

ftp_server.py





#!/usr/bin/env python

#_*_ coding:utf-8 _*_





import SocketServer

import commands

import socket





class MySocksServer(SocketServer.BaseRequestHandler):

    

    def recv_all(self,obj,msg_length,dst_file):

       

        while msg_length != 0:

            if msg_length <= 4096:

                data = obj.recv(msg_length)

                msg_length = 0

                print 'to less ',msg_length

            else:

                data = obj.recv(4096)

                msg_length -= 4096

                print 'else ',msg_length

            dst_file.write(data)

        

        return 'done'





    def handle(self):

        print 'get a new conn from ',self.client_address

        

        while True:

            cmd = self.request.recv(1024)

            if not cmd:

                print 'lost connetion with',self.client_address

                break

            #option,filename,file_size = cmd.split()

            cmd_c = cmd.split()

            

            if cmd_c[0] == 'put':

                # client want to upload file

                f = file('recv/%s' % cmd_c[1],'wb')

                write_to_file = self.recv_all(self.request, int(cmd_c[2]), f)

                if write_to_file == 'done':

                    self.request.send('file upload success')

                    f.close()

                    

            else:

                print 'start send cmd back info'

                cmd_result = commands.getstatusoutput(cmd_c[0])

                self.request.send(str(len(cmd_result[1])))

                self.request.sendall(cmd_result[1])

            

if __name__ == '__main__':

    h = '0.0.0.0'

    p = 50004

    s = SocketServer.ThreadingTCPServer((h,p),MySocksServer)

    sk = socket.socket(socket.AF_INET,socket.SOCK_STREAM)

    s.serve_forever()

python下的socket常用方法举例的更多相关文章

  1. SSL握手通信详解及linux下c/c++ SSL Socket代码举例

    SSL握手通信详解及linux下c/c++ SSL Socket代码举例 摘自:http://www.169it.com/article/3215130236.html   分享到:8     发布时 ...

  2. SSL握手通信详解及linux下c/c++ SSL Socket代码举例(另附SSL双向认证客户端代码)

    SSL握手通信详解及linux下c/c++ SSL Socket代码举例(另附SSL双向认证客户端代码) 摘自: https://blog.csdn.net/sjin_1314/article/det ...

  3. python下的web服务器模块

    python下的web服务模块有三种: BaseHTTPServer: 提供基本的Web服务和处理器类,分别是HTTPServer和BaseHTTPRequestHandler SimpleHTTPS ...

  4. python socket编程---从使用Python开发一个Socket示例说到开发者的思维和习惯问题

    今天主要说的是一个开发者的思维和习惯问题. 思维包括编程的思维和解决一个具体问题的分析思维,分析思路,分析方法,甚至是分析工具. 无论是好习惯还是不好的习惯,都是在者一天一天的思维中形成的.那些不好的 ...

  5. Day28--Python--网络通信协议 tcp与udp下的socket

    昨日内容回顾: 1. CS架构 服务端客户端架构 软件CS架构: 京东,淘宝,QQ,微信,暴风影音,快播 硬件CS架构: 打印机 服务端: 提供服务的 客户端: 享受服务的 BS架构: 浏览器和服务端 ...

  6. python网络编程:socket、服务端、客户端

    本文内容: socket介绍 TCP: 服务端 客户端 UDP: 服务端 客户端 首发时间:2018-02-08 01:14 修改: 2018-03-20 :重置了布局,增加了UDP 什么是socke ...

  7. Day10 Python网络编程 Socket编程

    一.客户端/服务器架构 1.C/S架构,包括: 1.硬件C/S架构(打印机) 2.软件C/S架构(web服务)[QQ,SSH,MySQL,FTP] 2.C/S架构与socket的关系: 我们学习soc ...

  8. python基础之socket与socketserver

    ---引入 Socket的英文原义是“孔”或“插座”,在Unix的进程通信机制中又称为‘套接字’.套接字实际上并不复杂,它是由一个ip地址以及一个端口号组成.Socket正如其英文原意那样,像一个多孔 ...

  9. python基础之socket编程 (转自林海峰老师)

    python基础之socket编程   阅读目录 一 客户端/服务器架构 二 osi七层 三 socket层 四 socket是什么 五 套接字发展史及分类 六 套接字工作流程 七 基于TCP的套接字 ...

随机推荐

  1. 13 款高逼格且实用的 Linux 运维必备工具

    转载于民工哥技术之路 1. 查看进程占用带宽情况 - Nethogs Nethogs 是一个终端下的网络流量监控工具可以直观的显示每个进程占用的带宽. 下载:http://sourceforge.ne ...

  2. cisco常用命令详解

    cisco常用命令详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.常用命令用法展示 1.命令行模式的来回切换 yinzhengjie>enable #从用户模式切换到 ...

  3. python自动化运维之路~DAY2

    python自动化运维之路~DAY2 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.字符编码与转码 1.什么是编码. 基本概念很简单.首先,我们从一段信息即消息说起,消息以人类 ...

  4. 修改tomcat启动窗口的名称

    场景:我们在启动tomcat的时候,一般会出现tomcat窗口,默认窗口名字是tomcat,如果我们想知道这个tomcat的端口号,我们需要查看配置文件,很麻烦有木有.如果我们可以直接把端口号设置在窗 ...

  5. JS获取客户端IP地址、MAC和主机名【转】

    JS获取客户端IP地址.MAC和主机名 引用:JS获取客户端IP地址.MAC和主机名的7个方法汇总 利用搜狐接口 <html> <head> <meta http-equ ...

  6. Study 6 —— 字体和段落属性

    字体风格{font-style:normal | italic | oblique | inherit字体复合属性{font:font-style font-variant font-weight f ...

  7. 字符串数字转换成对应的Double数值

    一,介绍 前面实现了字符串转换成整形数值.参考这里: 它不支持小数,不支持符号(正.负号) 现在实现一个更复杂一点字符串转换成数值的程序. 它支持“浮点字符串”转换成对应的浮点数值,如: " ...

  8. 基于Redis主从复制读写分离架构的Session共享(Windows Server)

    搭建主从复制 1.安装软件 下载Redis-x64-3.2.100.zip:https://github.com/MicrosoftArchive/redis/releases 第一步:将Redis拷 ...

  9. 破解WEP工具wesside-ng

    1.关于wesside-ng wesside-ng是一款自动化的WEP破解工具,该工具采用了多种WEP加密破解技术.它首先会自动明确目标无线网络,然后尝试与之相关联,在获得PRGA(伪随机生成算法)异 ...

  10. Hadop 基础

    HDFS 体系结构 mapreduce 体系结构和算法 haddop 集群 zookeeper 操作:HBase 体系结构Hive /Sqoop 体系结构和基本操作: mapreduce 逻辑处理数据 ...