我有在家庭路由器上運行的嵌入式Linux固件。當我以root身份從終端一個接一個地運行以下命令時,它的工作原理沒有任何錯誤,並符合我的目的。我知道這不是一個安全的政策。這只是爲了測試一些東西。如何使用bash腳本更改iptable條目?
iptables -P INPUT ACCEPT
iptables -P FORWARD ACCEPT
iptables -P OUTPUT ACCEPT
iptables -F
iptables -X
iptables -A INPUT -p tcp -i eth1 --dport 4444 -j ACCEPT
但是,如果這是在bash腳本如下root身份運行,
#!/bin/bash
iptables -P INPUT ACCEPT
iptables -P FORWARD ACCEPT
iptables -P OUTPUT ACCEPT
iptables -F
iptables -X
iptables -A INPUT -p tcp -i eth1 --dport 4444 -j ACCEPT
它提供了以下錯誤:
iptables: Bad policy name. Run `dmesg' for more information.
iptables: Bad policy name. Run `dmesg' for more information.
iptables: Bad policy name. Run `dmesg' for more information.
iptables: No chain/target/match by that name.
iptables: No chain/target/match by that name.
我已確認的最後一行bash腳本執行沒有錯誤,並且條目可以在iptables中看到。但是,所有其他行都會引發錯誤。我究竟做錯了什麼?令人驚訝的是,同樣的批處理腳本在我的Ubuntu機器上工作正常。
您是如何以root特權運行shell腳本的?你能讓我們知道你是如何引用它的嗎? – Inian
該路由器附帶默認憑證默認運行的telnet服務。 –