Linux系统安全:从面临的攻击和风险到安全加固、安全维护策略(文末有福利)

1. Linux面临的攻击与风险

1.1. Linux系统架构

在这里插入图片描述

Linux系统架构解读:

  • 用户之间隔离
  • 内核态与用户态之间隔离
  • 用户进程一般以低权限用户运行
  • 系统服务一般以特权服务运行
  • 用户态通过系统调用进入内核态
  • 内核对系统资源进行管理和分配

1.2. Linux系统常见安全威胁

1.2.1. 远端网络攻击

  • 用户仿冒攻击:通过伪造用户ID,暴力破解用户密码,登录系统提供的网络服务
  • 网络DOS攻击:被远程用户进行拒绝服务攻击,如SYN Flood攻击
  • 网络服务/进程攻击:对外开放了网络端口的业务进程存在缺陷可被远端攻击

1.2.2. 本地进程攻击

  • 业务进程被攻击:攻击者利用业务进程的缺陷进行攻击,导致正常业务进程无法正常工作
  • 内核被攻击:内核运行在特权态,攻击者利用内核漏洞进行攻击,从而提权
  • 系统服务被攻击:系统服务一般运行在高权限,攻击者利用系统服务的缺陷进行提权,从而对系统进行更大的破坏,如获取系统关键信息,篡改系统文件

1.2.3. 近端物理攻击

  • 镜像篡改攻击:设备加载的固件被替换或篡改,导致运行恶意系统
  • 物理端口被攻击:利用系统的串口等物理端口进行攻击,绕过登录或导致系统无法正常工作,或泄露系统关键信息

1.3. 攻击的常用步骤

踩点–>扫描–>攻击–>提权–>消除日志或植入后门

  • 踩点:信息搜集、端口扫描
  • 扫描:漏洞扫描、利用已知漏洞、不安全配置,弱密码/口令
  • 攻击:暴力破解、定向挖掘目标的未知漏洞
  • 提权:利用系统弱点进行提权
  • 消除日志:篡改日志,隐藏踪迹
  • 植入后门:植入木马,持续控制

以上攻击步骤与2009年 Lockheed Martin 公司提出的杀链(Kill Chain)理论很相似。杀链其实就是攻击者进行网络攻击时所采取的步骤(1侦察 -> 2武器化 -> 3交付 -> 4利用 -> 5安装 -> 6命令和控制 -> 7针对目标的活动)。若要了解更多杀链理论可以参阅博主文章《「 网络安全常用术语解读 」杀链Kill Chain详解》。

1.4. 应对攻击常用的防御手段

  • 针对踩点:屏蔽系统敏感信息
  • 针对扫描、攻击:服务安全:关闭非必要端口,对网络进行隔离,使用安全协议; 系统漏洞防御机制;最小化安装;保持系统更新;认证与鉴权
  • 针对提权:文件访问控制;最小化授权;应用隔离机制
  • 针对消除日志、植入后门:安全维护

2. 防御系统信息泄露

2.1. Linux系统信息泄露的风险

  • 网络服务暴露系统详细信息
  • 网络协议栈暴露系统信息
  • 系统配置文件默认提供内核版本信息
  • 通过google、shodan等搜索引擎可获取大量信息,比如,通过goole获取目标系统的操作系统及版本信息
  • 内核接口泄露地址布局等信息
  • 登录打印泄露系统信息,如 cat /etc/issue.net telnet 10.67.188.34

Shodan是世界上第一个用于互联网连接设备的搜索引擎。了解互联网智能如何帮助攻击者做出更好的决策。

2.2. 通过端口扫描获取目标信息

攻击者使用端口扫描工具Nmap可获取系统对外提供的网络服务、操作系统版本等详细信息

2.3. 通过Banner隐藏系统信息

修改系统的issue、issue.net文件内容:
echo "Authorized uses only." >/etc/issue.net
修改OpenSSH的banner信息
etc/ssh/sshd_config中配置Banner /etc/issue.net

2.4. 隐藏系统网络协议栈信息

通过ICMP报文可获取子网信息,可执行如下命令防御

iptables -A INPUT -p icmp --icmp-type address-mask-request -j DROP
iptables -A OUTPUT -p icmp --icmp-type address-mask-reply -j DROP

