Python TCP服务端多线程接收RFID网络读卡器上传数据
本示例使用设备介绍:WIFI/TCP/UDP/HTTP协议RFID液显网络读卡器可二次开发语音播报POE-淘宝网 (taobao.com)
#python通过缩进来表示代码块,不可以随意更改每行前面的空白,否则程序会运行错误!!!如果缩进不一致,就会报错: IndentationError
#!/usr/bin/env python
# -*- coding: utf-8 -*-
#python -m pdb xxx.py 调试程度 n命令单步执行,s命令单步执行 会进入函数内部 b xx ,c
#import pdb pdb.set_trace() 设断点import sys
import socketserver
import os
import socket
import time
import pdbclass Server(socketserver.BaseRequestHandler):def handle(self):print("conn is :", self.request) # connprint("client_address is :", self.client_address) # addrwhile True:if self.request:# 接收收消息data = self.request.recv(1024).strip()if not data:print("no data break")breakprint("no data continue")continueGetData = 'Received from %s:%s' % (self.client_address) + " :"for num in range(0, len(data)):GetData = GetData + '%02X ' % (data[num])print(GetData)#解析接收到的数据if (data[0] == eval('0xC1') or data[0] == eval('0xCF')): # 接收IC读卡器上传的读卡号数据、IC卡离开读卡器的信息FunCode = '%02X' % (data[0])DEvIp = '%d.%d.%d.%d' % (data[1], data[2], data[3], data[4]) # 设备IPDevNo = '%05d' % (data[5] + data[6] * 256) # 机号FrameNo = '%d' % (data[7] + data[8] * 256) # 数据包序号Cardlen=data[9]; #卡号长度Card16H="" #16进制卡号for num in range(10, 10+Cardlen):Card16H = Card16H + '%02X' % (data[num])Cardno = data[10] #转10进制卡号Cardno = Cardno + (data[11] * 256)Cardno = Cardno + (data[12] * 65536)Cardno = Cardno + (data[13] * 16777216)CardnoStr = '%010d' % CardnoSerialNum = '' # 设备硬件序列号for num in range(10+Cardlen, len(data)):SerialNum = SerialNum + '%02X' % (data[num])if (data[0] == eval('0xC1')):print('数据解析:IC读卡器刷卡数据,设备IP:' + DEvIp + ',机号:' + DevNo + ",数据包号:" + FrameNo +",卡号长度:"+"%d" %(Cardlen)+ ",16进制卡号:" + Card16H + " 转10进制卡号:" + CardnoStr + ",硬件序列号:" + SerialNum+"\n")else:print('数据解析:IC卡离开读卡器,设备IP:' + DEvIp + ',机号:' + DevNo + ",数据包号:" + FrameNo +",卡号长度:"+"%d" %(Cardlen)+ ",16进制卡号:" + Card16H + " 转10进制卡号:" + CardnoStr + ",硬件序列号:" + SerialNum + "\n")RespByte=GetResponseData(2) #根据不同情况生成要回应指令码self.request.sendall(RespByte) #发送回应指令码SendData = 'Send Data to %s:%s' % (self.client_address) + " :"for num in range(0, len(RespByte)):SendData = SendData + '%02X ' % (RespByte[num])print(SendData+"\n")elif (data[0] == eval('0xD1') or data[0] == eval('0xDF')): # 接收ID读卡器上传的读卡号数据、ID卡离开读卡器数据FunCode = '%02X' % (data[0])DEvIp = '%d.%d.%d.%d' % (data[1], data[2], data[3], data[4]) # 设备IPDevNo = '%05d' % (data[5] + data[6] * 256) # 机号FrameNo = '%d' % (data[7] + data[8] * 256) # 数据包序号Card16H = '%02X%02X%02X%02X%02X' % (data[9],data[10], data[11], data[12], data[13]) # 16进制卡号Cardno = data[9] #转10进制卡事情Cardno = Cardno + (data[10] * 256)Cardno = Cardno + (data[11] * 65536)Cardno = Cardno + (data[12] * 16777216)CardnoStr = '%010d' % CardnoSerialNum = '' # 设备硬件序列号for num in range(14, len(data)):SerialNum = SerialNum + '%02X' % (data[num])if (data[0] == eval('0xD1')):print('数据解析:ID读卡器刷卡数据,设备IP:' + DEvIp + ',机号:' + DevNo + ",数据包号:" + FrameNo + ",16进制卡号:" + Card16H + " 转10进制卡号:" + CardnoStr + ",硬件序列号:" + SerialNum + "\n")else:print('数据解析:ID卡离开读卡器,设备IP:' + DEvIp + ',机号:' + DevNo + ",数据包号:" + FrameNo + ",16进制卡号:" + Card16H + " 转10进制卡号:" + CardnoStr + ",硬件序列号:" + SerialNum + "\n")RespByte = GetResponseData(2) # 根据不同情况生成要回应指令码self.request.sendall(RespByte) # 发送回应指令码SendData = 'Send Data to %s:%s' % (self.client_address) + " :"for num in range(0, len(RespByte)):SendData = SendData + '%02X ' % (RespByte[num])print(SendData + "\n")elif (data[0] == eval('0xF3')): # 接收到设备的心跳数据包,设备心跳间隔可根据协议自行设置FunCode = '%02X' % (data[0])DEvIp = '%d.%d.%d.%d' % (data[1], data[2], data[3], data[4]) # 设备IPDevNo = '%05d' % (data[5] + data[6] * 256) # 机号FrameNo = '%d' % (data[7] + data[8] * 256) # 数据包序号heartbeattype='%02X' % (data[9])outleng='%d' % (data[10])switchon='%02X' % (data[11])inputinf='%02X' % (data[12])rand='%02X%02X%02X%02X' % (data[13], data[14], data[15], data[16])SerialNum = ''for num in range(17, len(data)):SerialNum = SerialNum + '%02X' % (data[num])print('接收数据解析:设备心跳包,设备IP:' + DEvIp + ',机号:' + DevNo + ",数据包号:" + FrameNo + ",心跳类型:" + heartbeattype + ",长度:" + outleng+ ",继电器状态:" + switchon + ",输入接口状态:" + inputinf + ",随机校验码:" + rand + ",硬件序列号:" + SerialNum + "\n")def GetResponseData(respcode): # 生成不同的回应数据sdata=bytearray()if (respcode==0): # 生成蜂鸣响声的回应数据sdata.append(eval('0x96')) # 蜂鸣响声的指令码sdata.append(eval('0x00')) # 机号低sdata.append(eval('0x00')) # 机号高,0000表示任意机号sdata.append(eval('0x01')) # 蜂鸣响声代码,取值范围0-12elif(respcode==1): # 生成显示文字+蜂鸣响声的 回应数据DispStr = "本次刷卡成功,感谢您的使用,再见! "DispByte = bytes(DispStr, encoding='gbk') # 将要显示的文字转bytesDispByte = DispByte[0:34] # 两行屏可以显示34个字符CommByte=bytes([eval('0x5A'), 0, 0, 2, 30]) # 5A是指令码+2字节机号+1字节蜂鸣代码+1字节显示时长sdata = CommByte + DispByte # 加入显示文字的ASC码elif (respcode == 2): # 生成显示文字+蜂鸣响声的+继电器开关+TTS中文语音的 回应数据DispStr = "本次刷卡成功,感谢您的使用,再见! "DispByte = bytes(DispStr, encoding='gbk') # 将要显示的文字转bytesDispByte = DispByte[0:34] # 两行屏可以显示34个字符SpkStr = '[v1]欢迎您使用我们的网络读卡器,谢谢!' # 要播报的TTS语音,[v10]表示音量,取值0-16,可放置字符串的任意地方,一次最多126个字节Spkb = bytes(SpkStr, encoding='gbk') # 将要播报的TTS语音转bytes,Spkl = len(Spkb) # TTS语音长度sufb = bytes([eval('0x55'), eval('0xaa'), eval('0x66'), eval('0x99')]) # 固定的抗干扰后缀comb = bytes([eval('0x5C'), 0, 0, 1, eval('0xF0'), 20, 0, 20, 0, 34,Spkl]) # 5C是指令码+2字节机号+1字节蜂鸣代码+1字节继电器代码+2字节继电器延时+1字节显示时长+1字节显示起始位+1字节显示长度+1语音长度sdata = comb + DispByte + Spkb + sufbelif (respcode == 3): # 生成开启继电器开关的 回应数据sdata.append(eval('0x78')) # 蜂鸣响声的指令码sdata.append(eval('0x00')) # 机号低sdata.append(eval('0x00')) # 机号高,0000表示任意机号sdata.append(eval('0xF0')) # 继电器代码 F0表示全部继电器、F1表示1号继电器 、F2表示2号继电器......sdata.append(eval('0x2c')) # 继电器开启延时低位sdata.append(eval('0x01')) # 继电器开启延时高位,FFFF表示继电器一直开启return sdataif __name__ == "__main__":IpList = []if sys.platform == 'linux' or sys.platform == 'mac': # linux、mac系统获取电脑所有网卡IPips = [ip.split('/')[0] for ip in os.popen("ip addr | grep 'inet '|awk '{print $2}'").readlines()]for i in ips:IpList.append(i)print('%d ' % (len(IpList)) + i)else:addrs = socket.getaddrinfo(socket.gethostname(), None) # windows获取电脑所有网卡IPfor item in addrs:if ':' not in item[4][0]:IpList.append(item[4][0])print('%d ' % (len(IpList)) + item[4][0])Bindip = IpList[0] # 如有多张网卡,可选择绑定不同的网卡address = ('', 39169) # 未指定绑定网卡,可侦听本机所有网卡信息,读卡器出厂默认39169通讯端口with socketserver.ThreadingTCPServer(address, Server) as server:try:server.serve_forever()except Exception as e:print(e)passpass
相关文章:

