在Bash中比较两个IP地址

在Bash中比较两个IP地址,bash,ubuntu,ip-address,Bash,Ubuntu,Ip Address,我试图找出两个ip地址是否相同。我承认我是bash的新手,但我认为没有理由这样做不起作用: if [[ "$IPAddress" != "$OLDIPAddress" ]] then echo "IP Not the Same" else echo "IP Same" fi 出于测试目的,我甚至对这两个变量的值进行了硬编码,但它们仍然不相同。我知道你并不总是看到自己的打字错误,但我不明白为什么这不起作用。有什么想法吗?虽然您的命令应该可以工作,但您可以使用简单的测试操作符(仅一个括号)

我试图找出两个ip地址是否相同。我承认我是bash的新手,但我认为没有理由这样做不起作用:

if [[ "$IPAddress" != "$OLDIPAddress" ]]
then
  echo "IP Not the Same"
else
  echo "IP Same"
fi

出于测试目的,我甚至对这两个变量的值进行了硬编码,但它们仍然不相同。我知道你并不总是看到自己的打字错误,但我不明白为什么这不起作用。有什么想法吗?

虽然您的命令应该可以工作,但您可以使用简单的测试操作符(仅一个括号)。优点是它可以与任何(POSIX)shell一起工作。但是,
[[
操作符也应该工作

你能重现这个小例子吗?(应该输出“是”):


用于比较不同格式的ip地址的快速演示脚本,例如,“普通”与DHCP始终为3位八位组。希望除了比较之外,您还可以使用一些有用的技巧进行解析和验证,并为社区提供更多的催化剂。(这是我第一篇有代码的帖子,希望它能通过ok——一如既往的YMMV。)


请告诉我们如何定义
$IPAddress
$OLDIPAddress
。这两个值是什么?即使是测试值。如果将它们都发送到
xxd
hexdump
,您会得到什么?这取决于您所说的“相同”…是否“127.0.0.1”与“127.000.001”相同?如果是这样的话,那么简单的文本比较将是无效的…@twalberg八进制定义真的很少见。这不太可能是原因,但是嘿!还是很好的一点!:)@hek2mgl不一定考虑octal,尽管这也是一个有效的观察结果……我更多考虑的是一个基于表单的条目,它可能返回与printf“%03d”等价的值x对于每个八位字节…永远不要相信输入…这大致就是我进行测试的方式。我得到的结果是两个IP地址不相同,尽管它们显然是相同的。由于我无法理解的原因,此示例返回的结果不相同…您复制/粘贴了我的代码并尝试了吗?没有任何更改吗?是的。复制和p最后,我做的唯一一件事就是在顶部添加一个#!/bin/bash。
IPAddress="127.0.0.1"
OLDIPAddress="127.0.0.1"

if [ "$IPAddress" != "$OLDIPAddress" ] ; then 
    echo "no"
else
    echo "yes"
fi
#!/bin/bash
# demo.sh - parse, validate, compare ip addresses
# usage: demo.sh {ipaddress1} {ipaddress2}

#--- IP ADDRESS 1
#---   Is there anything besides digits and three dots?
#---   Parse out the octets
#---   There should be exactly 4 populated octets
#---   All 4 octets must not be > 255
[ "${1//[0-9]/}" != '...' ] && echo "invalid" && exit 1
O1=(${1//./ })
[ -z "${O1[3]}" -o -n "${O1[4]}" ] && echo "invalid" && exit 1
[ ${O1[0]} -gt 255 -o ${O1[1]} -gt 255 -o ${O1[2]} -gt 255 -o ${O1[3]} -gt 255 ] && echo "invalid" && exit 1
#--- IP ADDRESS 2
[ "${2//[0-9]/}" != '...' ] && echo "invalid" && exit 1
O2=(${2//./ })
[ -z "${O2[3]}" -o -n "${O2[4]}" ] && echo "invalid" && exit 1
[ ${O2[0]} -gt 255 -o ${O2[1]} -gt 255 -o ${O2[2]} -gt 255 -o ${O2[3]} -gt 255 ] && echo "invalid" && exit 1

#--- Numeric compares of each octet
echo "Comparing each octect"
if [ ${O1[0]} -eq ${O2[0]} ]
  then
    echo "  ${O1[0]} == ${O2[0]}"
  else
    echo "  ${O1[0]} != ${O2[0]}"
  fi
if [ ${O1[1]} -eq ${O2[1]} ]
  then
    echo "  ${O1[1]} == ${O2[1]}"
  else
    echo "  ${O1[1]} != ${O2[1]}"
  fi
if [ ${O1[2]} -eq ${O2[2]} ]
  then
    echo "  ${O1[2]} == ${O2[2]}"
  else
    echo "  ${O1[2]} != ${O2[2]}"
  fi
if [ ${O1[3]} -eq ${O2[3]} ]
  then
    echo "  ${O1[3]} == ${O2[3]}"
  else
    echo "  ${O1[3]} != ${O2[3]}"
  fi

#--- Numeric IP address compare
echo "Compare via long if"
if [ ${O1[0]} -eq ${O2[0]} -a ${O1[1]} -eq ${O2[1]} -a ${O1[2]} -eq ${O2[2]} -a ${O1[3]} -eq ${O2[3]} ]
  then
    echo "  ${1} == ${2}"
  else
    echo "  ${1} != ${2}"
  fi

#--- Loop for numeric compare
echo "Compare via loop"
SAME="Y"
for I in 0 1 2 3
  do
   echo "  loop ${I} compare ${O1[$I]} ${O2[$I]}"
   [ ${O1[$I]} -ne ${O2[$I]} ] && SAME="" && break
  done
echo "  result"
if [ -n "${SAME}" ]
  then
    echo "  ${1} == ${2}"
  else
    echo "  ${1} != ${2}"
  fi

exit


$ ./demo.sh 1.2.3.4 1.2.3
invalid
$ ./demo.sh 1.2.3.4 1.2.q.4
invalid
$ ./demo.sh 1.2.3.4 1.2.3.4.
invalid
$ ./demo.sh 1.2.3.4 1.2.3.4.5
invalid
$ ./demo.sh 1.2.3.4 1.2.300.4
invalid
$ ./demo.sh 1.02.3.004 01.2.003.4
Comparing each octect
  1 == 01
  02 == 2
  3 == 003
  004 == 4
Compare via long if
  1.02.3.004 == 01.2.003.4
Compare via loop
  loop 0 compare 1 01
  loop 1 compare 02 2
  loop 2 compare 3 003
  loop 3 compare 004 4
  result
  1.02.3.004 == 01.2.003.4
$ ./demo.sh 1.02.3.004 01.2.030.4
Comparing each octect
  1 == 01
  02 == 2
  3 != 030
  004 == 4
Compare via long if
  1.02.3.004 != 01.2.030.4
Compare via loop
  loop 0 compare 1 01
  loop 1 compare 02 2
  loop 2 compare 3 030
  result
  1.02.3.004 != 01.2.030.4
$