当前位置: 首页 > news >正文

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)源代码

-- 九、 子查询 -- 无关子查询 -- 比较子查询&#xff1a;能确切知道子查询返回的是单值时&#xff0c;可以用>&#xff0c;<&#xff0c;&#xff0c;>&#xff0c;<&#xff0c;!或<>等比较运算符。 -- 49、 查询与“俞心怡”在同一个部门的读者的借…...

使用Docker部署开源分布式任务调度系统DolphinScheduler

&#x1f525;博客主页&#xff1a; 小羊失眠啦. &#x1f3a5;系列专栏&#xff1a;《C语言》 《数据结构》 《Linux》《Cpolar》 ❤️感谢大家点赞&#x1f44d;收藏⭐评论✍️ 使用Docker部署开源分布式任务调度系统DolphinScheduler 文章目录 使用Docker部署开源分布式任务…...

光猫桥接与直接拨号的对比

近期搬家&#xff0c;经历了一次拉宽带&#xff0c;换光猫&#xff0c;购置路由器的过程&#xff0c;有一些总结记录下来&#xff0c;备忘 装宽带之前已经知道桥接的好处就是可以路由器拨号&#xff0c;避免拉胯的光猫拖慢网速&#xff0c;但具体有什么坏处也不清楚&#xff0…...

使用cpolar配合Plex搭建私人媒体站并实现远程访问

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

Web APIs——综合案例

1、学生就业统计表 2、渲染业务 根据持久化数据渲染页面 步骤&#xff1a; ①&#xff1a;读取localstorage本地数据 如果有数据则转换为对象放到变量里面一会使用它渲染页面如果没有则用默认空数组[]为了测试效果&#xff0c;可以先把initData存入本地存储看效果 ②&…...

2023.10月考试战报|华为认证HCIP考试100%通过

相关文章&#xff1a; 考试战报|2023.7月-8月思科认证、华为认证-CSDN博客 2023.4月及5月最新HCIP 考试战报来袭_厦门微思网络的博客-CSDN博客 HCIP 3-4月考试战报_厦门微思网络的博客-CSDN博客 2023年HCIP/CCNP考试战报_厦门微思网络的博客-CSDN博客 2023年10月&#xff0…...

Oracle 三种分页方法(rownum、offset和fetch、row_number() over())

Oracle的三种分页指的是在进行分页查询时&#xff0c;使用三种不同的方式来实现分页效果&#xff0c;分别是使用rownum、使用offset和fetch、使用row_number() over() 1、使用rownum rownum是oracle中一个伪劣&#xff0c;它用于表示返回的行的序号。使用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:动态替…...

基于Ollama的本地大模型开发:handy-llama工具包详解与应用实践

1. 项目概述&#xff1a;一个让Ollama“听话”的本地AI工具箱如果你最近也在折腾本地大模型&#xff0c;大概率听说过Ollama。它确实是个好东西&#xff0c;一条命令就能把Llama、Qwen、Gemma这些主流模型拉到本地跑起来&#xff0c;对开发者来说门槛降低了不少。但用久了你会发…...

告别手动分页!用z-paging在uni-app里5分钟搞定列表加载(附完整配置流程)

告别手动分页&#xff01;用z-paging在uni-app里5分钟搞定列表加载&#xff08;附完整配置流程&#xff09; 每次开发uni-app的列表页&#xff0c;最头疼的就是处理分页逻辑。下拉刷新要重置数据、上拉加载要拼接数组、空状态要手动判断...这些重复劳动不仅浪费时间&#xff0c…...

单调栈入门到精通:每日温度 柱状图中最大的矩形

目录 一、入门题&#xff1a;739. 每日温度&#xff08;中等&#xff09; 题目描述 核心思路&#xff1a;单调栈的本质 代码实现&#xff08;Java&#xff09; 复杂度分析 二、进阶题&#xff1a;84. 柱状图中最大的矩形&#xff08;困难&#xff09; 题目描述 核心思路…...

暗黑破坏神2存档编辑器:d2s-editor完全指南

暗黑破坏神2存档编辑器&#xff1a;d2s-editor完全指南 【免费下载链接】d2s-editor 项目地址: https://gitcode.com/gh_mirrors/d2/d2s-editor 还在为暗黑破坏神2漫长的刷装备过程感到疲惫吗&#xff1f;想要快速体验不同职业build却不想从头练级&#xff1f;d2s-edit…...

Sqlserver 学习笔记

这次的学习内容主要是关于数据库的使用。数据库和表的创建&#xff0c;增删改查的内容一&#xff0c;数据库&#xff08;1&#xff09;数据库的创建create database StudentDB --创建数据库 on primary --定义在主文件组上的文件 ( nameStudentDB_data, --逻辑名称 filenameD:\…...

别把你的命,全拴在那个“单点故障”的工位上

前几天周五晚上&#xff0c;外出回家&#xff0c;正好赶上晚高峰。 挤在地铁1号线里&#xff0c;我旁边站着个小伙子&#xff0c;西装淋得半湿&#xff0c;怀里紧紧抱着个电脑包。他那双眼直勾勾地盯着手机屏幕&#xff0c;屏幕上是密密麻麻的Excel表格。地铁一晃&#xff0c;…...

GNSS形变监测系统

采用GNSS形变监测技术&#xff0c;静态精度&#xff08;差分模式&#xff09;可达水平&#xff08;2.5mm1ppm&#xff09;、垂直&#xff08;5mm1ppm&#xff09;&#xff0c;可精准捕捉矿山边坡每天几毫米的渐进式形变&#xff0c;及时发现早期蠕变迹象&#xff0c;避免隐患累…...

YOLO11涨点优化:Block改进 | 融合EfficientNetV2的Fused-MBConv模块,优化浅层网络特征提取效率

一、写作动机:为什么还要折腾YOLO11? YOLO11作为Ultralytics团队在2025年持续主推的实时目标检测模型,自发布以来在COCO基准和工业落地场景中展现了极强的竞争力。其架构延续了Backbone+Neck+Head的模块化设计,并引入C3k2模块替换上一代C2f、在Backbone末端加入C2PSA注意力…...

GHelper终极指南:3分钟快速配置华硕笔记本性能优化神器

GHelper终极指南&#xff1a;3分钟快速配置华硕笔记本性能优化神器 【免费下载链接】g-helper Lightweight, open-source control tool for ASUS laptops and ROG Ally. Manage performance modes, fans, GPU, battery, and RGB lighting across Zephyrus, Flow, TUF, Strix, S…...

高互动投票制作平台,支持音视频+多客户管理系统

温馨提示&#xff1a;文末有资源获取方式近年来&#xff0c;微信生态中的互动投票依旧是最有效的用户增长方式之一。最近体验了一款全新的投票源码系统V9.8版本&#xff0c;架构全面升级&#xff0c;功能值得一说。源码获取方式在源码闪购网。核心功能亮点多媒体投票支持&#…...