通过ICMP报文获取目标系统时间戳信息(可用来猜测随机数),可执行如下命令防御

iptables -A INPUT -p icmp --icmp-type timestamp-request -j DROP
iptables -A OUTPUT -p icmp --icmp-type timestamp-reply -j DROP

2.5. 隐藏内核地址布局信息

特权态地址存在泄露风险,系统中的普通用户通过查看内核导出的接口,可获取内核地址布局信息,内核地址布局信息被用户态获取,可使 KASLR 失效。

内核地址信息需要保护,防止普通用户通过 dmesg 、串口打印等手段获取,绕过 KASLR
使用 sysctl 设置 kernel.kptr_restrict 值为 1,禁止用户态低权限用户查看内核打印的地址。

3. 对系统加固以防御远程攻击

3.1. 服务安全

3.1.1. 关闭非必要端口

每个对外监听的网络端口,对攻击者而言都是一个攻击入口,可使用端口查询命令( netstat、lsof 等)审视系统所有监听端口的合理性,使用 iptables 对系统中不对外暴露的端口进行过滤,命令如下

iptalbes -A INPUT -p tcp --dport XXX -j DROP
iptalbes -A INPUT -p udp --dport XXX -j DROP

3.1.2. 对网络进行隔离

  • 对于第三方组件监听的端口,可使用 iptables 对端口进行过滤
  • 当系统同时连接多个网段时,应对网段进行隔离,以减少攻击面
  • 业务进程须绑定固定的IP地址,防止监听所有的IP地址0.0.0.0
  • 不对外提供服务的端口,应仅在本地监听127.x.x.x

3.1.3. 使用安全协议

  • 使用明文通信协议存在通信内容被嗅探的风险
  • 推荐使用安全协议的开源组件,开源的组件风险更容易发现和修复
  • 自研服务应使用加密协议,且要对传输进行加密

3.2. 系统漏洞防御机制

3.2.1. 栈保护

攻击者利用堆栈溢出漏洞时,通常会覆盖函数的返回地址,以控制程序执行流:

  • gcc编译时使用-fstack-protector-strong选项(使用-all选项也可以,但会影响性能和程序包大小)
  • 在函数的栈缓冲区(buffer)和控制信息(RBP)间插入一个canary字段,当缓冲区溢出时,在返回地址被覆盖前canary字段会先被覆盖。通过检查canary字段的值是否被修改,就可以判断是否发生了溢出攻击。
    在这里插入图片描述

3.2.2. 地址随机化ASLR

  • 用户态地址随机化ASLR

    • 将进程的某些内存空间地址进行随机化来增大攻击者预测目的地址的难度
    • 通过sysctl来对kernel.randomize_va_space进行设置,设置为2,可获得最大的随机化能力
    • gcc编译程序时加入"-fPIE -pie"选项开启PIE,实现代码段和数据段的随机化
  • 内核地址随机化KALSR

    • 将内核镜像的基地进行随机化偏移
    • 每次启动后的内核地址随机
    • 增加攻击者对漏洞进行利用的难度

3.2.3. 堆栈不可执行NX(DEP)

攻击者发现目标系统的漏洞后,通常会尝试将恶意代码注入到可控的数据区。
NX(No-excute)通过将数据区所在内存页标识为不可执行,当程序溢出成功并跳转到注入的代码时,由于数据区不可执行,此时CPU就会抛出异常,而不执行恶意指令。
可通过如下命令对程序开启或关闭DEP保护:

gcc -z,noexecstack 开启NX保护
gcc -z,execstack 禁止NX保护

3.2.4. 控制流完整性CFI

随着攻击技术发展,主流漏洞利用方式转变为代码重用攻击,ROP是Androd的主要ROOT工具。CFI(Controle Flow Integrite)是防御代码重用攻击的主流方案,早在 2005 年 Micosoft 就提出此概念,其核心思想是对所有程序跳转做校验,跳转包括间接函数调用,函数返回(加上函数头签名)。

3.2.5. 面向返回的编程ROP

面向返回的编程(Return-oriented Programming,ROP)是一种新型的基于代码复用技术的攻击,攻击者从已有的库或可执行文件中提取指令片段,构建恶意代码。

3.3. 最小化安装

