为什么使用 POST 进行更新比超链接更安全

为什么使用 post 进行更新比超链接更安全

在 php 中更新记录时,选择使用 执行操作(通常通过表单和 http 方法,如 post 或 put)还是 超链接(通常使用 get 方法)归结为安全性最佳实践。这就是为什么执行操作是首选:

安全

get(超链接): 由链接触发的操作通常使用 get http 方法,该方法旨在检索信息,而不是修改信息。当用于更新或删除时,敏感数据(例如记录 id)可能会在 url 中暴露,使其容易受到 url 操纵或 csrf(跨站点请求伪造)等攻击。

有问题的示例:

任何人都可以操纵 url 中的 id 来篡改未经授权的记录。

post(执行操作): 更新应使用带有 post 方法的表单,其中数据在请求正文而不是 url 中发送。这种方法隐藏了敏感信息,并使未经授权的操作变得更加困难,特别是与 csrf 令牌等其他安全措施结合使用时。

推荐示例:

        

遵守 http 约定

http 协议对每个方法都有明确的意图:

get: 检索信息(幂等且无副作用)。post/put:提交或更新信息(非幂等且有副作用)。

使用 get 进行更新或删除等操作违反了这些约定,并且可能会混淆缓存或代理等中介机构,这些中介机构可能会将 get 请求视为安全且无副作用。

防止意外行为

超链接可能会无意中触发(例如,意外点击或机器人跟踪链接)。使用 post 的表单,尤其是添加了确认步骤,可以降低意外执行的可能性。

与高级安全性和验证的兼容性

使用表单可以无缝集成其他安全措施,例如:

csrf 令牌: 防止恶意跨域请求。输入验证:提交表单之前验证记录 id。权限控制:在呈现表单之前验证用户访问权限。

使用执行操作(通过带有 post 或 put 的表单)更新记录是推荐的方法。这可确保更好的安全性、符合 http 约定并降低意外操作的风险。超链接应保留用于不会改变系统状态的导航或只读操作。

以上就是为什么使用 POST 进行更新比超链接更安全的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1249694.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月9日 21:34:50
下一篇 2025年12月9日 21:34:56

