参考: http://www.cnblogs.com/alex3714/articles/5830365.html

Socket

  • network socket is an endpoint of a connection across a computer network. Today, most communication between computers is based on the Internet Protocol; therefore most network sockets are Internet sockets. More precisely, a socket is a handle (abstract reference) that a local program can pass to the networking application programming interface (API) to use the connection, for example "send this data on this socket".
  • 实现步骤 (伪代码:)
  • Socket socket = getSocket(type = "TCP")  #设定好协议类型
    connect(socket, address = "1.2.3.4", port = "") #连接远程机器
    send(socket, "Hello, world!") #发送消息
    close(socket) #关闭连接

简单Socket 实例

1. 客户端

#!/usr/bin/python
# -*- coding: utf-8 -*- # 客户端
import socket
client = socket.socket() # 声明socket类型, 同时生成socket链接对象
client.connect(('localhost', 6969)) client.send(b"Hellow World") # 只能接收字节类型, 所以要加b转一下 data = client.recv(1024) # 收1024个字节
print("recv: ", data) client.close()

客户端

2. 服务端

#!/usr/bin/python
# -*- coding: utf-8 -*- """
要实现对话:
1. 需要用多线程, 服务器端和客户端交叉执行才能完成一个对话;
2. 用异步也可以实现
3. 最简单的, 哪个实例发过来的, 就用哪个实例接收(在代码执行窗口手动切换 client端和服务端).
""" # 服务器端
import socket
server = socket.socket() # 不传入参数就是使用构造方法的默认参数设置
server.bind(('localhost', 6969)) # 绑定要监听的端口
server.listen() # 监听 print("我要开始等电话了")
conn, addr = server.accept() # 等电话打进来. server.accept()返回两个值,分别赋给conn, addr.
# conn就是客户端连过来而在服务器端为其生成的一个连接实例 print(conn, addr) print("电话来了") # data = server.recv(1024) # 开始接收对方发过来的信息
data = conn.recv(1024) # 谁打来的电话, 跟谁聊
print("recv: ", data)
# server.send(data.upper())
conn.send(data.upper()) server.close()

服务端

实现效果:

挂起多个客户端实例.

客户端:

#!/usr/bin/python
# -*- coding: utf-8 -*-
"""
重复发送和接收多次:
1. 实现用户输入
""" import socket client = socket.socket() # 声明socket类型, 同时生成socket连接对象
client.connect('localhost', 6969) while True:
msg = input(">>: ").strip()
if len(msg) == 0: continue # 不能发空的. 否则系统以为用户还在输入, 会一直等.
client.send(msg.encode("utf-8"))
data = client.recv(1024)
print("recv: ", data.decode()) # 把utf-8转成unicode client.close()

client端

服务器端:

#!/usr/bin/python
# -*- coding: utf-8 -*-
"""
下面这段在linux执行时, 如果client端断开, server端会陷入死循环.
在window里, 如果client端断开, server端也会断开. 要克服上述问题, 要加个判断, 如果接收的信息是空, 断开循环. (见第二段代码) """
# 服务器端
import socket
server = socket.socket() # 不传入参数就是使用构造方法的默认参数设置
server.bind(('localhost', 6969)) # 绑定要监听的端口
server.listen() # 监听 print("我要开始等电话了")
conn, addr = server.accept() # 等电话打进来. server.accept()返回两个值,分别赋给conn, addr.
# conn就是客户端连过来而在服务器端为其生成的一个连接实例 print(conn, addr) print("电话来了") # data = server.recv(1024) # 开始接收对方发过来的信息
data = conn.recv(1024) # 谁打来的电话, 跟谁聊
print("recv: ", data)
# server.send(data.upper())
conn.send(data.upper()) server.close() """
上面这段代码实现的是如果client端断开, server端也随之断开. 但是server应该还能接收新的电话进来 . 所以要加循环.
"""
#
import os
import socket
server = socket.socket() # 不传入参数就是使用构造方法的默认参数设置
server.bind(('localhost', 6969)) # 绑定要监听的端口
server.listen() # 监听. server.listen(5)代表最多能挂起5个client端(不断开, 排队), 但这种情况要在异步情形下才能测出来. print("我要开始等电话了") while True: #即使当前client端断开, 还可以等新的电话
conn, addr = server.accept() # 等电话打进来. server.accept()返回两个值,分别赋给conn, addr.
# conn就是客户端连过来而在服务器端为其生成的一个连接实例 print(conn, addr)
print("电话来了") while True:
# data = server.recv(1024) # 开始接收对方发过来的信息
data = conn.recv(1024) # 谁打来的电话, 跟谁聊. 一次最多收10240字节.
print("recv: ", data)
if not data:
print("client has lost...")
break # 切断循环
res = os.popen(data).read() # 打印执行结果
# server.send(data.upper())
# conn.send(data.upper())
conn.send(res) server.close()

server端

Python Socket 通信的更多相关文章

  1. Python Socket通信原理

    [Python之旅]第五篇(一):Python Socket通信原理   python Socket 通信理论 socket例子 摘要:  只要和网络服务涉及的,就离不开Socket以及Socket编 ...

  2. python - socket通信笔记

    参考: 通过编写聊天程序来熟悉python中多线程和socket的用法:https://www.cnblogs.com/mingjiatang/p/4905395.html python socket ...

  3. Python socket 通信功能简介

    常用的地址家族AF_UNIX:基于文件,实现同一主机不同进程之间的通信AF_INET:基于网络,适用于IPv4AF_INET6:基于网络,使用于IPv6 常见的连接类型SOCK_STREAM:即TCP ...

  4. Python Socket通信黏包问题分析及解决方法

    参考:http://www.cnblogs.com/Eva-J/articles/8244551.html#_label5 1.黏包的表现(以客户端远程操作服务端命令为例) 注:只有在TCP协议通信的 ...

  5. Python Socket通信例子

    一.TCP 通信 服务端 #!/usr/bin/env python # -*- coding: utf-8 -*- # server_tcp.py import socket so = socket ...

  6. Python socket通信之FTP

    Python中利用socket进行server端和client端通信是网络编程的基础,是最简单的传输范例. (懂网络的请自动跳过这一部分) 首先,要想通信,必须建立连接,建立连接的过程,需要clien ...

  7. 树莓派小车By 树莓派爱好者ITJoker(通过python socket通信实现树莓派视频小车)(一)

    本文由树莓派爱好者ITJoker 编辑,转载请注明出处.本人也有新浪博客同样是树莓派爱好者ITJoker 所需材料:树莓派2B或者2B以上,L2985n驱动板,若干排线,电池及电池盒,usb无线网卡( ...

  8. 程序媛计划——python socket通信

    定义 socket 是进程间的一种通信方式,可以实现不同主机间的数据传输 #写服务期端程序server.py #实现服务器向客户端连接 #!/usr/bin/env python #coding:ut ...

  9. Python简易聊天工具-基于异步Socket通信

    继续学习Python中,最近看书<Python基础教程>中的虚拟茶话会项目,觉得很有意思,自己敲了一遍,受益匪浅,同时记录一下. 主要用到异步socket服务客户端和服务器模块asynco ...

随机推荐

  1. 《垃圾回收的算法与实现》——Python垃圾回收

    Python垃圾回收 python采用引用计数法进行垃圾回收 Python内存分配 python在分配内存空间时,在malloc之上堆放了3个独立的分层. python内存分配时主要由arena.po ...

  2. http错误代码含义

    "100" : Continue "101" : witching Protocols "200" : OK "201" ...

  3. Vue笔记:使用 Yarn 管理依赖包

    上年10月份, Facebook 发布了新的 node.js 包管理器 Yarn 用以替代 npm ,它比npm更快.更高效. Yarn VS npm 1.yarn.lock 文件 在 npm 中同样 ...

  4. Spring MVC的Controller统一异常处理:HandlerExceptionResolver

    a.针对500异常的统一处理1.实现HandlerExceptionResolver,重写resolveException方法 package com.liying.mango.common.inte ...

  5. mybatis中预编译sql与非预编译sql

    预编译sql有缓存作用,非预编译没得 mybaits中带有#传参的有预编译左右,$没得 多用#传参 预编译语句的优势在于归纳为:一次编译.多次运行,省去了解析优化等过程:此外预编译语句能防止sql注入 ...

  6. EOS 理解

    1.通过石墨烯技术来解决延迟和吞吐量. 2.账户体系:账户是可读的唯一标识符,不是地址.可包含多对公私钥.账户有权限规划.权限有阈值,公私钥有权重,公私钥的权重大于等于阀值才能拥有该权限进行相应操作. ...

  7. 描述linux系统从开机到登陆界面的启动过程

    简述:1.开机BIOS自检2.MBR引导3.grub引导菜单4.加载内核kernel5.启动init进程6.读取inittab文件,执行rc.sysinit,rc等脚本7.启动mingetty,进入系 ...

  8. 了解MySQL联表查询中的驱动表,优化查询,以小表驱动大表

    一.为什么要用小表驱动大表 1.驱动表的定义 当进行多表连接查询时, [驱动表] 的定义为: 1)指定了联接条件时,满足查询条件的记录行数少的表为[驱动表] 2)未指定联接条件时,行数少的表为[驱动表 ...

  9. 让浏览器兼容ES6语法(gulp+babel)

    使用gulp+babel搭建ES6环境 前言 我们查阅资料可以知道ECMAScript 2015(简称ES6)已经于2015年发布,由于用户使用的浏览器版本在安装的时候可能早于ES6的发布,而到了今天 ...

  10. 笨方法学python学习笔记

    创建于:2016-02-29 更新于:03-02 python版本:2.7 %r 用来做 debug 比较好,因为它会显示变量的原始数据(raw data),而其它的符号则是用来向用户展示输出的: 每 ...