使用Python进行Socket接口测试

news2024/9/20 20:43:00

        大家好,在现代软件开发中,网络通信是不可或缺的一部分。无论是传输数据、获取信息还是实现实时通讯,都离不开可靠的网络连接和有效的数据交换机制。而在网络编程的基础中,Socket(套接字)技术扮演了重要角色。

        Socket 允许计算机上的程序通过网络进行通信,它是网络通信的基础。Python 提供了强大且易于使用的 socket 模块,使开发者能够轻松地创建客户端和服务器应用,实现数据传输和交互。

        本文将深入探讨如何利用 Python 编程语言来进行 Socket 接口测试。我们将从基础概念开始介绍,逐步引导大家掌握创建、测试和优化 socket 接口的关键技能。希望本文可以给大家的工作带来一些帮助~

一、引言

简要介绍 socket 编程的重要性和应用场景:

        Socket 编程是计算机网络编程中的基础技术之一,它允许不同计算机之间通过网络进行通信和数据交换。通过 socket,开发者可以实现客户端和服务器之间的数据传输,从简单的消息传递到复杂的实时数据流都可以使用 socket 技术来实现。

        在现代软件开发中,无论是在 Web 开发、移动应用、云计算还是物联网等领域,socket 编程都扮演着重要角色。以下是一些常见的应用场景:

  • 网络通信:例如浏览器与服务器之间的 HTTP 请求、邮件传输等都依赖于 socket 编程。
  • 实时数据传输:如即时通讯应用、在线游戏中的实时状态更新等。
  • 分布式系统:各个节点之间的通信,例如分布式数据库、分布式计算等。
  • 设备控制与监控:物联网中各种设备之间的数据交换和控制。
  • 测试和仿真:在软件开发中,测试 socket 接口的正确性和性能是确保系统稳定运行的关键部分。
概述本文将要讨论的内容和目标:

本文旨在介绍如何使用 Python 编程语言来测试 socket 接口。我们将深入探讨以下主题:

  • Python 中的 socket 编程基础,包括创建 socket 对象、绑定地址和端口、发送和接收数据等基本操作。
  • 如何编写有效的 socket 测试用例,以确保接口功能和性能的稳定性。
  • 演示一个实际的客户端-服务器应用,展示如何使用自动化测试方法来验证 socket 接口的正确性。
  • 讨论一些高级主题,如异常处理、安全性和性能测试,以及多线程或异步 socket 编程的测试技巧。

        通过本文,读者将能够掌握使用 Python 进行 socket 接口测试的基本技能,为他们在日常开发和项目实施中提供实用的工具和方法。

二、Socket 简介

什么是 socket?

        在计算机网络编程中,socket(套接字)是一个抽象层,用于描述网络上的两个应用程序之间的通信链路。它允许程序员通过网络发送和接收数据,就像两个程序之间通过文件系统进行数据交换一样。socket 提供了一种统一的接口,使得不同操作系统上的应用程序可以进行网络通信,而无需关心底层网络细节。

socket 在网络编程中的角色和作用:

        Socket 主要用于实现客户端和服务器之间的通信。它可以用来建立连接、传输数据,并且支持多种不同的传输协议(如TCP、UDP等),从而适应不同的网络通信需求。在网络编程中,socket 扮演了以下几个重要角色:

  • 连接建立和维护:通过 socket,客户端和服务器可以建立稳定的连接,进行长期的数据交换。
  • 数据传输:socket 提供了发送和接收数据的方法,允许应用程序之间在网络上传输信息。
  • 网络协议支持:不同类型的 socket 可以支持多种传输协议,例如 TCP 和 UDP,从而满足不同的数据传输需求。
  • 跨平台兼容性:socket 提供了一种统一的编程接口,使得无论是在 Windows、Linux 还是其他操作系统上,开发者都可以使用相同的方法来实现网络通信。
常见的 socket 类型和用途:

在 socket 编程中,常见的几种 socket 类型包括:

  • 流式 socket(TCP socket):基于 TCP 协议,提供面向连接的可靠数据流传输。它适用于需要确保数据完整性和顺序性的应用,如 HTTP、FTP 等。

  • 数据报式 socket(UDP socket):基于 UDP 协议,提供不可靠的数据报传输。它适用于对数据传输时延要求较低的应用,如实时音视频传输、在线游戏中的实时通讯等。

  • 原始 socket:允许程序直接访问底层网络协议,用于实现特定的网络功能和高级网络安全性需求,如网络包嗅探、防火墙等。