系统若安装了大量的冗余软件包,将会扩大系统的攻击面
非业务所需的网络服务会打开新的端口
多余的系统服务会以高权限运行,提高本地攻击的风险
系统上的开发 、调试工具给本地攻击者带来极大便利

常见的开发调试工具
gcc/gdb/objdump/strace等
Linux内核的源码 和KO编译环境
常见的网络嗅探工具
tcpdump/、tshark、wireshark

3.4. 保持系统更新

漏洞SLA周期
高危:<=3个月
中危:<=6个月
低危:在下个维护版本修复

3.5. 认证与鉴权

3.5.1. 避免root直接用于远程登录

编辑 openssh 服务配置文件 sshd_conifg , 查找 PermitRootLogin 配置项,将设置为No

3.5.2. PAM机制

PAM是Linux上的可插拨认证模块机制,通过提供一些动态链接库和一套统一的api,将系统提供的服务和该服务的认证方式分开,使得系统管理呐可以根据需要给不同的服务配置不同的认证方式而无需更改服务程序,同时也便于向系统中添加新的认证手段

PAM的验证类别

  • auth 主要验证用户的身份
  • acccount 主要验证用户是否具备正确的权限
  • password 修改口令的验证(如口令的合法性)
  • session 会话期间对用户的管理和环境的配置

常用的PAM模块

  • 使用pam_pwhistory禁用历史密码
  • 使用pam_tally2对登录尝试次数进行限制
  • 使用pam_cracklib对口令复杂度检查

3.5.3. 口令有效期

长期使用同一个口令会增加被破解的可能,Shadow套件对口令的时效配置文件是/etc/login.defs,通过以下配置项对密码的时间限制进行设置:

PASS_MAX_DAYS 90
PASS_MIN_DAYS 00
PASS_WARN_AGE 30
PASS_MIN_LEN 6

用户口令遗忘后,管理员将用户口令重置,用户重置第一次登录系统时必须修改口令,以保证口令不被扩散。
passwd -e <用户名>

4. 对系统加固以防御本地攻击

4.1. 文件访问控制

4.1.1. 分区挂载安全

对于可插拔的存储设备,上面可能会存在设备文件、具有SUID权限的文件,当这些存储设备被挂载到系统后,将带来极大安全隐患。
使用安全挂载选项,去除外部设备中的特殊文件:

  • nosuid:表示分区的二进制文件的setuid权限不生效
  • noexec:表示分区不能包含可执行的二进制文件
  • nodev:表示分区不能包含特殊设备(软链接指向本地设备文件)

4.1.2. 文件的访问权限

4.1.2.1. umask

umask(默认文件权限666,文件夹777) 为用户创建权限掩码,是创建文件或文件夹时默认权限的基础,用户在创建时,文件的默认权限-掩码的权限就是文件的实际权限。
举例,umask 为 022 时:

  • 文件权限:666-022=644
  • 文件夹权限:777-022=755

如何设置Umask
用户可在命令行下执行umask命令,修改默认umask,如umask 077,要全局生效,可以将umask写在/etc/profile中。

4.1.2.2. setuid

具备setuid位的文件,在运行时的权限为文件owner的权限,使用find / -type f -perm /4000 -0 -perm /2000查找具有 setuid 权限的文件。

全局可写目录是攻击者放置恶意程序的首先目标,主要安全风险如下:

  • 全局可写目录下的文件,是文件替换攻击的高发区
  • 全局可写目录防止与独立分区,并设置 noexec,nosuid 等挂载权限
  • 全局可写目录(如 /tmp)的常用保护手段:
    • 设置目录粘滞位:使用chmod +t /dir,则dir目录下的文件只有文件owner才能删除
    • 软件链接保护:c通过sysctl设置fs.protected_symlinks值为1,只有目标文件的Owner与软件链接的Owner一样时,才能通过软链接访问目标文件
    • 硬链接保护:sysctl设置fs.protected_hardlinks值为1,阻止无权限的用户创建文件的硬链接
4.1.2.3. 应用MAC机制

DAC(自主访问控制机制)

  • 根据运行时的身份决定访问权限
  • 文件目录的rwx权限划分太简单
  • root身份运行的程序具有最高权限,无法限制

