关于如何在PC端和手机设备模拟TCP通讯过程

最近在搞基于okio的socket编程封装,由于条件限制,先必须在本地模拟;

下面记录下过程:

准备工作:PC一台(服务端),能开启Wi-Fi;手机一台(客户端);

网络条件先说明下:

手机跟PC必须在同一个网络;一般就是局域网;

因为我连接的是有线网络,所以让PC开启一个Wi-Fi,

DOS下键入如下命令,即可开启一个Wi-Fi:

netsh wlan start hostednetwork

(如果你之前没有使用过这个命令,是需要设置Wi-Fi名称和秘密的,建议搜索下)

然后让手机连接上这个Wi-Fi

之后继续在DOS下键入

ipconfig

这个是为了拿到无线局域网相关参数,找到里面的ipv4地址,例如192.168.x.1

接下来很关键的一个东西需要你先行确认下

有没有关掉防火墙,非常的关键,否则手机即使连接上这个Wi-Fi,但是没法connect的

关掉防火墙步骤:

找到控制面板-系统和安全-Windows防火墙,左右有一个启用和关闭Windows防火墙;关闭即可

关闭之后,可以测试下,另外找一台电脑,使用下面的命令测试下:

telnet 192.168.x.1 9011

其中9011是服务器模拟的端口号,当然这个命令前提条件是

服务端的程序已经起来了

我这边是用python做模拟的,你可以用其他的

# coding: utf-8

import threading
import socket

encoding = 'unicode_escape'
BUFSIZE = 1024

# a read thread, read data from remote
class Reader(threading.Thread):
    def __init__(self, client):
        threading.Thread.__init__(self)
        self.client = client
        
    def run(self):
        while True:
            data = self.client.recv(BUFSIZE)
            if(data):
                string = bytes.decode(data, encoding)
                print(string)
            else:
                break
        print("close:", self.client.getpeername())
        
    def readline(self):
        rec = self.inputs.readline()
        if rec:
            string = bytes.decode(rec, encoding)
            if len(string)>2:
                string = string[0:-2]
            else:
                string = ' '
        else:
            string = False
        return string

# a listen thread, listen remote connect
# when a remote machine request to connect, it will create a read thread to handle
class Listener(threading.Thread):
    def __init__(self, port):
        threading.Thread.__init__(self)
        self.port = port
        self.sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        self.sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
        self.sock.bind(("0.0.0.0", port))
        self.sock.listen(0)
    def run(self):
        print("listener started")
        while True:
            client, cltadd = self.sock.accept()
            Reader(client).start()
            cltadd = cltadd
            print("accept a connect")

lst  = Listener(9011)   # create a listen thread
lst.start() # then start

代码说明:

self.sock.bind(("0.0.0.0", port))

这个很关键,设置的就是本地的,你用127.0.0.1也可以

端口号最好是大于1024,免得你还要去查询端口号是否被占用;

上面的代码中,可能你还会看到明明是utf-8,为什么出现'unicode_escape'

encoding = 'unicode_escape'

解释下,心跳包发送的字符,没法向下兼容,使用utf-8,是乱码

客户端的的代码就不展示了,到此结束。

记得模拟完成,再将你的防火墙启用即可

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

编辑于

我来说两句

0 条评论
登录 后参与评论

扫码关注云+社区

领取腾讯云代金券