当前位置:首页 > 文章列表 > 文章 > php教程 > Simples Mudanças, Grandes Impactos: Como Fortalecer a Segurança da Sua Aplicação Laravel

Simples Mudanças, Grandes Impactos: Como Fortalecer a Segurança da Sua Aplicação Laravel

来源:dev.to 2024-09-03 12:57:48 0浏览 收藏

积累知识,胜过积蓄金银!毕竟在文章开发的过程中,会遇到各种各样的问题,往往都是一些细节知识点还没有掌握好而导致的,因此基础知识点的积累是很重要的。下面本文《Simples Mudanças, Grandes Impactos: Como Fortalecer a Segurança da Sua Aplicação Laravel》,就带大家讲解一下知识点,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~

Simples Mudanças, Grandes Impactos: Como Fortalecer a Segurança da Sua Aplicação Laravel

如果您已经参与过 laravel 项目,您肯定已经注意到该框架如何提供各种有用的开发工具。但是,你有没有想过你是否可能错过了一个错误?在使用这些工具时,您是否最终错过了一些简单但重要的细节来确保系统的安全?

在本文中,我将向您展示一些“简单”的错误,但非常常见且易于解决。


进行安全部署?

在互联网上公开项目时,需要注意 .env 文件将进入生产/审批环境或任何部署场景,如 app_env 和 app_debug密钥可能会在这些环境中打开可能的漏洞。

这些键有什么用呢?

  • app_env = 指示应用程序当前环境的标志,它可以接收诸如“本地”、“生产”、“暂存”、“测试”等值
  • app_debug = 指示当前环境是否处于调试模式的标志,它可以接收一个布尔值。

此配置仅用于开发环境。

app_env=local
app_debug=true

将此配置用于生产环境。

app_env=production
app_debug=false

在生产中不使用正确的配置会出现什么问题?

将 laravel 应用程序保留在调试模式下可以显示详细的错误消息,这对于开发来说非常有用,但对于其他环境来说却很糟糕,因为它可以显示以下敏感信息:

  • 代码片段。
  • php 和 laravel 版本。 (可用于利用版本中已知的安全漏洞)
  • 用户信息和密钥。
  • 数据库密码。
  • app_env 密钥状态。

指示环境值为“local”的密钥可以打开各种漏洞,范围从无需登录即可打开的 telescope,到使用 app_env 确定流量的某些系统功能的行为。例如,使用外部 api 的以下配置:

'api_service' => [
    'key' => env('app_env') === 'production' ? env('api_key_prod') : env('api_key_dev')
]

验证输入?

每个开发者在一生中的某个时刻都一定听过“不要信任用户”,在本文中您将看到另一个这样想的理由。

让我们想象一下以下场景,您在电子商务中有一个产品编辑表单,仅适用于非经理员工,但该表单没有可用的值字段,以不允许非经理员工进行更改. 已授权。

这是桌子产品

id valor nome quantidade codigo setor_id
1 100 panela 4 pan10323 3
... ... ... ... ... ...

这些是您的表单请求
的验证规则

public function rules(): array
{
    return [
        'nome' => 'string|max:255',
        'quantidade' => 'integer|min:0',
        'codigo' => 'string|max:255|unique:itens,codigo',
        'setor_id' => 'exists:setores,id',
    ];
}

这是您的控制器中使用的函数:

public function funcionarioupdateitem(updateitemrequest $request, $id)
{
    $item = item::findorfail($id);

    $result = $item->update($request->all());

    return response()->json(['sucesso' => $result], 200);
}

您已检查并且数据已正确更新,验证成功并且一切似乎都按顺序进行。然而,这个流程有一个很大的缺陷:我们正在考虑表单只会发送请求中的四个字段。

但是,如果恶意用户手动更改页面的 html 以添加 value 字段,会发生什么情况?或者,如果攻击者甚至通过 postman 等 api 平台发送请求,并在请求中包含 value 字段,该怎么办?

假设恶意用户将以下数据发送到路由:

{
   valor: 1,
   nome: 'panela barata',
}

您的表产品将包含以下记录:

id valor nome quantidade codigo setor_id
1 1 panela barata 4 pan10323 3
... ... ... ... ... ...

现在原价 100 r$ 的产品最终只需 r$ 1,问题是如何从请求中提取数据。

错了❌

$request->all();
  • 这就是所有请求数据的返回方式。

对✅

$request->validated();
  • 这样,仅返回请求中的有效数据。

如果示例中的 controller 使用正确的方式接收数据,则相同的恶意负载示例将导致以下记录:

id valor nome quantidade codigo setor_id
1 100 panela barata 4 pan10323 3
... ... ... ... ... ...

从而避免任何意外数据!


避免 sql 注入 ?

当我们谈论 sql 注入时,我们谈论的是使攻击者有可能在应用程序数据库中执行不需要的和不可预见的 sql 命令的漏洞。

示例:
假设您的系统具有执行以下查询的用户搜索功能。

$query = "select * from users where username = '$username'";

如果用户输入 admin',则认为 $user 变量是由执行搜索的用户给出的;删除表用户; -- 将生成以下查询。

select * from users where username = 'admin'; drop table users; --'

生成的查询是恶意的,会导致整个用户表崩溃,对应用程序的完整性造成巨大损害。

如何保护我的应用程序?