MAC(强制访问控制机制)

  • 进程需要先通过DAC权限检查,并通过MAC权限检查后,才能访问所需资源
  • 所有访问控制是基于策略设定的,普通用户无权更改
  • MAC相对DAC不是替换,而是增加了一层控制
  • 常用的MAC有SELinux(如rehat)、AppArmor(ubuntu)

4.2. 最小化授权

4.2.1. 避免使用root运行应用

使用root运行应用存在极大风险,若存在堆栈溢出漏洞,攻击者可获取管理员权限。

4.2.2. 通过capability进行授权

Linux提供了38个权能(capability),可对特权进行分隔以降低安全风险:

  • 对二进制可执行文件添加权能,可赋予其运行实体对应的权限
  • 合理对进程进行capability授权,可避免setuid权限位的使用
  • 避免授予过大特权,如 CAP_SYS_ADMIN

命令举例:
添加cap后普通用户恢复ping的使用权限
set cap "cap_net_admin,cap_net_raw+ep" /bin/ping
查看ping命令的capablity
getcap /bin/ping
删除添加的所有capablities
setcap -r /bin/ping

4.2.3. 通过sudo进行授权

在·/etc/sudoer·文件中,配置普通用户可以特权执行的命令
配置格式:User Host=(Runas)[Tag:]Commands

配置举例:

test ALL=(ALL) NOPASSWD: /sbin/lspci
test用户执行lspci,提示无权限
test用户执行sudo lspci就OK

4.3. 应用隔离机制

攻击者发现目标进程漏洞后,在进行漏洞利用时,经常会通过调用 syscall 来达到特定目的,比如当攻击者劫持程序执行流后,可通过execve这样的syscall来执行命令。

seccomp 是内核中的系统调用过滤机制。正常情况下,程序可以使用所有的 syscall 。使用seccomp 可以在程序中禁用某些syscall,这样就算攻击者劫持了程序流也只能调用部分受限的 syscall,减少程序被攻击后的影响。

4.4. 防范物理攻击

4.4.1. 安全启动

对bootloader(如grub)的配置修改进行口令认证
在具备可信计算条件的硬件上实现安全启动

4.4.2. 防止物理端口绕过认证

  • 攻击者连接串口后,可以直接访问操作系统shell,可能导致敏感信息泄露,或破坏系统完整性
  • 外部面板不可见但板内的能对系统进行管理或调试的内部串口、内部网口必须有接入认证机制
  • 如不能提供接入认证机制,则必须禁用/删除该接口的管理、调试功能

5. Linux安全维护

5.1. 日志审计

5.1.1. 机制与工具

  • 系统日志syslog:传统的系统日志服务,记录系统中的各种信息,如程序通过syslog接口记录的日志,硬件信息等。常用的系统日志组件为:syslog-ng,rsyslog.
  • 内核审计 audit:记录内核信息,如系统调用,文件读写,权限变更等。相比用户态的syslog,audit能记录更多的内核细节,能实现更细粒度的审计。

5.1.2. 常用的日志事件

  • 登录失败
  • 用户与组的更改
  • 文件的未授权访问

5.1.3. 对日志的保护

  • 攻击者控制目标系统后,往往会对日志进行篡改,以掩盖入侵痕迹
  • 对日志文件设置严格的访问权限,防止普通用户查看和修改
  • 对日志设置轮转(logrotate)
  • 将日志发送到日志服务器

5.2. 使用配置审计工具扫描系统配置

审计对象包括:OS、DB、Webserver、Nginx、路由器等。

5.3. 使用Nessus审计系统安全

Nessus号称是世界上最流行的漏洞扫描程序,全世界有超过75000个组织在使用它。该工具提供完整的电脑漏洞扫描服务,并随时更新其漏洞数据库。Nessus不同于传统的漏洞扫描软件,Nessus可同时在本机或远端上遥控,进行系统的漏洞分析扫描。对应渗透测试人员来说,Nessus是必不可少的工具之一。

只要目标IP,Nessus就可通过内置的NASL漏洞插件对目标进行扫描。主要支持OS、DB、Web应用和常用服务/协议等对象相关的弱密码、已知漏洞扫描及CIS Benchmark配置扫描,发现安全漏洞、风险。

5.4. 文件完整性

5.4.1. 常见的rootkit

