【Python实战】飞机大战
开发一个飞机大战游戏是Python学习的经典实战项目,尤其适合结合面向对象编程和游戏框架(如Pygame)进行实践。以下是游戏设计的核心考虑因素和模块划分建议:
一、游戏设计核心考虑因素
-
性能优化
- Python游戏需注意帧率控制(如60FPS)
- 避免频繁的对象创建/销毁(使用对象池管理子弹、敌机)
- 减少图像缩放等实时计算操作(预加载缩放后的图片)
-
游戏循环(Game Loop)
- 主循环需要处理:事件监听→状态更新→画面渲染→音效播放
- 控制循环频率(如
pygame.time.Clock().tick(60)
)
-
输入控制
- 响应键盘事件(WSAD/方向键移动,空格发射子弹)
- 支持手柄输入(可选扩展)
-
碰撞检测
- 使用矩形碰撞(
pygame.Rect.colliderect
) - 优化检测效率(分组检测:玩家子弹 vs 敌机、敌机 vs 玩家)
- 使用矩形碰撞(
-
游戏状态管理
- 区分不同场景:开始界面、游戏中、暂停、结束界面
- 使用状态机或场景堆栈管理(如
game_state = "playing"
)
-
资源管理
- 集中加载图片、音效、字体(避免重复IO操作)
- 使用相对路径确保跨平台兼容性
-
可扩展性
- 模块化设计,方便新增敌机类型、武器系统
- 配置数据分离(如敌机属性存于JSON文件)
二、游戏核心模块划分
1. 游戏主模块(Main Game)
# ====================== 游戏主逻辑 ======================
class Game:def __init__(self):# 初始化显示self.screen = pygame.display.set_mode((SCREEN_WIDTH, SCREEN_HEIGHT))pygame.display.set_caption("飞机大战")self.clock = pygame.time.Clock()# 加载资源self.load_resources()# 游戏状态self.running = Trueself.score = 0def load_resources(self):"""加载所有资源"""global shoot_sound, explosion_soundshoot_sound = load_sound("pew.wav")explosion_sound = load_sound("expl3.wav")# 初始化精灵组self.all_sprites = pygame.sprite.Group()self.enemies = pygame.sprite.Group()self.bullets = pygame.sprite.Group()# 创建玩家self.player = Player()self.all_sprites.add(self.player)# 创建敌机组self.enemy_spawn_timer = pygame.USEREVENT + 1pygame.time.set_timer(self.enemy_spawn_timer, 1000) # 每秒生成敌机def handle_events(self):"""处理事件循环"""for event in pygame.event.get():if event.type == pygame.QUIT:self.running = Falseelif event.type == pygame.KEYDOWN:if event.key == pygame.K_ESCAPE:self.running = Falseelif event.type == self.enemy_spawn_timer:enemy = Enemy()self.all_sprites.add(enemy)self.enemies.add(enemy)def check_collisions(self):"""检测碰撞事件"""# 子弹击中敌机hits = pygame.sprite.groupcollide(self.enemies, self.bullets, True, True)for hit in hits:self.score += 50explosion_sound.play()# 敌机撞击玩家hits = pygame.sprite.spritecollide(self.player, self.enemies, True)for hit in hits:self.player.health -= 1if self.player.health <= 0:self.game_over()def draw_hud(self):"""绘制游戏界面HUD"""# 绘制得分font = pygame.font.Font(None, 36)score_text = font.render(f"Score: {self.score}", True, WHITE)self.screen.blit(score_text, (10, 10))# 绘制生命值health_text = font.render(f"Health: {self.player.health}", True, RED)self.screen.blit(health_text, (10, 50))def game_over(self):"""游戏结束处理"""font = pygame.font.Font(None, 74)text = font.render("GAME OVER", True, RED)text_rect = text.get_rect(center=(SCREEN_WIDTH / 2, SCREEN_HEIGHT / 2))self.screen.blit(text, text_rect)pygame.display.flip()pygame.time.wait(10000) # 等待2秒self.running = Falsedef run(self):"""游戏主循环"""while self.running:# 控制帧率self.clock.tick(FPS)# 处理输入self.handle_events()keys = pygame.key.get_pressed()if keys[pygame.K_SPACE]:self.player.shoot(self.bullets, self.all_sprites)# 更新游戏状态self.all_sprites.update(keys) # 更新所有精灵self.check_collisions()# 渲染画面self.screen.fill(BLACK)self.all_sprites.draw(self.screen)self.draw_hud()pygame.display.flip()pygame.quit()
2. 精灵类(Sprites)
使用面向对象设计游戏元素:
-
Player(玩家飞机)
"""玩家飞机类"""def __init__(self):super().__init__()self.image = load_image("player.png")self.rect = self.image.get_rect(center=(SCREEN_WIDTH / 2, SCREEN_HEIGHT - 50))self.speed = PLAYER_SPEEDself.health = 3self.shoot_delay = 250 # 射击间隔(毫秒)self.last_shot = pygame.time.get_ticks()def update(self, keys):"""根据键盘输入更新位置"""# 水平移动if keys[pygame.K_LEFT] or keys[pygame.K_a]:self.rect.x -= self.speedif keys[pygame.K_RIGHT] or keys[pygame.K_d]:self.rect.x += self.speed# 垂直移动(可选)if keys[pygame.K_UP] or keys[pygame.K_w]:self.rect.y -= self.speedif keys[pygame.K_DOWN] or keys[pygame.K_s]:self.rect.y += self.speed# 边界约束self.rect.clamp_ip(pygame.Rect(0, 0, SCREEN_WIDTH, SCREEN_HEIGHT))def shoot(self, bullets, all_sprites):"""发射子弹"""now = pygame.time.get_ticks()if now - self.last_shot > self.shoot_delay:self.last_shot = nowbullet = Bullet(self.rect.centerx, self.rect.top)all_sprites.add(bullet)bullets.add(bullet)shoot_sound.play()
-
Enemy(敌机)
def __init__(self):super().__init__()self.image = load_image("enemy1.png")self.rect = self.image.get_rect()self.rect = self.image.get_rect(x=random.randrange(SCREEN_WIDTH - self.rect.width),y=random.randrange(-100, -40),)self.speed_y = random.randint(*ENEMY_SPEED_RANGE)self.speed_x = random.choice([-1, 0, 1]) # 横向移动def update(self, *args):"""自动向下移动"""self.rect.y += self.speed_yself.rect.x += self.speed_x# 移出屏幕后删除if self.rect.top > SCREEN_HEIGHT + 10:self.kill()
-
Bullet(子弹)
def __init__(self, x, y):super().__init__()self.image = load_image("bullet3.png")self.rect = self.image.get_rect(center=(x, y))self.speed_y = BULLET_SPEEDdef update(self, *args):"""向上移动"""self.rect.y += self.speed_yif self.rect.bottom < 0: # 移出屏幕后删除self.kill()
三、推荐技术栈
-
游戏框架
- Pygame:最适合2D游戏入门,文档丰富
Pygame官方文档 - Arcade:现代Python游戏库,面向对象更友好
Arcade官网
- Pygame:最适合2D游戏入门,文档丰富
-
素材资源
- 免费素材网站:OpenGameArt、Kenney Assets
- 临时占位素材:可用简单几何图形代替
-
代码结构参考
- GitHub经典项目:pygame-shmup
- 教程:Pygame飞机大战教程
四、开发路线建议
-
基础版本(1-3天)
- 实现玩家移动、发射子弹
- 随机生成敌机,碰撞检测得分
- 显示血量和分数
-
进阶版本(3-7天)
- 添加不同敌机类型(普通/快速/BOSS)
- 实现敌机发射子弹
- 增加音效和爆炸动画
- 支持游戏暂停/继续
-
扩展版本(可选)
- 添加道具系统(护盾、连发武器)
- 实现关卡进度和难度曲线
- 支持本地高分榜(SQLite存储)
- 打包为exe/APK文件
五、避坑指南
- 不要过早优化:先完成核心玩法,再考虑性能
- 善用精灵组(Sprite Groups):
pygame.sprite.Group()
管理同类对象 - 坐标系注意:Pygame的Y轴向下增大(与数学坐标系相反)
- 资源路径问题:使用
os.path
处理路径,避免绝对路径硬编码 - 调试技巧:用
print
输出变量或绘制调试矩形(pygame.draw.rect
)
通过分阶段实现,你将逐步掌握游戏开发的核心模式(状态机、对象池、事件驱动),同时巩固Python面向对象编程和模块化设计能力。
六、总体代码(单文件)
# -*- coding: utf-8 -*-
import pygame
import random
import os# 初始化Pygame和混音器
pygame.init()
pygame.mixer.init()# 游戏常量配置
SCREEN_WIDTH = 480
SCREEN_HEIGHT = 600
FPS = 60
PLAYER_SPEED = 5
ENEMY_SPEED_RANGE = (2, 4)
BULLET_SPEED = -8 # 玩家子弹速度(向上)# 颜色定义
BLACK = (0, 0, 0)
WHITE = (255, 255, 255)
RED = (255, 0, 0)# 资源路径配置
game_folder = os.path.dirname(__file__)
img_folder = os.path.join(game_folder, "images")
snd_folder = os.path.join(game_folder, "sounds")# 加载图形资源
def load_image(file):"""加载图像并转换格式,返回图像和矩形"""path = os.path.join(img_folder, file)try:image = pygame.image.load(path).convert()except pygame.error as e:print(f"无法加载图像: {path}")raise SystemExit(e)image.set_colorkey(BLACK) # 设置透明色return image# 加载音效资源
def load_sound(file):"""加载音效文件"""path = os.path.join(snd_folder, file)try:return pygame.mixer.Sound(path)except pygame.error as e:print(f"无法加载音效: {path}")return None# ====================== 游戏精灵类 ======================
class Player(pygame.sprite.Sprite):"""玩家飞机类"""def __init__(self):super().__init__()self.image = load_image("player.png")self.rect = self.image.get_rect(center=(SCREEN_WIDTH / 2, SCREEN_HEIGHT - 50))self.speed = PLAYER_SPEEDself.health = 3self.shoot_delay = 250 # 射击间隔(毫秒)self.last_shot = pygame.time.get_ticks()def update(self, keys):"""根据键盘输入更新位置"""# 水平移动if keys[pygame.K_LEFT] or keys[pygame.K_a]:self.rect.x -= self.speedif keys[pygame.K_RIGHT] or keys[pygame.K_d]:self.rect.x += self.speed# 垂直移动(可选)if keys[pygame.K_UP] or keys[pygame.K_w]:self.rect.y -= self.speedif keys[pygame.K_DOWN] or keys[pygame.K_s]:self.rect.y += self.speed# 边界约束self.rect.clamp_ip(pygame.Rect(0, 0, SCREEN_WIDTH, SCREEN_HEIGHT))def shoot(self, bullets, all_sprites):"""发射子弹"""now = pygame.time.get_ticks()if now - self.last_shot > self.shoot_delay:self.last_shot = nowbullet = Bullet(self.rect.centerx, self.rect.top)all_sprites.add(bullet)bullets.add(bullet)shoot_sound.play()class Enemy(pygame.sprite.Sprite):"""敌机基类"""def __init__(self):super().__init__()self.image = load_image("enemy1.png")self.rect = self.image.get_rect()self.rect = self.image.get_rect(x=random.randrange(SCREEN_WIDTH - self.rect.width),y=random.randrange(-100, -40),)self.speed_y = random.randint(*ENEMY_SPEED_RANGE)self.speed_x = random.choice([-1, 0, 1]) # 横向移动def update(self, *args):"""自动向下移动"""self.rect.y += self.speed_yself.rect.x += self.speed_x# 移出屏幕后删除if self.rect.top > SCREEN_HEIGHT + 10:self.kill()class Bullet(pygame.sprite.Sprite):"""玩家子弹类"""def __init__(self, x, y):super().__init__()self.image = load_image("bullet3.png")self.rect = self.image.get_rect(center=(x, y))self.speed_y = BULLET_SPEEDdef update(self, *args):"""向上移动"""self.rect.y += self.speed_yif self.rect.bottom < 0: # 移出屏幕后删除self.kill()# ====================== 游戏主逻辑 ======================
class Game:def __init__(self):# 初始化显示self.screen = pygame.display.set_mode((SCREEN_WIDTH, SCREEN_HEIGHT))pygame.display.set_caption("飞机大战")self.clock = pygame.time.Clock()# 加载资源self.load_resources()# 游戏状态self.running = Trueself.score = 0def load_resources(self):"""加载所有资源"""global shoot_sound, explosion_soundshoot_sound = load_sound("pew.wav")explosion_sound = load_sound("expl3.wav")# 初始化精灵组self.all_sprites = pygame.sprite.Group()self.enemies = pygame.sprite.Group()self.bullets = pygame.sprite.Group()# 创建玩家self.player = Player()self.all_sprites.add(self.player)# 创建敌机组self.enemy_spawn_timer = pygame.USEREVENT + 1pygame.time.set_timer(self.enemy_spawn_timer, 1000) # 每秒生成敌机def handle_events(self):"""处理事件循环"""for event in pygame.event.get():if event.type == pygame.QUIT:self.running = Falseelif event.type == pygame.KEYDOWN:if event.key == pygame.K_ESCAPE:self.running = Falseelif event.type == self.enemy_spawn_timer:enemy = Enemy()self.all_sprites.add(enemy)self.enemies.add(enemy)def check_collisions(self):"""检测碰撞事件"""# 子弹击中敌机hits = pygame.sprite.groupcollide(self.enemies, self.bullets, True, True)for hit in hits:self.score += 50explosion_sound.play()# 敌机撞击玩家hits = pygame.sprite.spritecollide(self.player, self.enemies, True)for hit in hits:self.player.health -= 1if self.player.health <= 0:self.game_over()def draw_hud(self):"""绘制游戏界面HUD"""# 绘制得分font = pygame.font.Font(None, 36)score_text = font.render(f"Score: {self.score}", True, WHITE)self.screen.blit(score_text, (10, 10))# 绘制生命值health_text = font.render(f"Health: {self.player.health}", True, RED)self.screen.blit(health_text, (10, 50))def game_over(self):"""游戏结束处理"""font = pygame.font.Font(None, 74)text = font.render("GAME OVER", True, RED)text_rect = text.get_rect(center=(SCREEN_WIDTH / 2, SCREEN_HEIGHT / 2))self.screen.blit(text, text_rect)pygame.display.flip()pygame.time.wait(10000) # 等待2秒self.running = Falsedef run(self):"""游戏主循环"""while self.running:# 控制帧率self.clock.tick(FPS)# 处理输入self.handle_events()keys = pygame.key.get_pressed()if keys[pygame.K_SPACE]:self.player.shoot(self.bullets, self.all_sprites)# 更新游戏状态self.all_sprites.update(keys) # 更新所有精灵self.check_collisions()# 渲染画面self.screen.fill(BLACK)self.all_sprites.draw(self.screen)self.draw_hud()pygame.display.flip()pygame.quit()if __name__ == "__main__":game = Game()game.run()
附件:图片资源
音效资源无法放置在此处,如自行下载。
相关文章:
【Python实战】飞机大战
开发一个飞机大战游戏是Python学习的经典实战项目,尤其适合结合面向对象编程和游戏框架(如Pygame)进行实践。以下是游戏设计的核心考虑因素和模块划分建议: 一、游戏设计核心考虑因素 性能优化 Python游戏需注意帧率控制ÿ…...
WebAPI项目从Newtonsoft.Json迁移到System.Text.Json踩坑备忘
1.控制器层方法返回类型不能为元组 控制器层方法返回类型为元组时,序列化结果为空。 因为元组没有属性只有field,除非使用IncludeFields参数专门指定,否则使用System.Text.Json进行序列化时不会序列化field var options new JsonSerializ…...
人工智能助力工业制造:迈向智能制造的未来
在当今数字化转型的浪潮中,人工智能(AI)技术正逐渐成为推动工业制造领域变革的核心力量。智能制造作为工业 4.0 的重要组成部分,通过将 AI 技术与传统制造工艺深度融合,正在重塑整个生产流程,提高生产效率、…...
影楼精修-露齿笑算法解析
注意,为避免侵权,本文图片均为AIGC生成或网络公开数据; 像素蛋糕-露齿笑 在介绍本文之前,先说一下,其实露齿笑特效,并非像素蛋糕首创,早在几年前,face app就率先推出了这个效果&am…...
【iview】es6变量结构赋值(对象赋值)
变量的解构赋值 以iview的src/index.js中Vue.prototype.$IVIEW改造为例练习下怎么使用变量的解构赋值 原来的写法: const install function(Vue, opts {}) {if (install.installed) return;locale.use(opts.locale);locale.i18n(opts.i18n);Object.keys(iview).fo…...
在Windows系统中使用Docker发布镜像到镜像仓库
在Windows系统中使用Docker发布镜像到镜像仓库的步骤如下: 步骤 1:安装并配置Docker 安装Docker Desktop • 下载Docker Desktop for Windows并安装。 • 确保启用WSL 2或Hyper-V后端(根据系统版本选择)。 验证Docker运行状态 打…...
糖尿病筛查常识---秋浦四郎
糖尿病筛查可以早期发现糖尿病或糖尿病前期(血糖异常但未达到糖尿病标准),以利于及时干预,预防并发症。因为许多人患上糖尿病时没有明显症状,但已经开始对身体造成损害,有了明显糖尿病症状才检查发现糖尿病…...
CSS 预处理器 Sass
目录 Sass 一、Sass 是什么? 二、核心功能详解 1. 变量(Variables) 2. 嵌套(Nesting) 3. 混合宏(Mixins) 4. 继承(Inheritance) 5. 运算(Operations&…...
Mybatisplus:一些常用功能
自动驼峰 mybatis-plus:configuration:# 开启驼峰命名规则,默认true开启map-underscore-to-camel-case: true# 控制台日志打印,便于查看SQLlog-impl: org.apache.ibatis.logging.stdout.StdOutImpl TableName 作用:表名注解,标识…...
Golang WaitGroup 用法 源码阅读笔记
使用 sync.WaitGroup可以用来阻塞等待一组并发任务完成 下面是如何使用sync.WaitGroup的使用 最重要的就是不能并发调用Add()和Wait() var wg sync.WaitGroupfor ... {wg.Add(1) // 不能和wg.Wait()并发执行go func() {// 不能在启动的函数里面执行wg.Add(), 否则会panicde…...
第二章:一致性基础 A Primer on Memory Consistency and Cache Coherence - 2nd Edition
在本章中,我们将介绍足够多的缓存一致性知识,以便理解一致性模型是如何与缓存相互作用的。我们在 2.1 节首先给出在本入门教程中所考虑的系统模型。为了简化本章以及后续章节的阐述,我们选择了尽可能简单的系统模型,该模型足以说明…...
C++类_移动构造函数
std::move 的主要用途是在对象所有权转移时,触发移动构造函数或移动赋值运算符,避免不必要的深拷贝,提升性能。 移动构造函数 和 移动赋值运算符, std::move转换为右值,匹配到移动构造函数和移动赋值运算符。…...
Spring AI 实战:第一章、Spring AI入门之DeepSeek调用
引言:当Spring遇上AI,会擦出怎样的火花? 作为一名Java开发者,是否曾经眼红Python阵营那些花里胡哨的AI应用?是否在对接各种大模型API时,被五花八门的接口规范搞得头大?好消息是,Spr…...
fastapi+vue中的用户权限管理设计
数据库设计:RBAC数据模型 这是一个典型的基于SQLAlchemy的RBAC权限系统数据模型实现,各模型分工明确,共同构成完整的权限管理系统。 图解说明: 实体关系: 用户(USER)和角色(ROLE)通过 USER_ROLE 中间表实现多对多关系…...
Space Engineers 太空工程师 [DLC 解锁] [Steam] [Windows]
Space Engineers 太空工程师 [DLC 解锁] [Steam] [Windows] 需要有游戏正版基础本体,安装路径不能带有中文,或其它非常规拉丁字符; DLC 版本 至最新全部 DLC 后续可能无法及时更新文章,具体最新版本见下载文件说明 DLC 解锁列表&…...
随机变量数字特征
主要介绍一维随机变量期望和方差、二维随机变量期望和方差、以及协方差相关公式,及推导。 一维随机变量 以一个抛硬币的场景作为例子,如下: 抛掷两枚均匀硬币,如果两枚都是正面向上,则赢得2元,否则就输掉…...
C++总结01-类型相关
一、数据存储 1.程序数据段 • 静态(全局)数据区:全局变量、静态变量 • 堆内存:程序员手动分配、手动释放 • 栈内存:编译器自动分配、自动释放 • 常量区:编译时大小、值确定不可修改 2.程序代码段 •…...
【多线程】七、POSIX信号量 环形队列的生产者消费者模型
文章目录 Ⅰ. 信号量一、POSIX 信号量的概念二、POSIX 信号量的类型区别三、POSIX 信号量与 SystemV 信号量的区别Ⅱ. 线程信号量基本原理一、为什么要引入信号量❓二、PV 操作三、POSIX 信号量的实现原理四、CAS操作介绍Ⅲ. POSIX未命名信号量接口一、初始化无名信号量二、销毁…...
二维码批量识别—混乱多张二维码识别-物品分拣—-未来之窗-仙盟创梦IDE
仙盟模型 用途 精准分拣:快速准确识别物品上复杂或多个二维码,依据码中信息(如目的地、品类等)实现物品自动化分拣,提高分拣效率与准确性。库存管理:识别入库、出库物品二维码,更新库存数据&am…...
《TensorFlow 与 TensorFlow Lite:协同驱动 AI 应用全景》
《TensorFlow 与 TensorFlow Lite:协同驱动 AI 应用全景》 摘要 :在机器学习技术浪潮中,TensorFlow 与 TensorFlow Lite 作为 Google 技术栈的核心组件,分别占据云端训练与端侧部署的关键位置。本文将系统梳理二者架构特性、功能…...
Spring AI 实战:第三章、Spring AI结构化输出之告别杂乱无章
引言:当程序员遇上剧荒 “周末看什么?” 这个看似简单的问题,往往能让我们在各大影视平台间反复横跳半小时,最后无奈选择重刷《老友记》。本期让我们用技术解决这个"世纪难题":让大模型成为你的私人影视推荐…...
ros2 humble 控制真实机械臂(以lerobot为例)
基础版 0.确保串口访问权限 sudo chmod 666 /dev/ttyARM0 # 确保串口访问权限 1.下载 lerobot 驱动功能包 git clone https://gitee.com/kong-yue1/lerobot_devices.git 2.编写控制节点(完整代码) 主要功能是与 Feetech 电机总线进行通信&#…...
REINFORCE蒙特卡罗策略梯度算法详解:python从零实现
🧠 向所有学习者致敬! “学习不是装满一桶水,而是点燃一把火。” —— 叶芝 我的博客主页: https://lizheng.blog.csdn.net 🌐 欢迎点击加入AI人工智能社区! 🚀 让我们一起努力,共创…...
模拟SIP终端向Freeswitch注册用户
1、简介 使用go语言编写一个程序,模拟SIP-T58终端在Freeswitch上注册用户 2、思路 以客户端向服务端Freeswitch发起REGISTER请求,告知服务器当前的联系地址构造SIP REGISTER请求 创建UDP连接,连接到Freeswitch的5060端口发送初始的REGISTER请…...
Elasticsearch 中的索引模板:如何使用可组合模板
作者:来自 Elastic Kofi Bartlett 探索可组合模板以及如何创建它们。 更多阅读: Elasticsearch:可组合的 Index templates - 7.8 版本之后 想获得 Elastic 认证吗?查看下一期 Elasticsearch Engineer 培训的时间! El…...
一篇文章看懂时间同步服务
Linux 系统时间与时区管理 一、时间与时钟类型 时钟类型说明管理工具系统时钟由 Linux 内核维护的软件时钟,基于时区配置显示时间timedatectl硬件时钟 (RTC)主板上的物理时钟,通常以 UTC 或本地时间存储,用于系统启动时初始化时间hwclock …...
Mysql常用语句汇总
Mysql语句分类 DDL: 数据定义语言,用来定义数据库对象(数据库、表、字段)DML: 数据操作语言,用来对数据库表中的数据进行增删改DQL: 数据查询语言,用来查询数据库中表的记录DCL: 数据控制语言,用来创建数据…...
迭代器的思想和实现细节
1. 迭代器的本质 迭代器是一种行为类似指针的对象,它可能是指针(如 std::vector 的迭代器),也可能是封装了指针的类(如 std::list 的迭代器)。如果是指针那天然就可以用下面的运算,如果是类&am…...
[Vue]编程式导航
在 Vue 中,编程式导航是通过 JavaScript 代码(而非 <router-link> 标签)动态控制路由跳转的核心方式。这个方法依赖于 Vue Router 提供的 API,能更灵活地处理复杂场景(如异步操作、条件跳转等)。 一、…...
使用Node.js搭建https服务器
一、引言 https是是http的安全版本,在http的基础上通过传输加密和身份认证保证了传输过程中的安全性。可以认为:https http tls/ssl。本文讲述使用Node.js搭建https服务器的方法。 二、编译OpenSSL 按照《Openssl在Linux下编译/交叉编译》࿰…...
网络安全:sql注入练习靶场——sqli_labs安装保姆级教程
网络安全:sql注入练习靶场——sqli_labs安装保姆级教程 前言 sqli-labs靶场是一个开源的sql注入练习的综合靶场,包含大部分sql注入漏洞以及注入方式 网络安全学习者可以通过在sqli-labs靶场练习提升对sql注入的理解,以及学习各种绕过姿势。…...
rfsoc petalinux适配调试记录
1。安装虚拟机 2.设置共享文件夹 https://xinzhi.wenda.so.com/a/1668239544201149先设置文件夹路径 vmware 12 下安装 ubuntu 16.04 后,按往常的惯例安装 vmware-tools,安装时提示建议使用 open-vm-tools,于是放弃 vmware-tools 的安装&am…...
Windows下编译WebRTC源码
一、开发环境要求 准备一台64位的win10或win11(我用的是win11)电脑。最好是一台纯净的、没有安装过其它软件的Windows主机,避免已安装的软件和库对编译造成影响。 然后最好预留超过100G的硬盘空间。因为编译WebRTC时会产生大量的临时文件需…...
【vscode】.dart文件没有错误波浪线
解决方法: 新建一个文件夹,在vscode里打开这个文件夹 在这个文件夹里新建.dart文件后打开即可出现错误波浪线...
OpenharmonyOS+RK3568,【编译烧录】
文章目录 1. 摘要 ✨2. 代码下载 📩3. 编译 🖥️4. 修改&适配 ✂️4.1 编译框架基本概念4.2 vendor & device 目录4.3 内核编译4.3.1 如何修改、适配自己的开发板? 4.4 修改外设驱动 5. 烧录&验证 📋参考 1. 摘要 ✨ …...
从零开始理解 C++ 后端编程中的分布式系统
一、什么是“分布式”? 简单来说,分布式系统就是由“多个计算机(或服务器)”组成的一个大系统,它们通过网络协作完成某个任务,就像一个“团队合作”一样。 想象你开了一家餐馆,最初只有 一个厨房 和 一个服务员,所有订单都在这里处理。随着生意变好,你需要: 开分店…...
基于SpringBoot的篮球竞赛预约平台设计与实现
1.1 研究背景 科学技术日新月异的如今,计算机在生活各个领域都占有重要的作用,尤其在信息管理方面,在这样的大背景下,学习计算机知识不仅仅是为了掌握一种技能,更重要的是能够让它真正地使用到实践中去,以…...
具身系列——PPO算法实现CartPole游戏(强化学习)
完整代码参考: https://gitee.com/chencib/ailib/blob/master/rl/ppo_cartpole.py 执行结果: 部分训练得分: (sd) D:\Dev\traditional_nn\feiai\test\rl>python ppo_cartpole_v2_succeed.py Ep: 0 | Reward: 23.0 | Running: 2…...
小程序与快应用:中国移动互联网的渐进式革命——卓伊凡的技术演进观
小程序与快应用:中国移动互联网的渐进式革命——卓伊凡的技术演进观 在知乎看到很多:“懂王”发布的要把内行笑疯了的评论,卓伊凡必须怼一下,真印证那句话,无知者无畏 一、Web与小程序的技术本质差异 1.1 浏览器渲染…...
Socket 编程 UDP
Socket 编程 UDP UDP 网络编程V1 版本 - echo serverV2 版本 - DictServerV3 版本 - 简单聊天室 补充参考内容地址转换函数关于 inet_ntoa UDP 网络编程 声明:下面代码的验证都是用Windows作为客户端的,如果你有两台云服务器可以直接粘贴我在Linux下的客…...
Lua 基础 API与 辅助库函数 中关于创建的方法用法
目录 基础 API 函数1. lua_len(L, index)2. lua_load(L, reader, data, chunkname, mode)3. lua_newstate(allocator, ud)4. lua_newtable(L)5. lua_newthread(L)6. lua_newuserdata(L, size)7. lua_next(L, index) 辅助库函数(luaL_*)8. luaL_len(L, in…...
YOLOv11改进:利用RT-DETR主干网络PPHGNetV2助力轻量化目标检测
这里写自定义目录标题 YOLOv11改进:利用RT-DETR主干网络PPHGNetV2助力轻量化目标检测1. 介绍2. 引言3. 技术背景3.1 YOLOv11概述3.2 RT-DETR与PPHGNetV23.3 相关工作 4. 应用使用场景5. 详细代码实现5.1 环境准备5.2 PPHGNetV2主干网络实现5.3 YOLOv11与PPHGNetV2集…...
centos7.0无法安装php8.2/8.3
在centos安装php8.2报错 configure: error: *** A compiler with support for C17 language features is required. 配置过程检测到你的系统编译器不支持 C17 语言特性,而 PHP 8.2 的编译需要编译器支持 C17 sudo yum update -y sudo yum install centos-releas…...
工业传动核心部件深度剖析:丝杆升降机与气缸的技术特性及选型指南
在工业自动化技术飞速发展的当下,丝杆升降机与气缸作为关键的直线传动部件,广泛应用于各类机械设备中。对于工程师而言,深入了解它们的技术特性、优缺点及适用场景,是实现高效、精准设备设计的重要前提。本文将从技术原理出发&…...
flask 获取各种请求数据:GET form-data x-www-form-urlencoded JSON headers 上传文件
在 Flask 里,能使用多种方法获取不同类型的请求数据,下面详细介绍常见请求数据的获取方式。 获取查询字符串参数(GET 请求) 查询字符串参数一般在 URL 里,以 ?key1value1&key2value2 这种形式存在。可通过 requ…...
c++_2011 NOIP 普及组 (1)
P1307 [NOIP 2011 普及组] 数字反转 P1307 [NOIP 2011 普及组] 数字反转 - 洛谷 # P1307 [NOIP 2011 普及组] 数字反转 ## 题目描述 给定一个整数 $N$,请将该数各个位上数字反转得到一个新数。新数也应满足整数的常见形式,即除非给定的原数为零&…...
信息泄露:网站敏感文件泄漏的隐形危机与防御之道
在网络安全领域,信息泄露常被称为“沉默的杀手”。攻击者无需复杂漏洞,仅通过网站无意暴露的敏感文件(如源码备份、配置文件、版本控制记录),即可获取数据库密码、API密钥甚至服务器权限。本文将深入剖析信息泄…...
C++笔记-多态(包含虚函数,纯虚函数和虚函数表等)
1.多态的概念 多态(polymorphism)的概念:通俗来说,就是多种形态。多态分为编译时多态(静态多态)和运行时多态(动态多态),这里我们重点讲运行时多态,编译时多态(静态多态)和运行时多态(动态多态)。编译时多态(静态多态)主要就是我们前面讲的函…...
2025年- H22-Lc130-206. 反转链表(链表)---java版
1.题目描述 2.思路 使用迭代法 (1)定义一个前指针 (2)然后定义两个变量 curr(head),curr.next。 (3)curr和curr.next交换位置(只要当前指针不为空,执行两两交换) 3.代码实现 /*** Definition for singly-…...
智能家居的OneNet云平台
一、声明 该项目只需要创建一个产品,然后这个产品里面包含几个设备,而不是直接创建几个产品 注意:传输数据使用到了不同的power,还有一定要手机先联网才能使用云平台 二、OneNet云平台创建 (1)Temperatur…...