首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >【Linux系列】Vim 编辑器中的替换命令::%sg'详解

【Linux系列】Vim 编辑器中的替换命令::%sg'详解

原创
作者头像
kwan的解忧杂货铺
发布2024-12-06 23:45:37
发布2024-12-06 23:45:37
1.4K0
举报

在开始今天的分享之前,我想先推荐一篇非常精彩的文章。

文章就是《渗透测试文件包含漏洞原理与验证(1)——文件包含概述》🚀🌟🚀🌟🚀🌟

链接是:点击这里

这篇文章详细解释了文件包含漏洞的原理,以及如何在实际的 Web 应用程序中发现和验证这类漏洞。它提到,文件包含漏洞通常发生在 PHP 等脚本语言中,当开发者在引入文件时没有对文件名进行充分的校验,就可能导致意外的文件泄露或恶意代码注入。

文章还介绍了几种 PHP 中的文件包含函数,包括include()include_once()require()require_once(),以及它们在找不到文件时的不同行为。此外,文章还探讨了利用文件包含漏洞的条件,比如函数通过动态变量引入文件,以及用户能够控制这个动态变量。

通过一些实际的示例,文章展示了如何通过修改文件扩展名来绕过某些安全限制,以及如何通过修改 URL 参数来实现文件包含攻击。

这篇文章不仅提供了丰富的技术细节,还强调了合法合规的重要性。它提醒我们,所有的渗透测试活动都应该在获得明确授权的情况下进行,并且要遵守相关法律法规。

如果你对 Web 安全感兴趣,或者想要提高你的 Web 应用程序的安全性,我强烈推荐你阅读这篇文章。它不仅能够提供实用的技术知识,还能帮助你更好地理解安全领域的法律和道德规范。让我们一起在合法合规的前提下,探索和提升 Web 安全吧!


在 Linux 系统中,Vim 是一款功能强大的文本编辑器,它以其高效的编辑能力和强大的插件系统而闻名。对于开发者和系统管理员来说,Vim 是日常工作中不可或缺的工具之一。在处理文本文件时,我们经常需要进行查找和替换操作,而 Vim 提供了一种非常灵活的方式来完成这些任务。

Vim 编辑器简介

Vim 是从 Vi 发展出来的一个文本编辑器,它继承了 Vi 的模式编辑方式,同时增加了很多新的功能,如语法高亮、代码补全、多窗口编辑等。Vim 的设计哲学是“模式、动作、文本对象”,这意味着几乎所有的操作都可以通过键盘快捷键来完成,从而提高了编辑效率。

替换命令:%s/true/false/g的组成

在 Vim 中,替换命令的基本格式是:[range]s/{pattern}/{string}/[flags],其中:

  • ::进入命令模式。
  • [range]:指定操作的范围,可以是单个行号、行号范围或者百分比表示整个文件。
  • s:表示替换(substitute)操作。
  • {pattern}:查找的模式,即要查找的字符串。
  • {string}:替换模式,即要替换成的字符串。
  • [flags]:替换标志,如全局替换g

命令模式

在 Vim 中,按下Esc键可以退出命令模式回到普通模式。在命令模式下,你可以输入各种命令来对文件进行操作,如保存文件、退出编辑器、执行替换等。

范围指定

%符号在 Vim 中代表整个文件,这意味着命令将对文件中的所有行生效。如果你只想对文件的某一部分进行操作,可以通过指定行号范围来替换特定区域,例如:10,20s/true/false/g将只替换第 10 行到第 20 行中的"true"。

查找和替换模式

:%s/true/false/g命令中,true是要查找的模式,即 Vim 会在文件中查找所有出现的"true"字符串。false是替换模式,即所有找到的"true"都会被替换为"false"。

全局替换标志

/g是全局替换标志,它告诉 Vim 对每一行中的所有匹配项进行替换。如果不使用/g标志,Vim 默认只会替换每一行中的第一个匹配项。

使用场景

:%s/true/false/g命令在多种场景下都非常有用,以下是一些常见的应用:

  1. 代码修改:在开发过程中,可能需要将代码中的某个常量或变量的值从"true"改为"false",这个命令可以快速完成整个文件的替换。
  2. 配置文件调整:在配置文件中,有时需要批量修改某些设置的开启或关闭状态,这个命令可以快速实现。
  3. 文本处理:在处理文本文件时,可能需要将文档中的某些关键词替换为其他词汇,这个命令可以大大提高效率。
    在这里插入图片描述
    在这里插入图片描述

安全性和备份

由于:%s/true/false/g命令会替换整个文件中的所有匹配项,这个操作是不可逆的。因此,在执行这个命令之前,最好先确认一下你的替换是否正确,或者先备份文件。Vim 提供了多种方式来备份文件,例如使用:%cp filename.bak命令可以将当前文件内容复制到一个新的备份文件中。

其他替换命令

Vim 的替换功能非常强大,除了全局替换外,还有其他一些有用的替换命令:

  • 逐行替换:s/true/false/g只对当前行进行替换。
  • 确认替换:%s/true/false/gc在每次替换前都会询问用户是否进行替换。
  • 正则表达式替换:%s/\btrue\b/false/g使用正则表达式匹配整个单词"true"。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Vim 编辑器简介
  • 替换命令:%s/true/false/g的组成
    • 命令模式
    • 范围指定
    • 查找和替换模式
    • 全局替换标志
  • 使用场景
  • 安全性和备份
  • 其他替换命令
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档