攻击者控制目标系统后,为了达到持续控制和获取机密数据的目的,往往会在系统中植入后门,常称其为rootkit。
用户态rootkit

  • 替换系统的认证程序,如sshd/login/PAM中的认证模块;
  • 替换常用的状态查看工具如ls/ps/find/netstat等,隐藏恶意进程、端口及文件
  • 在cron等定时任务中周期运行恶意程序
  • 往运行中的进程注入恶意代码

内核态rootkit

  • 插入恶意KO,支持系统调用
  • 植入提权接口

5.4.2. 检测与度量

IMA(Intergrity Measurement Architecture,完整性度量框架)

  • 实现当应用程序运行、动态链接库加载、内核模块加载时,将文件做一次度量,并创建与维护的一个度量列表ML,将度量结果扩展到PCR寄存器;
  • TPM的PCR寄存器只支持重置与扩展,因此恶意代码无法进行任意的篡改。而在执行恶意的操作前,系统已经将恶意代码的度量值写入到PCR中,因此 恶意代码无法绕过度量机制 。

AIDE(Advanced Instruction Detection Enviroment,高级入侵检测环境)

  • 为系统文件生成初始的校验码(文档数据库),然后每次执行检查命令时,AIDE会将之前生成的校验码和当前文件的校验码进行对比,并且输出报告。

内核模块签名

  • KO编译时进行签名
  • KO插入内核时进行签名校验

6. 附:Linux系统安全入门学习资料

  • Linux操作系统安全(入门).pdf (访问密码: 6277)

  • Linux操作系统安全(进阶).pdf (访问密码: 6277)


推荐阅读

一、网络安全常用术语解读系列(持续更新中)

  • 「 网络安全常用术语解读 」杀链Kill Chain详解
  • 「 网络安常用全术语解读 」点击劫持Clickjacking详解
  • 「 网络安常用全术语解读 」悬空标记注入详解
  • 「 网络安常用全术语解读 」内容安全策略CSP详解
  • 「 网络安全常用术语解读 」同源策略SOP详解
  • 「 网络安常用全术语解读 」静态分析结果交换格式SARIF详解
  • 「 网络安全常用术语解读 」安全自动化协议SCAP详解
  • 「 网络安常用全术语解读 」通用平台枚举CPE详解
  • 「 网络安全常用术语解读 」通用缺陷枚举CWE详解
  • 「 网络安全常用术语解读 」通用漏洞披露CVE详解
  • 「 网络安全常用术语解读 」通用漏洞评分系统CVSS详解
  • 「 网络安全常用术语解读 」漏洞利用交换VEX详解
  • 「 网络安全常用术语解读 」软件成分分析SCA详解:从发展背景到技术原理再到业界常用检测工具推荐
  • 「 网络安全常用术语解读 」通用攻击模式枚举和分类CAPEC详解
  • 「 网络安全常用术语解读 」网络攻击者的战术、技术和常识知识库ATT&CK详解

二、典型安全漏洞系列(持续更新中)

  • 「 典型安全漏洞系列 」13.信息泄露漏洞
  • 「 典型安全漏洞系列 」12.OAuth 2.0身份验证漏洞
  • 「 典型安全漏洞系列 」11.身份验证漏洞详解
  • 「 典型安全漏洞系列 」10.跨域资源共享CORS漏洞详解
  • 「 典型安全漏洞系列 」09.权限提升漏洞详解
  • 「 典型安全漏洞系列 」08.文件上传漏洞详解
  • 「 典型安全漏洞系列 」07.OS命令注入详解
  • 「 典型安全漏洞系列 」06.路径遍历(Path Traversal)详解
  • 「 典型安全漏洞系列 」05.XML外部实体注入XXE详解
  • 「 典型安全漏洞系列 」04.服务器端请求伪造SSRF详解
  • 「 典型安全漏洞系列 」03.跨站请求伪造CSRF详解
  • 「 典型安全漏洞系列 」02.SQL注入详解
  • 「 典型安全漏洞系列 」01.跨站脚本攻击XSS详解