常见的 socket 应用场景包括但不限于:

  • Web 服务器和客户端通信:浏览器通过 TCP socket 与 Web 服务器进行 HTTP 通信,获取网页内容。

  • 即时通讯应用:使用 UDP socket 实现实时消息传输,如即时聊天、视频会议等。

  • 远程数据获取和处理:通过 socket 连接远程设备,获取实时数据并进行处理,如物联网设备数据采集与监控。

  • 分布式系统通信:各个分布式系统节点之间的数据交换和同步,通过 socket 实现节点间的通信。

        总之,socket 是网络编程中不可或缺的技术基础,它提供了灵活、高效的数据传输机制,支持多种应用场景和需求,是现代软件开发中必要的工具之一。

三、Python 中的 Socket 编程

Python 中的 socket 模块简介

        Python 提供了一个内置的 socket 模块,使得开发者可以轻松地进行网络通信。这个模块实现了许多与网络相关的函数和类,使得创建客户端和服务器应用程序变得简单和直观。

创建 socket 对象

        在 Python 中,使用 socket 模块创建一个 socket 对象非常简单。可以根据需要选择创建 TCP socket 还是 UDP socket。下面是一个简单的例子,展示如何创建一个 TCP socket 客户端:

import socket

# 创建 TCP socket 对象
client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

在这个例子中,socket.socket() 函数接受两个参数:

  • socket.AF_INET 表示使用 IPv4 地址族。
  • socket.SOCK_STREAM 表示创建一个 TCP socket。如果要创建 UDP socket,可以使用 socket.SOCK_DGRAM
绑定 socket 到地址和端口

        在服务器端,需要将 socket 绑定到特定的地址(通常是主机的 IP 地址)和端口上,以便客户端可以连接到服务器。下面是一个示例展示如何在服务器端创建一个 TCP socket 并绑定到地址和端口:

import socket

# 创建 TCP socket 对象
server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

# 绑定到地址和端口
server_address = ('localhost', 8888)  # 使用本地地址和端口8888
server_socket.bind(server_address)

        在这个例子中,server_socket.bind() 方法将服务器 socket 绑定到 localhost 地址和 8888 端口上。

发送和接收数据

        一旦建立了连接,客户端和服务器就可以通过 socket 对象发送和接收数据。下面是一个简单的示例展示如何在客户端和服务器之间进行数据交换:

服务器端代码:
import socket

# 创建 TCP socket 对象
server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

# 绑定到地址和端口
server_address = ('localhost', 8888)
server_socket.bind(server_address)

# 监听连接
server_socket.listen(1)

print("等待客户端连接...")
connection, client_address = server_socket.accept()

try:
    print(f"连接来自 {client_address}")
    
    # 接收数据
    data = connection.recv(1024)
    print(f"收到来自客户端的数据:{data.decode()}")

    # 发送数据
    message = "Hello, client!"
    connection.sendall(message.encode())
finally:
    # 关闭连接
    connection.close()
    server_socket.close()

客户端代码:

import socket

# 创建 TCP socket 对象
client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

# 连接服务器
server_address = ('localhost', 8888)
client_socket.connect(server_address)

try:
    # 发送数据
    message = "Hello, server!"
    client_socket.sendall(message.encode())

    # 接收数据
    data = client_socket.recv(1024)
    print(f"收到来自服务器的数据:{data.decode()}")
finally:
    # 关闭连接
    client_socket.close()

        在这个例子中,客户端和服务器通过 socket.sendall() 方法发送数据,并通过 socket.recv() 方法接收数据。数据的传输是基于 TCP 的,确保了数据的完整性和顺序性。

四、编写 Socket 测试用例

使用 Python 的 unittest 或其他测试框架

        在 Python 中,可以使用标准库中的 unittest 模块来编写和运行测试用例。unittest 提供了一种结构化的方式来组织测试,并提供丰富的断言方法来验证预期行为。除了 unittest,还有其他测试框架如 pytest,它们也能很好地支持 socket 测试。

