AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 680963
Accepted
Sir Muffington
Sir Muffington
Asked: 2021-12-11 10:13:41 +0800 CST2021-12-11 10:13:41 +0800 CST 2021-12-11 10:13:41 +0800 CST

ls -la 编码为十六进制时如何执行?

  • 772

互联网上曾经有一个非常糟糕的笑话,您可以复制以 \x0B\x2E... 开头的内容...(只是一个示例),当您执行此命令时,终端会将其解释为sudo rm -rf /.

您如何进行这种混淆?我刚刚尝试运行 Cyber​​chef 并将我的命令转换为十六进制,即使使用语法ls -la也不会执行此命令。\x<hexcodetwocharactershere>\x<hexcodetwocharactershere>

  • 我究竟做错了什么?
  • 有没有类似的混淆方法?

PS我已经知道base64编码技巧,但这需要在系统上安装base64

总而言之,我不想使用 bash 以外的任何其他工具来实现我的目标(所以没有 base64 编码工具和类似工具,没有 xxd,没有管道)

bash shell-script
  • 2 2 个回答
  • 469 Views

2 个回答

  • Voted
  1. Best Answer
    Stéphane Chazelas
    2021-12-11T23:34:19+08:002021-12-11T23:34:19+08:00

    在大多数 shell 中,\x6c\x73\x20\x2d\x6c\x61代码会尝试像另一个引用运算符x6cx73x20x2dx6cx61一样运行命令。\

    在esor fishshells 中,它会尝试运行ls -la命令并且可能会失败,因为没有该名称的命令。In es,\不是引用运算符,但可用于扩展类似 C 的转义序列。

    in fish\既是引用运算符(如 in sh/ csh)又是转义序列引入器(如 in ) es。

    在这两种情况下,\x20都不会被解释为真正的空格字符在 shell 的语法中的令牌限制器,因此它不会使用作​​为参数运行ls命令。-la

    如果您输入$'\x6c\x73\x20\x2d\x6c\x61'支持该 ksh93 样式引用形式的 shell,则相同。

    您需要将这些扩展解释为 shell 代码,例如通过将其提供给eval, sh -c, source...

    eval $'\x6c\x73\x20\x2d\x6c\x61'
    

    或者至少让它经历分裂:

    code=$'\x6c\x73\x20\x2d\x6c\x61'
    $code # using split+glob in POSIX shells
    $=code # explicit IFS-splitting in zsh
    
    • 2
  2. Stephen Kitt
    2021-12-11T10:53:32+08:002021-12-11T10:53:32+08:00

    我不确定这是否符合问题的精神,尽管它仅适用于 bash:

    eval "$(printf "%b" "\x6c\x73\x20\x2d\x6c\x61")"
    

    您可以在运行之前检查解码的命令

    printf "%b\n" "\x6c\x73\x20\x2d\x6c\x61"
    
    • 1

相关问题

  • 从文本文件传递变量的奇怪问题

  • 虽然行读取保持转义空间?

  • MySQL Select with function IN () with bash array

  • `tee` 和 `bash` 进程替换顺序

  • 运行一个非常慢的脚本直到它成功

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve