Random 包生成加密安全的随机值

最后更新于 作者

The Random package generates cryptographically secure random values image

Stephen Rees-Carter 开发的 Random 包 通过一个简单的 PHP 辅助包,生成各种格式的加密安全的随机值。以下是创建此包的原因

我在安全审计中经常遇到的问题(尤其是在较旧的代码库中)是不安全的随机性,通常出现在需要安全性的位置。它通常使用某种形式的 rand(),通常被注入 md5() 中以生成随机哈希,并结合 str_shuffle() 生成新密码,或者用于使用 rand(100_000, 999_999) 生成一次性密码 (OTP)。

问题在于 rand() 不是加密安全的,mt_rand()mt_srand()str_shuffle()array_rand() 或 PHP 中其他不安全的函数也不安全。我们不能简单地宣布这些方法不安全,扔下麦克风就走开。相反,我们需要提供安全的替代方案 - 所以我们不能简单地说“不要以这种方式使用 rand()”,而是可以说“这里有一种你可以使用的安全方法!”

以下是使用 Random 包可以做的一些示例

随机一次性密码(数字固定长度 OTP)

生成一个 $length 位数字的随机数字一次性密码 (OTP)

$otp = Random::otp(int $length): string;

用于生成用于短信或电子邮件验证码的 OTP。

随机字符串

生成一个 $length 个字符的随机字符串,其中包含来自启用的字符类型的字符。默认情况下,它将随机选择字符,并且不保证存在任何特定字符类型。如果您需要包含每个字符中的一个,则可以设置 $requireAll = true。

// Primary method
$string = Random::string(
int $length = 32,
bool $lower = true,
bool $upper = true,
bool $numbers = true,
bool $symbols = true,
bool $requireAll = false
): string;

string 方法还附带了针对常见用例的友好包装器

// Random letters only
$letters = Random::letters(int $length = 32): string;
 
// Random alphanumeric (letters and numbers) token string
$token = Random::token(int $length = 32): string;
 
// Random letters, numbers, and symbols (i.e. a random password).
$password = Random::password(int $length = 16, bool $requireAll = false): string;
 
// Random alphanumeric token string with chunks separated by dashes, making it easy to read and type.
$password = Random::dashed(int $length = 25, string $delimiter = '-', int $chunkLength = 5, bool $mixedCase = true): string;

混洗数组、字符串或集合

安全地混洗数组、字符串或 Laravel 集合,可以选择保留键。

$shuffled = Random::shuffle(
array|string|\Illuminate\Support\Collection $values,
bool $preserveKeys = false
): array|string|\Illuminate\Support\Collection;

等等

访问 官方包 GitHub 页面获取完整详细信息,还可以查看 公告文章

Eric L. Barnes photo

Eric 是 Laravel 新闻的创始人,自 2012 年起就开始报道 Laravel。

归档于
Cube

Laravel 新闻通讯

加入 40,000 多名其他开发人员,绝不错过新的技巧、教程等等。

Laravel Forge logo

Laravel Forge

轻松创建和管理您的服务器,并在几秒钟内部署您的 Laravel 应用程序。

Laravel Forge
Tinkerwell logo

Tinkerwell

Laravel 开发人员必备的代码运行器。使用 AI、自动完成和本地和生产环境的即时反馈进行调试。

Tinkerwell
No Compromises logo

无妥协

Joel 和 Aaron,两位来自无妥协播客的经验丰富的开发人员,现在可以为您的 Laravel 项目提供服务。 ⬧ 固定费率 7500 美元/月。 ⬧ 没有漫长的销售流程。 ⬧ 没有合同。 ⬧ 100% 退款保证。

无妥协
Kirschbaum logo

Kirschbaum

提供创新和稳定性,以确保您的 Web 应用程序取得成功。

Kirschbaum
Shift logo

Shift

运行旧版本的 Laravel?立即使用自动化 Laravel 升级和代码现代化,让您的应用程序保持新鲜。

Shift
Bacancy logo

Bacancy

只需每月 2500 美元,就可以使用经验丰富的 Laravel 开发人员(具有 4-6 年的经验)为您的项目增效。获取 160 小时的专业知识和 15 天无风险试用。立即预约电话!

Bacancy
Lucky Media logo

Lucky Media

立即获得幸运 - Laravel 开发的理想选择,拥有十多年的经验!

Lucky Media
Lunar: Laravel E-Commerce logo

Lunar:Laravel 电子商务

Laravel 的电子商务。一个开源软件包,将现代无头电子商务功能的强大功能带到 Laravel。

Lunar:Laravel 电子商务
LaraJobs logo

LaraJobs

官方 Laravel 工作板

LaraJobs
SaaSykit: Laravel SaaS Starter Kit logo

SaaSykit:Laravel SaaS 启动工具包

SaaSykit 是一个 Laravel SaaS 启动工具包,它包含运行现代 SaaS 所需的所有功能。付款、漂亮的结账、管理面板、用户仪表板、身份验证、即用型组件、统计数据、博客、文档等等。

SaaSykit:Laravel SaaS 启动工具包
Rector logo

Rector

您实现 Laravel 无缝升级、降低成本和加速创新的合作伙伴,以帮助企业取得成功

Rector
MongoDB logo

MongoDB

通过 MongoDB 和 Laravel 的强大集成来增强您的 PHP 应用程序,使开发人员能够轻松高效地构建应用程序。支持事务性、搜索、分析和移动用例,同时使用熟悉的 Eloquent API。了解 MongoDB 的灵活、现代数据库如何改变您的 Laravel 应用程序。

MongoDB
Maska is a Simple Zero-dependency Input Mask Library image

Maska 是一个简单的零依赖输入掩码库

阅读文章
Add Swagger UI to Your Laravel Application image

在 Laravel 应用程序中添加 Swagger UI

阅读文章
Assert the Exact JSON Structure of a Response in Laravel 11.19 image

在 Laravel 11.19 中断言响应的精确 JSON 结构

阅读文章
Build SSH Apps with PHP and Laravel Prompts image

使用 PHP 和 Laravel Prompts 构建 SSH 应用程序

阅读文章
Building fast, fuzzy site search with Laravel and Typesense image

使用 Laravel 和 Typesense 构建快速、模糊的站点搜索

阅读文章
Add Comments to your Laravel Application with the Commenter Package image

使用 Commenter 包向 Laravel 应用程序添加评论

阅读文章