设计测试用例的结构和目标

        良好的测试用例应该覆盖各种情况,包括正常情况和异常情况,以确保 socket 接口的稳定性和正确性。以下是设计 socket 测试用例时的一些结构和目标:

  1. 连接测试

    • 确认服务器可以正确建立和接受客户端连接。
    • 确保客户端能够成功连接到服务器。
  2. 数据发送和接收测试

    • 确保服务器能够接收并正确处理来自客户端的数据。
    • 确保客户端能够成功发送数据并接收到服务器的响应。
  3. 异常情况测试

    • 测试在不同网络条件下的连接超时或断开处理。
    • 测试非法数据或格式错误时的处理。
  4. 性能测试(可选):

    • 测试在大数据量传输时的性能表现,如吞吐量和延迟。
示例:连接测试、数据发送和接收测试等

        下面是一个简单的示例,展示如何使用 unittest 编写 socket 测试用例。这个示例包括连接测试和数据发送接收测试。

import unittest
import socket
import threading

class TestSocket(unittest.TestCase):
    
    def setUp(self):
        # 启动一个简单的服务器
        self.server_thread = threading.Thread(target=self.run_server)
        self.server_thread.start()
    
    def tearDown(self):
        # 关闭服务器
        self.server_socket.close()
        self.server_thread.join()
    
    def run_server(self):
        self.server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        server_address = ('localhost', 8888)
        self.server_socket.bind(server_address)
        self.server_socket.listen(1)
        
        self.conn, self.client_address = self.server_socket.accept()
        
    def test_connection(self):
        # 测试连接是否成功
        client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        client_socket.connect(('localhost', 8888))
        client_socket.close()
    
    def test_send_receive(self):
        # 测试数据发送和接收
        message = "Hello, server!"
        client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        client_socket.connect(('localhost', 8888))
        client_socket.sendall(message.encode())
        
        received_data = self.conn.recv(1024)
        self.assertEqual(received_data.decode(), message)
        
        client_socket.close()

if __name__ == '__main__':
    unittest.main()

在这个示例中:

  • setUp() 方法用于启动一个简单的服务器,并在 tearDown() 方法中关闭服务器。
  • run_server() 方法创建服务器 socket 并绑定到 localhost:8888,等待客户端连接。
  • test_connection() 方法测试客户端是否能成功连接到服务器。
  • test_send_receive() 方法测试客户端发送数据给服务器并接收服务器的响应。

        通过这些测试用例,可以验证服务器和客户端在正常情况下的基本连接、数据发送和接收功能。可以根据具体的需求进一步扩展和优化这些测试用例,确保覆盖更多的场景和边界条件,以提高测试的全面性和可靠性。

五、实际案例演示

        在这部分,我们将演示一个简单的客户端-服务器应用,并展示如何编写测试用例来测试该应用的 socket 接口。重点将介绍如何模拟客户端和服务器,进行单元测试和集成测试。

1. 简单的客户端-服务器应用

        我们将创建一个简单的客户端-服务器应用,客户端向服务器发送消息,服务器接收并回复消息。以下是服务器端和客户端的实现:

服务器端代码 (server.py):
import socket

def start_server():
    server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    server_address = ('localhost', 8888)
    server_socket.bind(server_address)
    server_socket.listen(1)
    
    print(f"服务器启动,监听地址:{server_address}")
    
    while True:
        conn, client_address = server_socket.accept()
        print(f"客户端 {client_address} 连接成功!")
        
        try:
            while True:
                data = conn.recv(1024)
                if data:
                    print(f"收到来自客户端的消息:{data.decode()}")
                    conn.sendall(b"消息已收到")
                else:
                    break
        finally:
            conn.close()

if __name__ == "__main__":
    start_server()

客户端代码 (client.py):

import socket

def start_client(message):
    client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    server_address = ('localhost', 8888)
    client_socket.connect(server_address)
    
    try:
        # 发送消息
        client_socket.sendall(message.encode())
        
        # 接收服务器回复
        data = client_socket.recv(1024)
        print(f"收到服务器的回复:{data.decode()}")
    finally:
        client_socket.close()

if __name__ == "__main__":
    message = "Hello, server!"
    start_client(message)
2. 编写测试用例来测试 socket 接口

        接下来,我们将编写测试用例来测试这个简单的客户端-服务器应用的 socket 接口。我们将使用 unittest 模块来组织和运行测试。

测试用例代码 (test_socket_app.py):
import unittest
import socket
import threading
import time
from client import start_client
from server import start_server

