用python代码1、 设计一个信息系统,系统必须通过客户端录入账号口令远程登录; 2、 登录后客户端可通过键盘输入向服务器发送数据; 3、 服务器端设置嗅探关键字,如果客户端发送的数据包含该关键字,即将该数据显示出来。

时间: 2024-04-30 19:24:07 浏览: 19
这里提供一个基于socket的简单实现代码: 服务器端代码: ```python import socket # 设置嗅探关键字 KEYWORD = "hello" # 创建socket对象 server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 绑定IP和端口号 server_socket.bind(("localhost", 8888)) # 监听连接 server_socket.listen(1) print("服务器已启动,等待客户端连接...") # 等待客户端连接 client_socket, client_address = server_socket.accept() print(f"客户端 {client_address[0]}:{client_address[1]} 已连接。") # 接收客户端发送的数据并检查关键字 while True: data = client_socket.recv(1024).decode() if not data: break if KEYWORD in data: print(f"收到客户端 {client_address[0]}:{client_address[1]} 发来的数据:{data}") else: print("未检测到关键字。") # 关闭socket连接 client_socket.close() server_socket.close() print("服务器已关闭。") ``` 客户端代码: ```python import socket # 输入账号和口令 account = input("请输入账号:") password = input("请输入口令:") # 创建socket对象 client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 连接服务器 client_socket.connect(("localhost", 8888)) print("连接成功。") # 发送账号和口令 client_socket.send(f"{account} {password}".encode()) # 发送数据 while True: data = input("请输入要发送的数据:") if not data: break client_socket.send(data.encode()) # 关闭socket连接 client_socket.close() print("客户端已关闭。") ``` 运行客户端代码后,会要求输入账号和口令,输入后会连接服务器。然后可以输入要发送的数据,如果数据包含关键字"hello",服务器会将该数据显示出来。

相关推荐

zip
项目运行 首先确保 node 库安装完成,前端需要在 Vue 文件夹内将前端所需库下载下来。然后是 Electron 的所需要的库。 然后 Django 所需的库需要用 Python 下载 ### 注意事项 Django 关闭 Debug 模式后可能会找不到静态文件 ## 数据库设计 用户数据库设计 | 参数 | 备注 | | ------------ | -------------------------- | | userid | 用户ID,由服务器随机发放。 | | username | 用户名,用户注册时使用。 | | IdentityPub | 用户公钥的一种。 | | SignedPub | 用户公钥的一种。 | | OneTimePub | 用户公钥的一种。 | | EphemeralPub | 用户公钥的一种。 | | IdentityPri | 用户私钥的一种。 | | SignedPri | 用户私钥的一种。 | | OneTimePri | 用户私钥的一种。 | | EphemeralPri | 用户私钥的一种。 | 用户数据库是本地存储用户相关信息的数据库,如果是登陆过的用户或者是本机注册用户,则会存储私钥在本地,如果登录用户在本机没有存储私钥,会在登录时提醒,用户在输入私钥后会在本地进行计算,计算出公钥后会与服务器上存储的公钥进行对比,如果一致则说明输入的私钥正确,会将其转码后存储在数据库中,并完成登录。 好友关系数据库设计 | 参数 | 备注 | | ------------ | -------------------------------------- | | userid | 用户ID,由服务器随机发放。 | | whosfriend | 用户ID,用于鉴别本机不同用户的好友。 | | username | 用户名,该好友的用户名。 | | remark | 备注 | | status | 好友当前状态,用于区分是否为正式好友。 | | IdentityPub | 好友公钥之一 | | SignedPub | 好友公钥之一 | | OneTimePub | 好友公钥之一 | | EphemeralPub | 好友公钥之一 | 好友关系数据库是本地存储用户好友的相关信息的数据库,仅存储好友的公钥信息,由于想要达到一种离线消息的效果,好友是指用户单方面添加的好友,添加好友后会从服务器获取好友的公钥信息,添加好友信息到数据库中,然后即可发送消息。在对方登录后,会从服务器中获取到用户发送的消息,但是判断并非是已添加的好友,会先将对方的公钥信息添加到好友数据库中,但是status值设置为0表示并非正式好友。但是由于已经获取到了对方的公钥信息,可以及时对目标消息进行解密,以免造成消息漏收等错误。这类非正式好友会在好友列表中显示并提示是否添加或删除,只有在添加了好友后才可读取目标发送的消息。 消息保存数据库设计 | 参数 | 备注 -------- 该资源内项目源码是个人的毕设,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! <项目介绍> 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。 --------

最新推荐

recommend-type

Python实现的远程登录windows系统功能示例

Python 实现远程登录 Windows 系统功能主要依赖于 `wmi` 模块,这是一个用于访问 Windows Management Instrumentation (WMI) 的 Python 包。WMI 是 Microsoft 提供的一个标准接口,允许对 Windows 系统进行管理和...
recommend-type

不到40行代码用Python实现一个简单的推荐系统

这里我们将构建一个基于Python的简单电影推荐系统,主要涉及以下步骤: 1. 数据预处理:加载数据集,如ratings.csv(包含用户ID、电影ID、评分和时间戳)和movies.csv(包含电影ID和电影名称)。 2. 数据合并:将...
recommend-type

python学生信息管理系统实现代码

本文将详细介绍如何使用Python实现一个简单的学生信息管理系统。这个系统能够完成学生信息的创建、查看、查询、删除和修改等基本功能。通过阅读和理解以下内容,你可以了解到如何利用Python的文件操作、JSON序列化...
recommend-type

Python制作简易注册登录系统