Python TCP服务端多线程接收RFID网络读卡器上传数据
本示例使用设备介绍:WIFI/TCP/UDP/HTTP协议RFID液显网络读卡器可二次开发语音播报POE-淘宝网 (taobao.com) #python通过缩进来表示代码块,不可以随意更改每行前面的空白,否则程序会运行错误!!!如果缩进不…...

Ubuntu22.04安装MySql
在Ubuntu上安装mysql就比较简单了 1、常规操作,更新软件包列表 apt update 至少安装之前看一眼版本吧 apt list mysql-server 嗯,是8.0.35版本的 2、安装mysql apt install mysql-server 3、给root用户设置密码 # 第一次安装完无需密码,让你输入…...
设计模式-桥接模式(Bridge)
设计模式-桥接模式(Bridge) 一、桥接模式概述1.1 什么是桥接模式1.2 简单实现桥接模式 二、使用桥接模式注意事项三、实现桥接模式的方式3.1 使用继承和组合的方式实现桥接模式3.2 使用接口和内部类的方式实现桥接模式 一、桥接模式概述 1.1 什么是桥接…...

库存预占架构升级方案设计-交易库存中心
背景介绍  伴随物流行业的迅猛发展,一体化供应链模式的落地,对系统吞吐、系统稳定发出巨大挑战,库存作为供应链的重中之重表现更为明显。近三年数据可以看出:  接入商家同比增长37.64%、货…...