class TestSocketApp(unittest.TestCase):
    
    @classmethod
    def setUpClass(cls):
        cls.server_thread = threading.Thread(target=start_server)
        cls.server_thread.start()
        # 等待服务器启动
        time.sleep(1)
    
    @classmethod
    def tearDownClass(cls):
        # 关闭服务器
        client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        server_address = ('localhost', 8888)
        client_socket.connect(server_address)
        client_socket.close()
        cls.server_thread.join()
    
    def test_client_server_communication(self):
        message = "Hello, server!"
        start_client(message)
    
    def test_server_response(self):
        client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        server_address = ('localhost', 8888)
        client_socket.connect(server_address)
        
        try:
            # 发送消息
            message = "Ping!"
            client_socket.sendall(message.encode())
            
            # 接收服务器回复
            data = client_socket.recv(1024)
            self.assertEqual(data.decode(), "消息已收到")
        finally:
            client_socket.close()

if __name__ == '__main__':
    unittest.main()

3. 如何模拟客户端和服务器,进行单元测试和集成测试

在上面的示例中,我们通过以下方式模拟客户端和服务器进行测试:

  • 服务器启动和关闭

    • 在测试用例的 setUpClass() 方法中,启动一个独立的线程运行服务器。这样可以在单元测试中独立运行服务器,并在 tearDownClass() 方法中关闭服务器。
  • 客户端与服务器通信测试

    • test_client_server_communication() 方法测试客户端能否成功向服务器发送消息,并接收到服务器的回复。
  • 服务器响应测试

    • test_server_response() 方法测试客户端发送消息后,服务器能否正确接收并回复消息。

        通过这种方式,我们可以确保客户端和服务器在正常和异常情况下的基本通信功能。在实际应用中,可以进一步扩展测试用例,包括异常处理、性能测试等,以确保整个应用的稳定性和可靠性。

        这种测试方法不仅适用于简单的客户端-服务器应用,也可以扩展应用到更复杂的网络应用程序中,帮助开发者及时发现和修复潜在的网络通信问题。

六、高级主题

        在这部分,我们将详细介绍异常处理和错误场景的测试、安全性和性能测试的考虑,以及多线程或异步 socket 编程的测试方法。这些主题将帮助大家更全面地理解和实施高级的 socket 编程测试策略。

1. 异常处理和错误场景的测试

        在 socket 编程中,异常处理是至关重要的,因为网络通信可能面临各种不可预测的问题,如连接超时、数据丢失、网络中断等。测试时,需要确保程序能够正确地处理这些异常情况,并能够恢复到一个稳定的状态。

示例:

下面是一个简单的例子,展示如何测试服务器端处理客户端连接中断的情况:

import unittest
import socket
import threading
import time
from client import start_client
from server import start_server

class TestSocketExceptionHandling(unittest.TestCase):
    
    @classmethod
    def setUpClass(cls):
        cls.server_thread = threading.Thread(target=start_server)
        cls.server_thread.start()
        # 等待服务器启动
        time.sleep(1)
    
    @classmethod
    def tearDownClass(cls):
        # 关闭服务器
        client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        server_address = ('localhost', 8888)
        client_socket.connect(server_address)
        client_socket.close()
        cls.server_thread.join()
    
    def test_client_disconnect_handling(self):
        # 测试客户端断开连接时,服务器的处理
        client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        server_address = ('localhost', 8888)
        client_socket.connect(server_address)
        
        # 关闭客户端连接
        client_socket.close()
        
        # 等待一段时间以确保服务器处理断开连接
        time.sleep(1)
        
        # 尝试重新连接
        try:
            client_socket.connect(server_address)
        except ConnectionRefusedError:
            # 服务器应该拒绝连接
            pass
        else:
            self.fail("服务器未正确处理客户端断开连接情况")
        finally:
            client_socket.close()

if __name__ == '__main__':
    unittest.main()

        在这个测试用例中,我们模拟了客户端断开连接的情况,并验证服务器是否正确地拒绝了重新连接请求。这种方式可以确保服务器在异常情况下的行为符合预期。

2. 安全性和性能测试考虑

        安全性和性能是网络应用程序中另外两个重要的方面。安全性测试确保数据在传输过程中的保密性和完整性,而性能测试则评估系统在负载和高并发条件下的表现。

  • 安全性测试

    • 使用加密算法(如TLS/SSL)保护数据传输的安全性。
    • 防止常见的网络攻击,如拒绝服务(DDoS)攻击。
    • 定期审计和更新安全策略,确保网络通信的安全性。
  • 性能测试

    • 测试在不同负载条件下的响应时间和吞吐量。
    • 模拟大数据量的传输,评估系统的处理能力。
    • 使用性能监控工具(如Apache JMeter、Gatling等)进行压力测试和性能分析。