在Python编程中,创建一个简易的注册登录系统是一项常见的任务,尤其在开发Web应用程序时。本教程将指导你如何利用Python的Flask框架和相关的扩展库来实现这一功能。Flask是一个轻量级的Web服务器网关接口(WSGI)...
recommend-type

python mqtt 客户端的实现代码实例

Python MQTT 客户端是用于实现物联网(IoT)设备通信的一种工具,它基于MQTT (Message Queuing Telemetry Transport) 协议,这是一种轻量级的发布/订阅消息协议,设计思想是开放、简单、小巧,适用于低带宽、高延迟或...
recommend-type

电力电子系统建模与控制入门

"该资源是关于电力电子系统建模及控制的课程介绍,包含了课程的基本信息、教材与参考书目,以及课程的主要内容和学习要求。" 电力电子系统建模及控制是电力工程领域的一个重要分支,涉及到多学科的交叉应用,如功率变换技术、电工电子技术和自动控制理论。这门课程主要讲解电力电子系统的动态模型建立方法和控制系统设计,旨在培养学生的建模和控制能力。 课程安排在每周二的第1、2节课,上课地点位于东12教401室。教材采用了徐德鸿编著的《电力电子系统建模及控制》,同时推荐了几本参考书,包括朱桂萍的《电力电子电路的计算机仿真》、Jai P. Agrawal的《Powerelectronicsystems theory and design》以及Robert W. Erickson的《Fundamentals of Power Electronics》。 课程内容涵盖了从绪论到具体电力电子变换器的建模与控制,如DC/DC变换器的动态建模、电流断续模式下的建模、电流峰值控制,以及反馈控制设计。还包括三相功率变换器的动态模型、空间矢量调制技术、逆变器的建模与控制,以及DC/DC和逆变器并联系统的动态模型和均流控制。学习这门课程的学生被要求事先预习,并尝试对书本内容进行仿真模拟,以加深理解。 电力电子技术在20世纪的众多科技成果中扮演了关键角色,广泛应用于各个领域,如电气化、汽车、通信、国防等。课程通过列举各种电力电子装置的应用实例,如直流开关电源、逆变电源、静止无功补偿装置等,强调了其在有功电源、无功电源和传动装置中的重要地位,进一步凸显了电力电子系统建模与控制技术的实用性。 学习这门课程,学生将深入理解电力电子系统的内部工作机制,掌握动态模型建立的方法,以及如何设计有效的控制系统,为实际工程应用打下坚实基础。通过仿真练习,学生可以增强解决实际问题的能力,从而在未来的工程实践中更好地应用电力电子技术。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

图像写入的陷阱:imwrite函数的潜在风险和规避策略,规避图像写入风险,保障数据安全

![图像写入的陷阱:imwrite函数的潜在风险和规避策略,规避图像写入风险,保障数据安全](https://static-aliyun-doc.oss-accelerate.aliyuncs.com/assets/img/zh-CN/2275688951/p86862.png) # 1. 图像写入的基本原理与陷阱 图像写入是计算机视觉和图像处理中一项基本操作,它将图像数据从内存保存到文件中。图像写入过程涉及将图像数据转换为特定文件格式,并将其写入磁盘。 在图像写入过程中,存在一些潜在陷阱,可能会导致写入失败或图像质量下降。这些陷阱包括: - **数据类型不匹配:**图像数据可能与目标文
recommend-type

protobuf-5.27.2 交叉编译

protobuf(Protocol Buffers)是一个由Google开发的轻量级、高效的序列化数据格式,用于在各种语言之间传输结构化的数据。版本5.27.2是一个较新的稳定版本,支持跨平台编译,使得可以在不同的架构和操作系统上构建和使用protobuf库。 交叉编译是指在一个平台上(通常为开发机)编译生成目标平台的可执行文件或库。对于protobuf的交叉编译,通常需要按照以下步骤操作: 1. 安装必要的工具:在源码目录下,你需要安装适合你的目标平台的C++编译器和相关工具链。 2. 配置Makefile或CMakeLists.txt:在protobuf的源码目录中,通常有一个CMa
recommend-type

SQL数据库基础入门:发展历程与关键概念

本文档深入介绍了SQL数据库的基础知识,首先从数据库的定义出发,强调其作为数据管理工具的重要性,减轻了开发人员的数据处理负担。数据库的核心概念是"万物皆关系",即使在面向对象编程中也有明显区分。文档讲述了数据库的发展历程,从早期的层次化和网状数据库到关系型数据库的兴起,如Oracle的里程碑式论文和拉里·埃里森推动的关系数据库商业化。Oracle的成功带动了全球范围内的数据库竞争,最终催生了SQL这一通用的数据库操作语言,统一了标准,使得关系型数据库成为主流。 接着,文档详细解释了数据库系统的构成,包括数据库本身(存储相关数据的集合)、数据库管理系统(DBMS,负责数据管理和操作的软件),以及数据库管理员(DBA,负责维护和管理整个系统)和用户应用程序(如Microsoft的SSMS)。这些组成部分协同工作,确保数据的有效管理和高效处理。 数据库系统的基本要求包括数据的独立性,即数据和程序的解耦,有助于快速开发和降低成本;减少冗余数据,提高数据共享性,以提高效率;以及系统的稳定性和安全性。学习SQL时,要注意不同数据库软件可能存在的差异,但核心语言SQL的学习是通用的,后续再根据具体产品学习特异性。 本文档提供了一个全面的框架,涵盖了SQL数据库从基础概念、发展历程、系统架构到基本要求的方方面面,对于初学者和数据库管理员来说是一份宝贵的参考资料。