laravel 自己的 eloquent orm 和查询生成器具有强大的保护功能,可以防止恶意输入和查询的潜在危险字符。 但是,在使用任何接受原始查询的方法时必须小心,因为如果滥用这些方法,可能会导致注入恶意输入。

示例:
错了❌

$email = $request->email;

db::select("select * from users where email = '" . $email . "'");

在这种情况下,我们通过字符串连接直接将用户输入传递给查询,这不会执行任何参数清理。

对✅

$email = $request->email;

user::where('email', $email)->get();

通过这种方式,我们使用 laravel 的原生保护,将输入作为参数传递给将构建查询的函数。

对✅

$email = $request->email;

db::select("select * from users where email = ?", [$mail]);

假设您确实需要使用接受原始查询的方法,请通过绑定传递参数。这样,laravel 将防止输入被解释为 sql 代码并保证查询安全。

别忘了⚠

始终在 laravel 中使用原始 sql 进行查询时使用绑定。


使用速率限制?

限制在给定时间内可以发出的请求数量对于保护您的应用程序免受某些类型的攻击至关重要,例如:

  • 暴力破解: 通过使用可能的组合发出大量请求来尝试“猜测”密码和凭据,直到成功。
  • ddos: 尝试在短时间内通过大量请求使服务器超载。

建议考虑将此保护添加到与身份验证形式相关的路由或使用私有随机令牌的路由。

如何申请?

在 appserviceprovider.php 文件中,您将在启动函数中创建 ratelimiter:

ratelimiter::for('default-limiter', function (request $request) {
            return limit::perminute(10);
});

好的,现在定义了限制器,我们将应用我们的敏感路线。

route::middleware('throttle:default-limiter')->group(function () {
    route::get('/private/{token}', [tokencontroller::class, 'privatething']);
});

考虑该路由接收一个随机生成的令牌来显示其承载者的私人数据。这样我们就设置了每分钟 10 个请求的限制,避免了可能的暴力攻击来猜测秘密令牌,从而获得对私人信息的访问权限。

仍然可以定义具体的、个性化的限制规则,例如通过ip:

RateLimiter::for('default-limiter', function (Request $request) {
    return Limit::perMinute(10)->by($request->ip());
});

这些限制通常基于 ip 和登录用户,对于防止不同类型的攻击非常重要,包括使用不同 ip 进行的 ddos 攻击。永远记住创建强大的限制规则!

如果您已经使用现成的 laravel 身份验证套件,例如 breeze 或 jetstream,那么恭喜您!您的登录路线已受到速率限制的保护。

注意⚠

设置限制时请密切注意,以免影响用户正常使用您的系统。如果路由的请求流量较大,建议使用 laravel 11 的每秒速率限制功能。


结论

我们在开发过程中必须始终密切关注安全问题,因为小的决定或看似微不足道的错误可能会在未来导致大问题。

非常感谢您阅读本文! ❤

好了,本文到此结束,带大家了解了《Simples Mudanças, Grandes Impactos: Como Fortalecer a Segurança da Sua Aplicação Laravel》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多文章知识!

版本声明
本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
Win10无法启动驱动精灵怎么办 Win10无法启动驱动精灵解决方法Win10无法启动驱动精灵怎么办 Win10无法启动驱动精灵解决方法
上一篇
Win10无法启动驱动精灵怎么办 Win10无法启动驱动精灵解决方法
PHP 函数中如何使用递归来求最小公倍数?
下一篇
PHP 函数中如何使用递归来求最小公倍数?
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    508次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • AI Make Song:零门槛AI音乐创作平台,助你轻松制作个性化音乐
    AI Make Song
    AI Make Song是一款革命性的AI音乐生成平台,提供文本和歌词转音乐的双模式输入,支持多语言及商业友好版权体系。无论你是音乐爱好者、内容创作者还是广告从业者,都能在这里实现“用文字创造音乐”的梦想。平台已生成超百万首原创音乐,覆盖全球20个国家,用户满意度高达95%。
    15次使用
  • SongGenerator.io:零门槛AI音乐生成器,快速创作高质量音乐
    SongGenerator
    探索SongGenerator.io,零门槛、全免费的AI音乐生成器。无需注册,通过简单文本输入即可生成多风格音乐,适用于内容创作者、音乐爱好者和教育工作者。日均生成量超10万次,全球50国家用户信赖。
    12次使用
  •  BeArt AI换脸:免费在线工具,轻松实现照片、视频、GIF换脸
    BeArt AI换脸
    探索BeArt AI换脸工具,免费在线使用,无需下载软件,即可对照片、视频和GIF进行高质量换脸。体验快速、流畅、无水印的换脸效果,适用于娱乐创作、影视制作、广告营销等多种场景。
    12次使用
  • SEO标题协启动:AI驱动的智能对话与内容生成平台 - 提升创作效率
    协启动
    SEO摘要协启动(XieQiDong Chatbot)是由深圳协启动传媒有限公司运营的AI智能服务平台,提供多模型支持的对话服务、文档处理和图像生成工具,旨在提升用户内容创作与信息处理效率。平台支持订阅制付费,适合个人及企业用户,满足日常聊天、文案生成、学习辅助等需求。
    16次使用
  • Brev AI:零注册门槛的全功能免费AI音乐创作平台
    Brev AI
    探索Brev AI,一个无需注册即可免费使用的AI音乐创作平台,提供多功能工具如音乐生成、去人声、歌词创作等,适用于内容创作、商业配乐和个人创作,满足您的音乐需求。
    17次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码