3. 多线程或异步 socket 编程的测试方法

        在现代应用程序中,多线程或异步编程模型常用于提高系统的并发能力和性能。在这种情况下,需要特别关注如何有效地测试并发场景下的 socket 接口。

示例:

下面是一个简单的示例,演示如何使用 asyncio 模块进行异步 socket 编程的测试:

import asyncio
import unittest
import socket
from client_async import start_client_async
from server_async import start_server_async

class TestAsyncSocket(unittest.TestCase):
    
    @classmethod
    def setUpClass(cls):
        cls.loop = asyncio.new_event_loop()
        asyncio.set_event_loop(cls.loop)
        cls.server = cls.loop.run_until_complete(start_server_async())
    
    @classmethod
    def tearDownClass(cls):
        cls.server.close()
        cls.loop.run_until_complete(cls.server.wait_closed())
        cls.loop.close()
    
    def test_async_client_server_communication(self):
        message = "Hello, server!"
        result = self.loop.run_until_complete(start_client_async(message))
        self.assertEqual(result, "消息已收到")

if __name__ == '__main__':
    unittest.main()

在这个示例中:

  • 使用 asyncio 创建了异步的客户端和服务器实现 (client_async.pyserver_async.py)。
  • TestAsyncSocket 类中的 setUpClass() 方法启动了异步服务器,并在 tearDownClass() 方法中关闭服务器。
  • test_async_client_server_communication() 方法测试了异步客户端向服务器发送消息并接收响应的功能。

        通过这种方式,可以有效地测试多线程或异步环境下的 socket 接口,并确保系统在高并发和异步操作下的稳定性和正确性。

        总结来说,异常处理、安全性和性能测试以及多线程或异步 socket 编程的测试方法是确保网络应用程序质量和稳定性的关键步骤。在设计和实施测试策略时,需要根据具体的应用场景和需求选择合适的测试方法和工具,以达到最佳的测试覆盖和效果。

七、注意事项

        在进行 Socket 编程以及编写相关测试用例时,有几个重要的注意事项需要特别关注。以下将详细介绍这些注意事项,确保示例代码和测试用例能够完整运行并展示预期的结果。

1. 清晰的语言和示意图帮助理解

在编写示例代码和测试用例时,使用清晰简洁的语言是非常重要的。确保每一步操作和每个函数的作用都能清晰地表达出来,避免使用过于复杂的代码结构或术语,以免读者难以理解和理解示例代码的意图。

示意图的使用也能极大地帮助读者理解网络通信的流程和数据传输的路径。例如,可以绘制简单的时序图或数据流图来说明客户端和服务器之间的交互过程。

2. 实用性和实际应用

确保示例代码和测试用例具有实用性和实际应用性。例如,演示一个简单的客户端-服务器应用,展示如何通过 socket 传输数据。这种示例可以直接应用于开发网络应用程序的初学者,帮助他们理解基本的网络通信原理和操作步骤。

在编写测试用例时,关注实际的错误场景和异常处理情况也非常重要。例如,模拟客户端断开连接或网络中断的情况,验证服务器是否能正确地处理这些异常情况并恢复到正常工作状态。

3. 自行尝试和扩展

鼓励读者在理解示例代码和测试用例的基础上,自行尝试和扩展。例如,可以尝试修改示例代码中的端口号或 IP 地址,测试不同网络配置下的表现。另外,可以尝试使用不同的 socket 类型(如 UDP socket),并编写相应的测试用例来验证其行为和性能。

在扩展测试用例时,可以考虑增加更复杂的场景和功能。例如,实现一个支持多客户端并发连接的服务器,并编写相应的性能测试用例来评估其并发处理能力。

示例

为了具体展示以上注意事项,以下提供一个简单的示例:

示例代码 (server.py):

import socket

def start_server():
    server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    server_address = ('localhost', 8888)
    server_socket.bind(server_address)
    server_socket.listen(1)
    
    print(f"服务器启动,监听地址:{server_address}")
    
    while True:
        conn, client_address = server_socket.accept()
        print(f"客户端 {client_address} 连接成功!")
        
        try:
            while True:
                data = conn.recv(1024)
                if data:
                    print(f"收到来自客户端的消息:{data.decode()}")
                    conn.sendall(b"消息已收到")
                else:
                    break
        finally:
            conn.close()

