from socket import *
serverSocket=socket(AF_INET,SOCK_STREAM)
serverSocket.bind(("",8899))
serverSocket.listen(5)
newSocket,clientAddr=serverSocket.accept() #返回新的套接字和对方的ip地址和端口号
print("有客户端连接")
recvDate=newSocket.revc(1024)
print("%s%s"%(str(clientAddr),recvDate))
newSocket.send("thank you !")
newSocket.close()
serverSocket.close()
from socket import *

# 创建socket
tcpSerSocket = socket(AF_INET, SOCK_STREAM) # 绑定本地信息
address = ('', 8899)
tcpSerSocket.bind(address) # 使用socket创建的套接字默认的属性是主动的,使用listen将其变为被动的,这样就可以接收别人的链接了
tcpSerSocket.listen(5) # 如果有新的客户端来链接服务器,那么就产生一个新的套接字专门为这个客户端服务器
# newSocket用来为这个客户端服务
# tcpSerSocket就可以省下来专门等待其他新客户端的链接
newSocket, clientAddr = tcpSerSocket.accept() # 接收对方发送过来的数据,最大接收1024个字节
recvData = newSocket.recv(1024)
print('接收到的数据为:%d',recvData.decode("gb2312")) # 发送一些数据到客户端
newSocket.send("thank you !".encode("gb2312")) # 关闭为这个客户端服务的套接字,只要关闭了,就意味着为不能再为这个客户端服务了,如果还需要服务,只能再次重新连接
newSocket.close() # 关闭监听套接字,只要这个套接字关闭了,就意味着整个程序不能再接收任何新的客户端的连接
tcpSerSocket.close()
# 多线程服务器,接收客户机链接

from socket import *
from threading import * def recv_send_Thread(customer_sock,addr):
while True: str=customer_sock.recv(1024) # 循环接收客户端发来的信息
customer_sock.send(str)
print(str.decode("gb2312"))
if str.decode("gb2312") == 'exit':
print("关闭套接字")
customer_sock.close()
break
customer_sock.close()
#创建服务器的socket
server_tcp_socket=socket(AF_INET,SOCK_STREAM) # 解决MSL问题,如果服务器先断开链接,则第四次会后不必等2被时间,即可链接,避免出现等到2倍时间内地址被占用的问题
server_tcp_socket.setsockopt(SOL_SOCKET,SO_REUSEADDR,1) #bind绑定地址和端口
server_tcp_socket.bind(("",8899)) #设置监听listen
server_tcp_socket.listen(5) while True:
new_socket,new_addr=server_tcp_socket.accept() #等待接受客户端链接
print(("与客户%s建立链接成功,可以交流" % new_addr[0]))
new_socket.send(("您好客户%s,已经建立链接,可以交流" % new_addr[0]).encode("gb2312")) # 链接成功后,发送链接信息
th=Thread(target=recv_send_Thread,args=(new_socket,new_addr))
th.start()
th.join() #收发信息 #释放链接
server_tcp_socket.close()
#select版本的服务器代码
#轮询的方式检测,效率低;32位最多链接1023个,64位最多链接2045个端口
from socket import *
from select import select
from sys import * def main(): server = socket(AF_INET,SOCK_STREAM)
# 解决MSL问题,如果服务器先断开链接,则第四次会后不必等2被时间,即可链接,避免出现等到2倍时间内地址被占用的问题
server.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
address = ("",8000)
server.bind(address)
server.listen(1024)
inputs=[server,stdin]
running = True
while True:
readable,writeable,exceptional = select(inputs,[],[])
for sock in readable: if(sock == server):
s,addr = server.accept()
print(s)
inputs.append(s)
s.send("已经建立好链接".encode("gb2312"))
elif sock == stdin:
cmd = stdin.readline()
running = False
break
else:
msg = sock.recv(1024)
print(msg.decode("gb2312"))
sock.send(("服务器收到了客户端发送的:%s"%(msg.decode("gb2312"))).encode("gb2312"))
if msg.decode("gb2312")=='exit':
#sock.send("将要断开链接".encode("gb2312"))
sock.close()
inputs.remove(sock)
if running==False:
break
server.close()
print("服务器关闭")
if __name__ =="__main__":
main()
# epool 方式实现服务器
# epool是没有套接字上限,是时间通知机制。 pool是轮询机制,解决了套接字有上限的问题。 from socket import *
from select import * s = socket(AF_INET,SOCK_STREAM)
# 解决MSL问题,如果服务器先断开链接,则第四次会后不必等2被时间,即可链接,避免出现等到2倍时间内地址被占用的问题
s.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
addr=("",8000)
s.bind(addr)
s.listen(10)
epoll_l = epoll()
epoll_l.register(s.fileno(),EPOLLIN|EPOLLET) connections={}
addresses={} while True:
epoll_list = epoll_l.poll() for fd,events in epoll_list:
if fd == s.fileno():
soc,addres = s.accept()
soc.send("已经链接链接".encode("gb2312"))
connections[soc.fileno()] = soc
addresses[soc.fileno()] = addres epoll_l.register(soc.fileno(), EPOLLIN|EPOLLET)
elif events == EPOLLIN: msg = connections[fd].recv(1024)
print(msg.decode("gb2312"))
connections[fd].send(("收到了客户端的%s"%msg.decode("gb2312")).encode("gb2312"))
if msg.decode("gb2312") == "exit":
epoll_l.unregister(fd)
connections[fd].close()
print()
else:
pass
# 协程,生成器版本