【redis】ssm项目整合redis,redis注解式缓存及应用场景,redis的击穿、穿透、雪崩的解决方案
目录 一、整合redis 1、介绍 1.1、redis(Remote Dictionary Server) 1.2、MySQL 1.3、区别 2、整合 2.1、配置 2.2、文件配置 2.3、key的生成规则方法 2.4、注意 二、redis注解式缓存 1、Cacheable注解 2、CachePut注解 3、CacheEvict注解…...
chatGPT对英语论文怎么润色呢?
chatGPT对英语论文怎么润色呢? 回答1: 润色英语论文是一项重要的任务,它有助于提高论文的质量、语法准确性和清晰度。以下是一些关于如何润色英语论文的建议: 语法和拼写检查: 使用拼写和语法检查工具,如…...

【机器学习4】降维
常见的降维方法有主成分分析、 线性判别分析、 等距映射、 局部线性嵌入、 拉普拉斯特征映射、 局部保留投影等。 1 PCA最大方差角度理解 PCA无监督学习算法。 PCA的目标, 即最大化投影方差, 也就是让数据在主轴上投影的方差最大。 在黄线所处的轴上&…...

注册商标有助于企业拓展市场渠道
拓展市场渠道 注册商标有助于企业拓展市场渠道。在商业合作和交易中,消费者往往更加倾向于选择有知名度和信誉的品牌。通过注册商标,企业可以树立自己的品牌形象,提高品牌知名度和美誉度,从而更好地开拓市场和拓展业务。同时&…...