if __name__ == "__main__":
    start_server()

示例测试用例 (test_server.py):

import unittest
import socket
import threading
import time
from client import start_client
from server import start_server

class TestSocketExceptionHandling(unittest.TestCase):
    
    @classmethod
    def setUpClass(cls):
        cls.server_thread = threading.Thread(target=start_server)
        cls.server_thread.start()
        # 等待服务器启动
        time.sleep(1)
    
    @classmethod
    def tearDownClass(cls):
        # 关闭服务器
        client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        server_address = ('localhost', 8888)
        client_socket.connect(server_address)
        client_socket.close()
        cls.server_thread.join()
    
    def test_client_disconnect_handling(self):
        # 测试客户端断开连接时,服务器的处理
        client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        server_address = ('localhost', 8888)
        client_socket.connect(server_address)
        
        # 关闭客户端连接
        client_socket.close()
        
        # 等待一段时间以确保服务器处理断开连接
        time.sleep(1)
        
        # 尝试重新连接
        try:
            client_socket.connect(server_address)
        except ConnectionRefusedError:
            # 服务器应该拒绝连接
            pass
        else:
            self.fail("服务器未正确处理客户端断开连接情况")
        finally:
            client_socket.close()

if __name__ == '__main__':
    unittest.main()

        在这个示例中,我们通过一个简单的服务器和相应的测试用例展示了如何处理客户端断开连接的情况,并确保服务器在异常情况下的行为符合预期。同时,使用了 unittest 来组织和运行测试用例,确保能够清晰地展示预期的测试结果。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1870306.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2024 6.17~6.23 周报

一、上周工作 吴恩达的机器学习、实验-回顾之前密集连接部分 二、本周计划 继续机器学习,同时思考实验如何修改,开始整理代码 三、完成情况 3.1 多类特征、多元线性回归的梯度下降、特征缩放、逻辑回归 多类特征: 多元线性回归的梯度下…

基于PHP的长城景区信息管理系统