import time

def A():
while True:
print("----a----")
yield
time.sleep(1) def B(c):
while True:
print("----b----")
c.__next__()
time.sleep(1) a=A()
print(a.__next__())
b=B(a)
# 协程,greenlet版本

from greenlet import greenlet
import time def test1():
while True:
print("A")
gr2.switch()
time.sleep(1) def test2():
while True:
print("B")
gr1.switch()
time.sleep(1) gr1=greenlet(test1)
gr2=greenlet(test2) gr1.switch()
#  gevent版本的服务器

import gevent
#from socket import *
from gevent import socket,monkey
monkey.patch_all() def handle_request(conn):
while True:
data=conn.recv(1024)
if not data:
conn.close()
break
print("recv:%s"%data.decode("gb2312"))
conn.send(data) def server(port):
s=socket.socket()
# 解决MSL问题,如果服务器先断开链接,则第四次会后不必等2被时间,即可链接,避免出现等到2倍时间内地址被占用的问题
#s.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
s.bind(("",port))
s.listen(5)
while True:
cli,addr = s.accept()
cli.send("已经连接成功".encode("gb2312"))
gevent.spawn(handle_request,cli) if __name__=="__main__":
server(8000)

客户端程序:

# 客户端程序
from socket import * # 创建socket
tcpClientSocket = socket(AF_INET, SOCK_STREAM) # 链接服务器
serAddr = ('192.168.249.210', 8000)
tcpClientSocket.connect(serAddr) # 建立连接
recvData = tcpClientSocket.recv(1024) # 接收数据
print('接收到的数据为:'+recvData.decode("gb2312"))
while True:
# 提示用户输入数据
sendData = input("请输入要发送的数据:")
tcpClientSocket.send(sendData.encode("gb2312")) # 循环发送数据
if sendData == "exit":
break
# 接收对方发送过来的数据,最大接收1024个字节
recvData = tcpClientSocket.recv(1024) # 循环接收数据
print('接收到的数据为:'+recvData.decode("gb2312")) # 关闭套接字
tcpClientSocket.close()