三、CISSP考试通关笔记(已完结)

  • 「 CISSP学习笔记 」08. 安全运营
  • 「 CISSP学习笔记 」07. 安全评估与测试
  • 「 CISSP学习笔记 」6. 安全开发
  • 「 CISSP学习笔记 」5. 安全架构和工程
  • 「 CISSP学习笔记 」4. 身份和访问管理
  • 「 CISSP学习笔记 」3.通信与网络安全
  • 「 CISSP学习笔记 」2.资产安全
  • 「 CISSP学习笔记 」1.安全与风险管理
  • 「 CISSP学习笔记 」0.开篇
    在这里插入图片描述

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

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

相关文章

Swift-27-类的初始化与销毁

Swift的初始化是一个有大量规则的固定过程。初始化是设置类型实例的操作&#xff0c;包括给每个存储属性初始值&#xff0c;以及一些其他准备工作。完成这个过程后&#xff0c;实例就可以使用了。 简单来讲就是类的构造函数&#xff0c;基本语法如下&#xff1a; 注意&#xff…

【webrtc】Chrome和Firefox在SDP协商过程中,针对localhost的不同处理

内网下chrome端webrtc协商失败 现象 我有一个webrtc服务器在局域网内&#xff0c;使用chrome浏览器访问时&#xff0c;发现webrtc在做媒体协商时失败。 具体表现是&#xff0c;在交换sdp后&#xff0c;ice的状态是oniceconnectionstatechange: failed 但是换成Firefox浏览器…

计算机网络相关知识总结

一、概述 计算机网络可以极大扩展计算机系统的功能机器应用范围&#xff0c;提高可靠性&#xff0c;在为用户提供放方便的同时&#xff0c;减少了整体系统费用&#xff0c;提高性价比。 计算机网络的功能主要有&#xff1a;1. 数据共享&#xff1b;2. 资源共享&#xff1b;3. 管…

前端实现将二进制文件流,并下载为excel文件

目录 一、关于二进制流二、项目实践三、常见问题及解决 一、关于二进制流 含义&#xff1a;二进制流是一种计算机文件格式&#xff0c;它的数据以二进制形式存储&#xff0c;与文本文件不同。 二进制文件可以包含任意类型的数据&#xff0c;例如&#xff1a;图像、音频、视频…

Prompt Engineering,提示工程

什么是提示工程&#xff1f; 提示工程也叫【指令工程】。 Prompt发送给大模型的指令。比如[讲个笑话]、[用Python编个贪吃蛇游戏]、[给男/女朋友写情书]等看起来简单&#xff0c;但上手简单精通难 [Propmpt]是AGI时代的[编程语言][Propmpt]是AGI时代的[软件工程][提示工程]是…

Pytorch常用的函数(八)常见优化器SGD,Adagrad,RMSprop,Adam,AdamW总结

Pytorch常用的函数(八)常见优化器SGD,Adagrad,RMSprop,Adam,AdamW总结 在深度学习中&#xff0c;优化器的目标是通过调整模型的参数&#xff0c;最小化&#xff08;或最大化&#xff09;一个损失函数。 优化器使用梯度下降等迭代方法来更新模型的参数&#xff0c;以使损失函数…

C#仿QQ抽屉式窗体的设计方法:创建特殊窗体

目录 1.WindowFromPoint函数 2.GetParent函数 3.实例 &#xff08;1&#xff09; 图片集合编辑器 &#xff08;2&#xff09;Form1.Designer.cs &#xff08;3&#xff09;Form1.cs 4.生成效果 QQ软件对于绝大多数的人来说再熟悉不过了&#xff0c;它以使用方便、界面美…

MySQL创建数据库与表

要求&#xff1a; 1.在本机安装数据库 2.创建一个数据库db_classes 3.创建一行表db_hero 4.将四大名著中的常见人物插入这个英雄表 目录 要求&#xff1a; 过程&#xff1a; 结果&#xff1a; 命令总结&#xff1a; 过程&#xff1a; 1.安装数据库 http://t.csdnimg…

【软件工程】【第一章概述】d1

关键字&#xff1a; 什么是软件、软件危机、软件工程定义、软件生命周期、软件过程、瀑布模型

设计模式学习笔记 - 开源实战四(中):剖析Spring框架中用来支持扩展的设计模式

概述 上篇文章&#xff0c;学习了 Spring 框架背后蕴含的设计思想&#xff0c;比如约定优于配置、低侵入松耦合、模块化轻量级等等。这些设计思想可以借鉴到其他框架开发中&#xff0c;在大的设计层面提高框架的代码质量。 除了上篇文章降到的设计思想&#xff0c;实际上&…