有需要请加文章底部Q哦 可远程调试 基于PHP的长城景区信息管理系统 一 介绍 此长城景区信息管理系统基于原生PHP开发,数据库mysql。系统角色分为用户和管理员。 技术栈:phpmysqlphpstudyvscode 二 功能 用户 1 注册/登录/注销 2 浏览长城景区信息(旅…

出手便是王炸,曙光存储将高端存储推向新高度

二十年磨一剑,今朝试锋芒。 近日,曙光存储重磅发布全球首个亿级IOPS集中式全闪存储FlashNexus,正式宣告进入高端存储市场。 作为存储产业皇冠上的明珠,高端存储一向以技术难度大、市场准入门槛高和竞争格局稳定著称,…

React的Props、生命周期

Props 的只读性 “Props” 是 React 中用于传递数据给组件的一种机制,通常作为组件的参数进行传递。在 React 中,props 是只读的,意味着一旦将数据传递给组件的 props,组件就不能直接修改这些 props 的值。所以组件无论是使用函数…

Studying-代码随想录训练营day22| 回溯理论基础、77.组合、216.组合总和II、17.电话号码的字母组合

第22天,回溯章节开始!一大算法难点,加油加油! 回溯理论基础组合问题的剪枝操作 文档讲解:代码随想录回溯理论基础 视频讲解:回溯理论基础 回溯法也叫回溯搜索法,它是一种搜索,遍历的…

数值稳定性、模型初始化和激活函数

一、数值稳定性:神经网络很深的时候数据非常容易不稳定 1、神经网络梯度 h^(t-1)是t-1层的输出,也就是t层的输入,y是需要优化的目标函数,向量关于向量的倒数是一个矩阵。 2、问题:梯度爆炸、梯度消失 (1&…

leetcode-19-回溯

引自代码随想录 [77]组合 给定两个整数 n 和 k,返回 1 ... n 中所有可能的 k 个数的组合。 示例: 输入: n 4, k 2 输出: [ [2,4], [3,4], [2,3], [1,2], [1,3], [1,4]] 1、大致逻辑 k为树的深度,到叶子节点的路径即为一个结果 开始索引保证不重复…

当了面试官才知道:做好这3点,面试成功率至少提高50%

关于辉哥: 资深IT从业者, 曾就职于阿里、腾讯、美团、中信科等互联网公司和央企; 两岁小男孩的父亲。 不定期分享职场 | 婚姻 | 育儿 | 个人成长心得体会 关注我,一起学习和成长。 最近作为公司社招面…

一文入门CMake

我们前几篇文章已经入门了gcc和Makefile,现在可以来玩玩CMake了。 CMake和Makefile是差不多的,基本上是可以相互替换使用的。CMAke可以生成Makefile,所以本质上我们还是用的Makefile,只不过用了CMake就不用再写Makefile了&#x…

Zookeeper 四、Zookeeper应用场景

Zookeeper是一个典型的发布/订阅模式的分布式数据管理与协调框架,我们可以使用它来进行分布式数据的发布与订阅。另一方面,通过对Zookeeper中丰富的数据节点类型进行交叉使用,配合Watcher事件通知机制,可以非常方便地构建一系列分…

Day.js

Day.js 是什么? Day.js是一个极简的JavaScript库,可以为现代浏览器解析、验证、操作和显示日期和时间。 Day.js中文网 为什么要使用Day.js ? 因为Day.js文件只有2KB左右,下载、解析和执行的JavaScript更少,为代码留下更…

如何避免爬取网站时IP被封?

互联网协议 (IP) 地址是识别网络抓取工具的最常见方式。IP 是每个互联网交换的核心,对其进行跟踪和分析可以了解很多有关连接客户端的信息。 在网络抓取中,IP 跟踪和分析(又名指纹)通常用于限制和阻止网络抓取程序或其他不需要的访…

配电房挂轨巡检机器人

配电房作为电网中的重要组成部分。其运行的的安全和稳定性直接影响到电力供应的质量。然而,传统的人工巡检模式存在诸多弊端,例如巡检效率低下、人员安全难以保障、巡检结果主观性强等问题。为了解决这些问题,旗晟机器人推出B3系列升降云台轨…

浅谈LiveData的通知过程

浅谈 LiveData 的通知机制 LiveData 和 ViewModel 一起是 Google 官方的 MVVM 架构的一个组成部分。巧了,昨天分析了一个问题是 ViewModel 的生命周期导致的。今天又遇到了一个问题是 LiveData 通知导致的。而 ViewModel 的生命周期和 LiveData 的通知机制是它们的…

AI绘图软件:设计师的创意加速器

在人工智能的浪潮中,AI绘图软件工具已成为设计师和创意工作者的得力助手,它们不仅加速了复杂绘图任务的完成,还激发了无限创意。本文将为您介绍几款AI绘图软件工具,它如何成为提升工作效率和创意灵感的关键。 1. StartAI&#xf…

ISO37001认证:防范贿赂风险的强大工具

随着全球反贿赂法规的日益严格,各类组织面临的贿赂风险和合规压力不断增加。ISO37001反贿赂管理体系认证应运而生,为组织提供了一个系统化的管理框架,帮助其有效发现、预防和管控贿赂风险。本文将详细探讨ISO37001认证的作用和意义&#xff0…

小白学python(第三天)

小伙伴,大家好呀,昨天的内容吸收的好?昨天有小伙伴私信我,建议我在博文中加点练习题,可以看出这位童鞋很想学好这门语言哈,那我也尽量满足大家的要求。 从控制台输入 语法格式: 变量名 input…

神经网络学习笔记9-简单的反向传播和线性回归

tensor在pytorch中是一个非常重要的类型 假如需要计算梯度,就将tensor中 requires_grad设为true loss是一个张量,在做运算时构建运算图,因此不要直接进行,会将将梯度存入w,当反向传播完成 后,该计算图会…

C# 23设计模式备忘

创建型模式:单例(Singleton)模式:某个类只能生成一个实例,该类提供了一个全局访问点供外部获取该实例,其拓展是有限多例模式。 原型(Prototype)模式:将一个对象作为原型&…

地铁中的CAN通信--地铁高效安全运转原理

目前地铁采用了自动化的技术来实现控制,有ATC(列车自动控制)系统可以实现列车自动驾驶、自动跟踪、自动调度;SCADA(供电系统管理自动化)系统可以实现主变电所、牵引变电所、降压变电所设备系统的遥控、遥信、遥测;BAS(环境监控系统)和FAS(火灾报警系统)可以实现车站…