推荐能用ios端磁力下载工具
关于ios端磁力下载工具,之前的文章给大家介绍过2个,分别是雷电下载和闪电下载。但是如今因为不可抗力和苹果商店对于磁力下载和云盘功能的限制,目前这两款工具已经不能够使用了。也就是说免费的下载工具已经没有了,毕竟实现ios端这…...
网页文档阅读的学习笔记
1. 阅读邮件 我是一名人工智能专业的博士生,请你帮我总结此页面的要点...

mysql图书管理系统(49-56)源代码
-- 九、 子查询 -- 无关子查询 -- 比较子查询:能确切知道子查询返回的是单值时,可以用>,<,,>,<,!或<>等比较运算符。 -- 49、 查询与“俞心怡”在同一个部门的读者的借…...

使用Docker部署开源分布式任务调度系统DolphinScheduler
🔥博客主页: 小羊失眠啦. 🎥系列专栏:《C语言》 《数据结构》 《Linux》《Cpolar》 ❤️感谢大家点赞👍收藏⭐评论✍️ 使用Docker部署开源分布式任务调度系统DolphinScheduler 文章目录 使用Docker部署开源分布式任务…...
光猫桥接与直接拨号的对比
近期搬家,经历了一次拉宽带,换光猫,购置路由器的过程,有一些总结记录下来,备忘 装宽带之前已经知道桥接的好处就是可以路由器拨号,避免拉胯的光猫拖慢网速,但具体有什么坏处也不清楚࿰…...

使用cpolar配合Plex搭建私人媒体站并实现远程访问
文章目录 1.前言2. Plex网站搭建2.1 Plex下载和安装2.2 Plex网页测试2.3 cpolar的安装和注册 3. 本地网页发布3.1 Cpolar云端设置3.2 Cpolar本地设置 4. 公网访问测试5. 结语 1.前言 用手机或者平板电脑看视频,已经算是生活中稀松平常的场景了,特别是各…...

Web APIs——综合案例
1、学生就业统计表 2、渲染业务 根据持久化数据渲染页面 步骤: ①:读取localstorage本地数据 如果有数据则转换为对象放到变量里面一会使用它渲染页面如果没有则用默认空数组[]为了测试效果,可以先把initData存入本地存储看效果 ②&…...
2023.10月考试战报|华为认证HCIP考试100%通过
相关文章: 考试战报|2023.7月-8月思科认证、华为认证-CSDN博客 2023.4月及5月最新HCIP 考试战报来袭_厦门微思网络的博客-CSDN博客 HCIP 3-4月考试战报_厦门微思网络的博客-CSDN博客 2023年HCIP/CCNP考试战报_厦门微思网络的博客-CSDN博客 2023年10月࿰…...

Oracle 三种分页方法(rownum、offset和fetch、row_number() over())
Oracle的三种分页指的是在进行分页查询时,使用三种不同的方式来实现分页效果,分别是使用rownum、使用offset和fetch、使用row_number() over() 1、使用rownum rownum是oracle中一个伪劣,它用于表示返回的行的序号。使用rownum进行分页查询的方…...
13. 一文快速学懂常用工具——Kubernetes 命令
本章讲解知识点 Kubernetes 基本命令本专栏适合于软件开发刚入职的学生或人士,有一定的编程基础,帮助大家快速掌握工作中必会的工具和指令。本专栏针对面试题答案进行了优化,尽量做到好记、言简意赅。如专栏内容有错漏,欢迎在评论区指出或私聊我更改,一起学习,共同进步。…...
【Linux】shell执行文件清理
#!/usr/bin/env bash ################################################################################# # 程序名称: AutoClearFiles.sh # 创建日期: 2022-11-16 # 作者: evens # 使用说明: …...