相关推荐

  • PHP7和PHP8的安全性提升

    PHP7 和 PHP8 的安全性提升涵盖以下方面:底层引擎优化,提升执行速度,增加攻击难度。限制和改进危险函数,降低 SQL 注入和 XSS 等攻击风险。引入命名参数、联合类型等特性,提高代码可读性和可维护性,减少 bug 导致的安全风险。强调开发人员的编码习惯和安全意识,安全是一个持续改进的过程。…

    2025年12月9日
    000
  • 什么是 PHP 中的依赖注入以及为什么它对于测试和可维护性至关重要

    PHP依赖注入:提升测试性和可维护性的利器 依赖注入 (DI) 是一种软件设计模式,它能显著增强代码的灵活度、可测试性和可维护性。在面向对象编程 (OOP) 中,尤其是在PHP开发中,DI模式被广泛应用。DI允许类从外部获取其依赖项(运行所需的对象),而不是在内部自行创建。这种解耦机制促进了代码模块…

    2025年12月9日
    000
  • PHP7和PHP8性能差异

    PHP8因引入JIT编译器而实现显著性能提升。JIT编译器在运行时将“热点”代码编译成机器码,从而提高执行效率。性能差异取决于代码、应用和服务器配置。除了JIT,PHP8还优化了字符串操作和数组访问等方面。优化代码需要了解PHP内部机制和最佳实践,例如使用局部变量、避免全局变量和不必要的内存分配。性…

    2025年12月9日
    000
  • PHP7和PHP8的内存管理差异

    PHP8较PHP7显著优化了内存管理。PHP8采用了更先进的垃圾回收器ZMM,引入了更精细的内存分配和回收策略,显著减少内存碎片和提升效率。例如,在处理大量对象时,PHP8能有效识别和回收短暂对象,避免内存浪费。但需要注意的是,代码模式在PHP8下可能与PHP7不同,需要优化代码以充分利用ZMM的优…

    2025年12月9日
    000
  • 怎样在 PHP 8 中打开 JIT?

    PHP 8 中打开 JIT 的方法:找到 php.ini 文件中的 opcache.jit 指令,并将其设置为 1(混合模式)、tracing(跟踪模式)或 function(函数模式)。但需注意,JIT 并非万能药,它对代码风格和结构敏感,在某些场景下可能无效或不利。因此,应根据实际情况选择合适的…

    2025年12月9日
    000
  • PHP 8.4 中的 HTTP 动词变化

    PHP 8.4 已于 11 月发布,您和您的团队无疑一直在努力理解该语言最新版本所带来的新功能、弃用和更改。这包括对非 POST HTTP 动词的更改。在这篇博客中,我将介绍 PHP 中 HTTP 动词的背景,解释为什么 PHP 8.4 中的 HTTP 动词变化很重要。然后,我提供了一个指南,供开发…

    2025年12月9日
    000
  • PHP7浮点型精度如何?

    PHP7 浮点型精度受限于 IEEE 754 标准,并非无限精确,导致舍入误差和比较困难。 使用 epsilon 来比较浮点数的差值是否小于容差,以确定其是否几乎相等。 涉及货币计算时避免使用浮点数,使用整数或 bc math 扩展以获得更高的精度。 PHP7 浮点型精度?这问题问得妙啊!很多初学者…

    2025年12月9日
    000
  • PHP7如何使用伪类型mixed?

    PHP7中不存在mixed类型,但可使用联合类型(如string|int)或null类型配合类型判断来处理多种类型的参数。利用内置函数进行类型检查、编写清晰的文档注释,有助于编写健壮易维护的PHP代码。 PHP7的mixed类型:真相与陷阱 不少人问我PHP7怎么用mixed类型,其实答案很简单:你…

    2025年12月9日
    000
  • PHP 8 开启 JIT 后出现问题怎么办?

    PHP 8 的 JIT 可能带来问题,包括内存泄漏、段错误、性能下降和兼容性问题。解决方法包括诊断问题、禁用 JIT、升级 PHP、简化代码。 PHP 8 引入的 JIT (Just-In-Time) 编译器,是个让人又爱又恨的东西。爱它是因为性能提升显著,恨它是因为…坑真不少。 标题问“PHP 8…

    2025年12月9日
    000
  • 大佬们的 JSON

    什么是 json? json 代表 javascript 对象表示法。它是一种轻量级数据格式,用于在系统之间存储和交换信息,尤其是在 web 应用程序中。 将 json 视为一种以清晰、结构化的格式编写和组织数据的方法。 为什么选择 json? 人类可读:易于理解和编写。与语言无关:用于多种编程语言…

    2025年12月9日
    000
  • 我为什么喜欢 Laravel:初学者的观点

    当我第一次开始 web 开发时,我努力寻找一个既易于学习又足够强大以适合实际项目的框架。然后,我发现了 laravel,它彻底改变了我构建应用程序的方式。这就是我喜欢 laravel 以及你也应该考虑使用它的原因: 1。易于上手laravel 的文档非常棒。如果您是初学者,只需几个命令即可开始: c…

    2025年12月9日
    000
  • 代码气味 – 未解析的元标签

    不完整的元标签是不专业的 tl;dr:不完整或空元标记会破坏功能和用户体验。 问题 标签出现在输出中电子邮件文本包含人类可读文本之间的占位符丢失的占位符会让用户感到困惑网站呈现奇怪的字符空值会触发错误潜在的安全注入漏洞 解决方案 验证元标记尽早断言完整性快速失败避免空值抛出有意义的异常自动元验证 语…

    2025年12月9日 好文分享
    000
  • PHP:我应该嘲笑还是应该走?

    简而言之模拟 模拟旨在测试真实对象的行为。 它们模拟依赖关系,因此您不必调用可能显着减慢单元测试速度的外部资源。 您可以定义期望并验证它们。 例如,您可以确保某个方法被调用特定次数和/或使用某些参数: use phpunitframeworktestcase;class mytest extends…

    2025年12月9日
    000
  • 通过直接 AWS Lambda 调用简化内部 API

    这是文档的改进和完善版本:通过直接 aws lambda 调用简化内部 api 使用面向服务的架构 (soa) 系统时,您可能需要一个内部 api 来进行服务之间的通信。一种常见的方法是将 aws lambda 与 api 网关结合使用。然而,对于内部 api,有一个更简单、更高效的选择:直接调用 …

    2025年12月9日
    000
  • 为什么 Laravel 是现代 Web 应用程序的首选框架

    您的项目的成功取决于您选择的框架。人们可能很容易对众多可用的替代方案感到不知所措。不过,laravel 是一个不断脱颖而出的框架。无论项目有多复杂,laravel 都已成为现代 web 开发的首选框架。 但为什么它变得如此出名呢?让我们来看看是什么因素促使 laravel 成为全球开发者的热门选择。…

    2025年12月9日
    000
  • 如何以不同的方式查看 WordPress 字段

    在处理 WordPress 项目时(无论是开发插件、创建自定义主题还是管理实时站点),了解元数据至关重要。元数据代表存储有关您的帖子、术语、用户和评论的关键信息的不可见层。然而,如果没有合适的工具,访问这些领域可能会很困难。 为什么理解元数据很重要? WordPress 中的每个元素(帖子、用户或分…

    2025年12月9日
    000
  • Dockerize 您的 PHP 和 MySQL 应用程序:多容器应用程序分步指南

    在现代软件开发领域,容器化已成为高效部署和可扩展性的基石。 docker 可以轻松地将应用程序及其依赖项打包到可移植容器中。在本博客中,我们将引导您使用 docker compose 创建多容器 php 和 mysql 应用程序。 为什么对 php 和 mysql 使用 docker? 一致性:在开…

    2025年12月9日
    000
  • 如何以不同的方式查看您的 WordPress 字段

    当您从事 WordPress 项目时,无论是开发插件、创建自定义主题还是管理生产中的网站,了解元数据都是至关重要的。元数据代表存储有关您的帖子、术语、用户和评论的关键信息的不可见层。然而,如果您没有合适的工具,访问这些字段可能会很困难。 为什么了解元数据很重要? WordPress 中的每个元素(帖…

    2025年12月9日
    000
  • 接口签名为什么需要剔除空字符并进行参数排序?

    接口签名中的空字符剔除和参数排序原理 许多三方接口在签名过程中都会遵循如下规则: 剔除空字符参数按ASCII 码升序排序 这种做法看似约定俗成,但实际上有着客观的技术原因。 空字符剔除 如果将空字符包含在签名中,当接口字段较多且包含大量空字段时,字符串拼接和计算签名所需的资源将显着增加。原始数据越长…

    2025年12月9日
    000
  • Docker下ThinkPHP6定时任务无法写入日志:777权限失效的原因是什么?

    为什么 PHP 环境给了 777 权限,第二天仍无法写入? 在基于 Docker 的 ThinkPHP6 环境中,尽管当天授予了 777 权限,但出现无法创建日志的情况。 仔细检查后,发现问题根源在于定时任务。在定时任务运行时,执行用户是 root,而不是与 PHP 进程相同的用户。因此,即使文件或…

    2025年12月9日
    000

发表回复

登录后才能评论
关注微信