面向连接的tcp 编程的更多相关文章

  1. 基于TCP(面向连接)的Socket编程

    基于TCP(面向连接)的Socket编程 一.客户端: 1.打开一个套接字(Socket); 2.发起连接请求(connect); 3.如果连接成功,则进行数据交换(read.write.send.r ...

  2. 初识-----基于Socket的UDP和TCP编程及测试代码

    一.概述 TCP(传输控制协议)和UDP(用户数据报协议是网络体系结构TCP/IP模型中传输层一层中的两个不同的通信协议. TCP:传输控制协议,一种面向连接的协议,给用户进程提供可靠的全双工的字节流 ...

  3. [C# 网络编程系列]专题五:TCP编程

    转自:http://www.cnblogs.com/zhili/archive/2012/08/25/2656840.html 前言 前面专题的例子都是基于应用层上的HTTP协议的介绍, 现在本专题来 ...

  4. 基于Socket的UDP和TCP编程介绍

    一.概述 TCP(传输控制协议)和UDP(用户数据报协议是网络体系结构TCP/IP模型中传输层一层中的两个不同的通信协议. TCP:传输控制协议,一种面向连接的协议,给用户进程提供可靠的全双工的字节流 ...

  5. C#网络程序设计(3)网络传输编程之TCP编程

        网络传输编程指基于各种网络协议进行编程,包括TCP编程,UDP编程,P2P编程.本节介绍TCP编程.     (1)TCP简介: TCP是TCP/IP体系中最重要的传输层协议,它提供全双工和可 ...

  6. JAVA 通过 Socket 实现 TCP 编程

    简介 TCP简介 TCP(Transmission Control Protocol 传输控制协议)是一种面向连接的.可靠的.基于字节流的传输层通信协议,由IETF的RFC 793定义.在简化的计算机 ...

  7. Windows Socket的UDP和TCP编程介绍

    1:网络中进程之间如何通信 为了实现进程之间通信,首要解决的问题是如何唯一标识一个进程,在本地可以通过进程PID来唯一标识一个进程,但是在网络中则是行不通的,其实TCP/IP协议族已经帮我们解决了这个 ...

  8. 转:【专题五】TCP编程

    前言 前面专题的例子都是基于应用层上的HTTP协议的介绍, 现在本专题来介绍下传输层协议——TCP协议,主要介绍下TCP协议的工作过程和基于TCP协议的一个简单的通信程序,下面就开始本专题的正文了. ...

  9. 第13章 TCP编程(1)_socket套接字

    1. socket套接字 (1)套接字简介 ①socket是一种通讯机制,它包含一整套的调用接口和数据结构的定义,它给应用进程提供了使用如TCP/UDP等网络协议进行网络通讯的手段. ②Linux中的 ...

随机推荐

  1. 面试题--Java

    &与&&区别? &与&&都是逻辑运算符,都是判断两边为真则为真,两边为假则为假,但是&&如果第一个条件不成立的话,后面的将不会再继续执行 ...

  2. <? extends T> <? super T>

    拿前者来说,这其实就是一个指定的泛型,不过这个泛型可以是T及T的任何子类, 如果一个set方法,是把一个泛型对象T赋值给一个泛型T属性,现在这个T变成了<? extends T>,那么se ...

  3. nodejs --- formidable模块 , post 上传.

    1. 只有一个文件域: var formidable = require('formidable'), http = require('http'), util = require('util'); ...

  4. wc语法2

    wc命令的功能为统计指定文件中的字节数.字数.行数, 并将统计结果显示输出. 语法:wc [选项] 文件… 说明:该命令统计给定文件中的字节数.字数.行数.如果没有给出文件名,则从标准输入读取.wc同 ...

  5. 剑指Offer 50. 数组中重复的数字 (数组)

    题目描述 在一个长度为n的数组里的所有数字都在0到n-1的范围内. 数组中某些数字是重复的,但不知道有几个数字是重复的.也不知道每个数字重复几次.请找出数组中任意一个重复的数字. 例如,如果输入长度为 ...

  6. python 前端 html

    web 服务本质: 浏览器发出请求--HTTP协议--服务端接收信息----服务端返回响应---服务端把HTML文件发给浏览器--浏览器渲染页面. HTML: 超文本标记语言是一种用于创建网页的标记语 ...

  7. gitlab修改默认端口

    部署gitlab的时候,一启动,发现80和8080端口已经被占用,无奈,只得先将监听80端口的nginx和监听8080端口的jenkins停止.这会儿有空,琢磨一下如何修改gitlab的默认端口. 修 ...

  8. spring jpa + mybatis快速开始:

    springmvc开始搭建 源码地址 https://gitee.com/flydb/spingjpamy pom: <packaging>war</packaging> &l ...

  9. Itellij Idea全局搜索

    Ctrl+N按名字搜索类   1 相当于eclipse的ctrl+shift+R,输入类名可以定位到这个类文件 2 就像idea在其它的搜索部分的表现一样,搜索类名也能对你所要搜索的内容多个部分进行匹 ...

  10. 查看linux系统CPU及内存配置

    总核数 = 物理CPU个数 X 每颗物理CPU的核数 总逻辑CPU数 = 物理CPU个数 X 每颗物理CPU的核数 X 超线程数 查看物理CPU个数 cat /proc/cpuinfo| grep & ...