Android MotionLayout
MotionLayout exends ConstraintLayout(动画框架 过渡) View动画 API1 属性动画API11 过渡动画API18 root.width RootViewWidth TransitionManager.beginDelayedTransition(view) 过渡动画 可以改变其大小和流畅性 Fade 可以改变透明度 通过TrasitinManager管理 Go:动态替…...
SkyWalking 10.2.0 SWCK 配置过程
SkyWalking 10.2.0 & SWCK 配置过程 skywalking oap-server & ui 使用Docker安装在K8S集群以外,K8S集群中的微服务使用initContainer按命名空间将skywalking-java-agent注入到业务容器中。 SWCK有整套的解决方案,全安装在K8S群集中。 具体可参…...

【JavaEE】-- HTTP
1. HTTP是什么? HTTP(全称为"超文本传输协议")是一种应用非常广泛的应用层协议,HTTP是基于TCP协议的一种应用层协议。 应用层协议:是计算机网络协议栈中最高层的协议,它定义了运行在不同主机上…...
React Native 开发环境搭建(全平台详解)
React Native 开发环境搭建(全平台详解) 在开始使用 React Native 开发移动应用之前,正确设置开发环境是至关重要的一步。本文将为你提供一份全面的指南,涵盖 macOS 和 Windows 平台的配置步骤,如何在 Android 和 iOS…...

图表类系列各种样式PPT模版分享
图标图表系列PPT模版,柱状图PPT模版,线状图PPT模版,折线图PPT模版,饼状图PPT模版,雷达图PPT模版,树状图PPT模版 图表类系列各种样式PPT模版分享:图表系列PPT模板https://pan.quark.cn/s/20d40aa…...

Android 之 kotlin 语言学习笔记三(Kotlin-Java 互操作)
参考官方文档:https://developer.android.google.cn/kotlin/interop?hlzh-cn 一、Java(供 Kotlin 使用) 1、不得使用硬关键字 不要使用 Kotlin 的任何硬关键字作为方法的名称 或字段。允许使用 Kotlin 的软关键字、修饰符关键字和特殊标识…...

C/C++ 中附加包含目录、附加库目录与附加依赖项详解
在 C/C 编程的编译和链接过程中,附加包含目录、附加库目录和附加依赖项是三个至关重要的设置,它们相互配合,确保程序能够正确引用外部资源并顺利构建。虽然在学习过程中,这些概念容易让人混淆,但深入理解它们的作用和联…...

【MATLAB代码】基于最大相关熵准则(MCC)的三维鲁棒卡尔曼滤波算法(MCC-KF),附源代码|订阅专栏后可直接查看
文章所述的代码实现了基于最大相关熵准则(MCC)的三维鲁棒卡尔曼滤波算法(MCC-KF),针对传感器观测数据中存在的脉冲型异常噪声问题,通过非线性加权机制提升滤波器的抗干扰能力。代码通过对比传统KF与MCC-KF在含异常值场景下的表现,验证了后者在状态估计鲁棒性方面的显著优…...
0x-3-Oracle 23 ai-sqlcl 25.1 集成安装-配置和优化
是不是受够了安装了oracle database之后sqlplus的简陋,无法删除无法上下翻页的苦恼。 可以安装readline和rlwrap插件的话,配置.bahs_profile后也能解决上下翻页这些,但是很多生产环境无法安装rpm包。 oracle提供了sqlcl免费许可,…...

Visual Studio Code 扩展
Visual Studio Code 扩展 change-case 大小写转换EmmyLua for VSCode 调试插件Bookmarks 书签 change-case 大小写转换 https://marketplace.visualstudio.com/items?itemNamewmaurer.change-case 选中单词后,命令 changeCase.commands 可预览转换效果 EmmyLua…...

何谓AI编程【02】AI编程官网以优雅草星云智控为例建设实践-完善顶部-建立各项子页-调整排版-优雅草卓伊凡
何谓AI编程【02】AI编程官网以优雅草星云智控为例建设实践-完善顶部-建立各项子页-调整排版-优雅草卓伊凡 背景 我们以建设星云智控官网来做AI编程实践,很多人以为AI已经强大到不需要程序员了,其实不是,AI更加需要程序员,普通人…...