《R语言与农业数据统计分析及建模》学习——ggplot2绘图基础

一、农业科研数据可视化常用图形及用途 1、数据可视化的重要性 通过可视化&#xff0c;我们可以更直观地理解和分析数据的特征和趋势。 2、常用图表类型及其概述 散点图&#xff1a;用于展示两个变量之间的关系&#xff0c;可用于观察数据的分布、趋势和异常值。 折线图&…

[SWPUCTF 2022 新生赛]1z_unserialize

function __destruct()这是类的析构函数。在 PHP 中&#xff0c;析构函数会在对象被销毁时自动调用。 $a($this->lly): 将 $this->lly 的值作为参数传递给 $a 所代表的函数。 由题目可知&#xff0c;实现nss反序列化的同时&#xff0c;会触发__destruct()的魔术方法将l…

【数据结构(邓俊辉)学习笔记】向量03——常规向量

文章目录 0.概述1.元素访问2.置乱器3.判等器与比较器4.无序查找4.1 判等器4.2 顺序查找4.3 实现4.4 复杂度 5. 插入5.1 算法实现5.2 复杂度分析 6. 删除6.1 区间删除6.2 单元删除6.3 复杂度 7. 唯一化7.1 实现7.2 正确性7.3 复杂度 8. 遍历8.1 实现8.2 复杂度 9. 总结 0.概述 …

【树莓派学习】开发环境配置

【树莓派学习】开发环境配置 ​ Raspberry Pi OS作为基于Linux的系统&#xff0c;其默认网络配置在国内的网络环境下容易出现访问慢甚至无法连接等问题&#xff0c;不便于我们的学习&#xff0c;同时&#xff0c;树莓派上C/C的使用需要单独安装WiringPi。本文主要介绍如何更改…

探索开源的容器引擎--------------Docker容器操作

目录 一、Docker 容器操作 1.1容器创建 1.2查看容器的运行状态 1.3启动容器 1.4创建并启动容器 1.4.1当利用 docker run 来创建容器时&#xff0c; Docker 在后台的标准运行过程是&#xff1a; 1.4.2在后台持续运行 docker run 创建的容器 1.4.3创建容器并持续运行容器…

PYTHON用[邻接列表]及[邻接矩阵]来存储无向图

# 图可以根据边的性质进行分类&#xff1a;# 有向图&#xff08;Directed Graph&#xff09;&#xff1a;在有向图中&#xff0c;边是有方向性的&#xff0c;从一个节点指向另一个节点。这意味着从节点 A 到节点 B 的边与从节点 B 到节点 A 的边可以是不同的&#xff0c;或者根…

parallels desktop19出来了吗?2024最新版本有哪些新功能

Parallels Desktop 19已经发布。以下是关于Parallels Desktop 19的相关信息&#xff1a; 发布时间&#xff1a;Parallels Desktop 19是在近期发布的一款虚拟机软件&#xff0c;具体发布时间为2023年下半年。 功能特点&#xff1a; 针对搭载苹果芯片的Mac进行了优化&#xff0c…

微信小程序webview和小程序通讯

1.背景介绍 1.1需要在小程序嵌入vr页面&#xff0c;同时在vr页面添加操作按钮与小程序进行通信交互 1.2 开发工具&#xff1a;uniapp开发小程序 1.3原型图 功能&#xff1a;.点击体验官带看跳转小程序的体验官带看页面 功能&#xff1a;点击立即咨询唤起小程序弹窗打电话 2.…

Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单人脸检测/识别实战案例 之五 简单进行车牌检测和识别

Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单人脸检测/识别实战案例 之五 简单进行车牌检测和识别 目录 Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单人脸检测/识别实战案例 之五 简单进行车牌检测和识别 一、简单介绍 二、简单进行车牌检测和识别实现原理 …

Jmeter之Beanshell详解

一、 Beanshell概念 Beanshell: BeanShell是一种完全符合Java语法规范的脚本语言,并且又拥有自己的一些语法和方法;BeanShell是一种松散类型的脚本语言(这点和JS类似);BeanShell是用Java写成的,一个小型的、免费的、可以下载的、嵌入式的Java源代码解释器,具有对象脚本语言特性…