跳转至

安全技术

Rust语言应用安全性分析

Rust语言简介与安全性概述

Rust语言简介

Rust 是由 Mozilla 主导开发的高性能编译型编程语言,遵循"安全、并发、实用"的设计原则。在过去几年中,Rust编程语言以其独特的安全保障特性和高效的性能,成为了众多开发者和大型科技公司的新宠。许多大厂开始纷纷在自己的项目中引入Rust,比如Cloudflare的pingora,Android中的Binder等等。1 2 3

下面我们举一个例子来看看Rust程序

Rust安全性概述

之所以人们对Rust那么充满兴趣,除了其强大的语法规则之外,Rust提供了一系列的安全保障机制也让人非常感兴趣,其主要集中在以下几个方面:4

  • 内存安全:Rust通过使用所有权系统和检查器等机制,解决了内存安全问题。它在编译时进行严格的借用规则检查,确保不会出现数据竞争、空指针解引用和缓冲区溢出等常见的内存错误。

  • 线程安全:Rust的并发模型使得编写线程安全的代码变得更加容易。它通过所有权和借用的机制,确保在编译时避免了数据竞争和并发问题,从而减少了运行时错误的潜在风险。

  • 抽象层安全检测:Rust提供了强大的抽象能力,使得开发者能够编写更加安全和可维护的代码。通过诸如模式匹配、类型系统、trait和泛型等特性,Rust鼓励使用安全抽象来减少错误和提高代码的可读性。

Rust强大的编译器管会接管很多工作,从而尽可能的减少各种内存错误的诞生。

Rust应用安全性分析

// TODO

ARM64逆向和利用 Part2——Use After Free(笔记)

翻译自ARM64 Reversing and Exploitation Part 2 – Use After Free | 8kSec Blogs,同时修改部分内容

在这篇博文中,我们将利用 vuln 二进制文件中的释放后使用漏洞。本文和下一篇文章的二进制文件可以在此处找到。此 UaF 挑战赛基于 Protostar 使用的挑战赛

Use-after-free漏洞发生在释放一段堆分配内存后的使用中。这可能会导致多种意外行为,包括从程序崩溃到代码执行。