Check whether an IP belongs to a specific range The 2019 Stack Overflow Developer Survey Results Are Inbc command unexpected resultsQuickly check whether many network hosts are up-and-runningIn a Bash if condition, how to check whether any files matching a simple wildcard expression exist?bash script to check file ownershipCheck if $REPLY is in a range of numbersgrep (/sed/awk) month rangeScript to remove IPs or network ranges from an IP spaceCheck in bash if make has done somethingI want to measure the time between two jobs in a logfileextract time range from log file using AWKHow do I check if I am in a graphical environment on a Mac using bash?

Geography at the pixel level

I see my dog run

What are my rights when I have a Sparpreis ticket but can't board an overcrowded train?

Could JWST stay at L2 "forever"?

What does Linus Torvalds mean when he says that Git "never ever" tracks a file?

How come people say “Would of”?

Is flight data recorder erased after every flight?

How was Skylab's orbit inclination chosen?

Can't find the latex code for the ⍎ (down tack jot) symbol

Is domain driven design an anti-SQL pattern?

How to change the limits of integration

JSON.serialize: is it possible to suppress null values of a map?

What could be the right powersource for 15 seconds lifespan disposable giant chainsaw?

Unbreakable Formation vs. Cry of the Carnarium

What are the motivations for publishing new editions of an existing textbook, beyond new discoveries in a field?

How can I create a character who can assume the widest possible range of creature sizes?

Why can Shazam do this?

Why do UK politicians seemingly ignore opinion polls on Brexit?

In microwave frequencies, do you use a circulator when you need a (near) perfect diode?

What do the Banks children have against barley water?

aging parents with no investments

Where to refill my bottle in India?

What is the meaning of Triage in Cybersec world?

Does duplicating a spell with Wish count as casting that spell?



Check whether an IP belongs to a specific range



The 2019 Stack Overflow Developer Survey Results Are Inbc command unexpected resultsQuickly check whether many network hosts are up-and-runningIn a Bash if condition, how to check whether any files matching a simple wildcard expression exist?bash script to check file ownershipCheck if $REPLY is in a range of numbersgrep (/sed/awk) month rangeScript to remove IPs or network ranges from an IP spaceCheck in bash if make has done somethingI want to measure the time between two jobs in a logfileextract time range from log file using AWKHow do I check if I am in a graphical environment on a Mac using bash?



.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty margin-bottom:0;








0















I have a log file that lists whitelisted IP ranges in this manner:



"217.29.0.0-217.29.255.255",
"204.12.0.0-204.12.255.255",
"198.54.223.0-198.54.223.255",


I am also working on a bash script which, amongst other things, needs to check this logfile and determine if a specified IP is whitelisted.



In the case of IP 204.12.5.10, for instance, how would I use the log file with the specified ranges to determine whether that IP is part of a range in that file?










share|improve this question
























  • Does it have to be bash? And do you need to support different address formats?

    – Sobrique
    Oct 5 '15 at 12:17











  • It has to be bash, or something called from bash (such as the ipcalc utility). The only format I will need to do this for is the above-given [range-start]-[range-end] format, as that is the format this specific logfile uses.

    – wbruan
    Oct 5 '15 at 12:19











  • Nopte that the aaa.bbb.ccc.ddd format is just custom, but you can trivially convert that to any other format. And if you convert it to decimal then you can simply check with the larger than and small than operators. (actually => and =<, since you probably want to include the edges).

    – Hennes
    Oct 5 '15 at 12:28

















0















I have a log file that lists whitelisted IP ranges in this manner:



"217.29.0.0-217.29.255.255",
"204.12.0.0-204.12.255.255",
"198.54.223.0-198.54.223.255",


I am also working on a bash script which, amongst other things, needs to check this logfile and determine if a specified IP is whitelisted.



In the case of IP 204.12.5.10, for instance, how would I use the log file with the specified ranges to determine whether that IP is part of a range in that file?










share|improve this question
























  • Does it have to be bash? And do you need to support different address formats?

    – Sobrique
    Oct 5 '15 at 12:17











  • It has to be bash, or something called from bash (such as the ipcalc utility). The only format I will need to do this for is the above-given [range-start]-[range-end] format, as that is the format this specific logfile uses.

    – wbruan
    Oct 5 '15 at 12:19











  • Nopte that the aaa.bbb.ccc.ddd format is just custom, but you can trivially convert that to any other format. And if you convert it to decimal then you can simply check with the larger than and small than operators. (actually => and =<, since you probably want to include the edges).

    – Hennes
    Oct 5 '15 at 12:28













0












0








0








I have a log file that lists whitelisted IP ranges in this manner:



"217.29.0.0-217.29.255.255",
"204.12.0.0-204.12.255.255",
"198.54.223.0-198.54.223.255",


I am also working on a bash script which, amongst other things, needs to check this logfile and determine if a specified IP is whitelisted.



In the case of IP 204.12.5.10, for instance, how would I use the log file with the specified ranges to determine whether that IP is part of a range in that file?










share|improve this question
















I have a log file that lists whitelisted IP ranges in this manner:



"217.29.0.0-217.29.255.255",
"204.12.0.0-204.12.255.255",
"198.54.223.0-198.54.223.255",


I am also working on a bash script which, amongst other things, needs to check this logfile and determine if a specified IP is whitelisted.



In the case of IP 204.12.5.10, for instance, how would I use the log file with the specified ranges to determine whether that IP is part of a range in that file?







bash scripting ip






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Oct 5 '15 at 12:20







wbruan

















asked Oct 5 '15 at 12:11









wbruanwbruan

335139




335139












  • Does it have to be bash? And do you need to support different address formats?

    – Sobrique
    Oct 5 '15 at 12:17











  • It has to be bash, or something called from bash (such as the ipcalc utility). The only format I will need to do this for is the above-given [range-start]-[range-end] format, as that is the format this specific logfile uses.

    – wbruan
    Oct 5 '15 at 12:19











  • Nopte that the aaa.bbb.ccc.ddd format is just custom, but you can trivially convert that to any other format. And if you convert it to decimal then you can simply check with the larger than and small than operators. (actually => and =<, since you probably want to include the edges).

    – Hennes
    Oct 5 '15 at 12:28

















  • Does it have to be bash? And do you need to support different address formats?

    – Sobrique
    Oct 5 '15 at 12:17











  • It has to be bash, or something called from bash (such as the ipcalc utility). The only format I will need to do this for is the above-given [range-start]-[range-end] format, as that is the format this specific logfile uses.

    – wbruan
    Oct 5 '15 at 12:19











  • Nopte that the aaa.bbb.ccc.ddd format is just custom, but you can trivially convert that to any other format. And if you convert it to decimal then you can simply check with the larger than and small than operators. (actually => and =<, since you probably want to include the edges).

    – Hennes
    Oct 5 '15 at 12:28
















Does it have to be bash? And do you need to support different address formats?

– Sobrique
Oct 5 '15 at 12:17





Does it have to be bash? And do you need to support different address formats?

– Sobrique
Oct 5 '15 at 12:17













It has to be bash, or something called from bash (such as the ipcalc utility). The only format I will need to do this for is the above-given [range-start]-[range-end] format, as that is the format this specific logfile uses.

– wbruan
Oct 5 '15 at 12:19





It has to be bash, or something called from bash (such as the ipcalc utility). The only format I will need to do this for is the above-given [range-start]-[range-end] format, as that is the format this specific logfile uses.

– wbruan
Oct 5 '15 at 12:19













Nopte that the aaa.bbb.ccc.ddd format is just custom, but you can trivially convert that to any other format. And if you convert it to decimal then you can simply check with the larger than and small than operators. (actually => and =<, since you probably want to include the edges).

– Hennes
Oct 5 '15 at 12:28





Nopte that the aaa.bbb.ccc.ddd format is just custom, but you can trivially convert that to any other format. And if you convert it to decimal then you can simply check with the larger than and small than operators. (actually => and =<, since you probably want to include the edges).

– Hennes
Oct 5 '15 at 12:28










2 Answers
2






active

oldest

votes


















2














The useful thing to remember with IP addresses is that they're actually just representations of a 32bit number.



So you can convert them to a decimal by multiplying the octets as base 256.



E.g.:



217.29.0.0 == 216 * 256 ^ 3 + 29 * 256 ^2 + 0 * 256 ^1 + 0 * 256 ^ 0
== 3640655872


So given a range like the above - first convert them both, such that you've got a start and end. Then compare any incoming IPs to see if they 'fit'.



So something like this (illustrating algorithm):



#!/usr/bin/env perl
use strict;
use warnings;

my $ip_to_check = "204.12.5.10";
my $dword = 0;
for ( split( '.', $ip_to_check ) ) $dword *= 256; $dword += $_
print "Checking $dwordn";

while (<DATA>)
my ( $start, $finish ) = m/([d.]+)/g;
my $start_dword = 0;
for ( split '.', $start ) $start_dword *= 256; $start_dword += $_
my $end_dword = 0;
for ( split '.', $finish ) $end_dword *= 256; $end_dword += $_
print "Range:n";
print "t$start t=> $start_dwordn";
print "t$finish t=> $end_dwordn";

print "$ip_to_check is in $_n" if $dword >= $start_dword and $dword <= $end_dword;


__DATA__
"217.29.0.0-217.29.255.255",
"204.12.0.0-204.12.255.255",
"198.54.223.0-198.54.223.255",


Could quite easily do that as a 'check script' - by reading a file (rather than DATA) and getting $ip_to_check from STDIN).



(note - as pure perl could be turned into a one liner fairly easily, or a script to call. Or re-written - I daresay you could do this with expr easily enough).






share|improve this answer























  • Though perl and not bash, this did work for my purposes. Thank you.

    – wbruan
    Oct 7 '15 at 5:08











  • Yes, I'm afraid I defected to perl many years ago when I started to stretch the limits of what could be done in bash. Fortunately, it's almost as ubiquitous, so you're not really inhibiting yourself much. (And in some cases - it's more common, for example if you're ever having to interact with AIX or another OS that doesn't do bash by default)

    – Sobrique
    Oct 7 '15 at 9:09


















1














Here's an awk version:



want=204.12.77.5
awk -v want=$want -F- '
function canon(ip)
split(" "ip,x,/[^0-9]+/)
return sprintf("%03d%03d%03d%03d",x[2],x[3],x[4],x[5])

BEGIN val = canon(want)
low = canon($1); high = canon($2);
if(val>=low && val<=high)print "in range " $0
' mylogfile


The function canon takes an ip address, splits out the number fields,
then extends each to 3 digits and returns the string.
It is called for the 2 values on each line, and these are
compared with the wanted ip address (set at the start), which
has also been "canonified".






share|improve this answer























    Your Answer








    StackExchange.ready(function()
    var channelOptions =
    tags: "".split(" "),
    id: "106"
    ;
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function()
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled)
    StackExchange.using("snippets", function()
    createEditor();
    );

    else
    createEditor();

    );

    function createEditor()
    StackExchange.prepareEditor(
    heartbeatType: 'answer',
    autoActivateHeartbeat: false,
    convertImagesToLinks: false,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: null,
    bindNavPrevention: true,
    postfix: "",
    imageUploader:
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    ,
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    );



    );













    draft saved

    draft discarded


















    StackExchange.ready(
    function ()
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f234008%2fcheck-whether-an-ip-belongs-to-a-specific-range%23new-answer', 'question_page');

    );

    Post as a guest















    Required, but never shown

























    2 Answers
    2






    active

    oldest

    votes








    2 Answers
    2






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    2














    The useful thing to remember with IP addresses is that they're actually just representations of a 32bit number.



    So you can convert them to a decimal by multiplying the octets as base 256.



    E.g.:



    217.29.0.0 == 216 * 256 ^ 3 + 29 * 256 ^2 + 0 * 256 ^1 + 0 * 256 ^ 0
    == 3640655872


    So given a range like the above - first convert them both, such that you've got a start and end. Then compare any incoming IPs to see if they 'fit'.



    So something like this (illustrating algorithm):



    #!/usr/bin/env perl
    use strict;
    use warnings;

    my $ip_to_check = "204.12.5.10";
    my $dword = 0;
    for ( split( '.', $ip_to_check ) ) $dword *= 256; $dword += $_
    print "Checking $dwordn";

    while (<DATA>)
    my ( $start, $finish ) = m/([d.]+)/g;
    my $start_dword = 0;
    for ( split '.', $start ) $start_dword *= 256; $start_dword += $_
    my $end_dword = 0;
    for ( split '.', $finish ) $end_dword *= 256; $end_dword += $_
    print "Range:n";
    print "t$start t=> $start_dwordn";
    print "t$finish t=> $end_dwordn";

    print "$ip_to_check is in $_n" if $dword >= $start_dword and $dword <= $end_dword;


    __DATA__
    "217.29.0.0-217.29.255.255",
    "204.12.0.0-204.12.255.255",
    "198.54.223.0-198.54.223.255",


    Could quite easily do that as a 'check script' - by reading a file (rather than DATA) and getting $ip_to_check from STDIN).



    (note - as pure perl could be turned into a one liner fairly easily, or a script to call. Or re-written - I daresay you could do this with expr easily enough).






    share|improve this answer























    • Though perl and not bash, this did work for my purposes. Thank you.

      – wbruan
      Oct 7 '15 at 5:08











    • Yes, I'm afraid I defected to perl many years ago when I started to stretch the limits of what could be done in bash. Fortunately, it's almost as ubiquitous, so you're not really inhibiting yourself much. (And in some cases - it's more common, for example if you're ever having to interact with AIX or another OS that doesn't do bash by default)

      – Sobrique
      Oct 7 '15 at 9:09















    2














    The useful thing to remember with IP addresses is that they're actually just representations of a 32bit number.



    So you can convert them to a decimal by multiplying the octets as base 256.



    E.g.:



    217.29.0.0 == 216 * 256 ^ 3 + 29 * 256 ^2 + 0 * 256 ^1 + 0 * 256 ^ 0
    == 3640655872


    So given a range like the above - first convert them both, such that you've got a start and end. Then compare any incoming IPs to see if they 'fit'.



    So something like this (illustrating algorithm):



    #!/usr/bin/env perl
    use strict;
    use warnings;

    my $ip_to_check = "204.12.5.10";
    my $dword = 0;
    for ( split( '.', $ip_to_check ) ) $dword *= 256; $dword += $_
    print "Checking $dwordn";

    while (<DATA>)
    my ( $start, $finish ) = m/([d.]+)/g;
    my $start_dword = 0;
    for ( split '.', $start ) $start_dword *= 256; $start_dword += $_
    my $end_dword = 0;
    for ( split '.', $finish ) $end_dword *= 256; $end_dword += $_
    print "Range:n";
    print "t$start t=> $start_dwordn";
    print "t$finish t=> $end_dwordn";

    print "$ip_to_check is in $_n" if $dword >= $start_dword and $dword <= $end_dword;


    __DATA__
    "217.29.0.0-217.29.255.255",
    "204.12.0.0-204.12.255.255",
    "198.54.223.0-198.54.223.255",


    Could quite easily do that as a 'check script' - by reading a file (rather than DATA) and getting $ip_to_check from STDIN).



    (note - as pure perl could be turned into a one liner fairly easily, or a script to call. Or re-written - I daresay you could do this with expr easily enough).






    share|improve this answer























    • Though perl and not bash, this did work for my purposes. Thank you.

      – wbruan
      Oct 7 '15 at 5:08











    • Yes, I'm afraid I defected to perl many years ago when I started to stretch the limits of what could be done in bash. Fortunately, it's almost as ubiquitous, so you're not really inhibiting yourself much. (And in some cases - it's more common, for example if you're ever having to interact with AIX or another OS that doesn't do bash by default)

      – Sobrique
      Oct 7 '15 at 9:09













    2












    2








    2







    The useful thing to remember with IP addresses is that they're actually just representations of a 32bit number.



    So you can convert them to a decimal by multiplying the octets as base 256.



    E.g.:



    217.29.0.0 == 216 * 256 ^ 3 + 29 * 256 ^2 + 0 * 256 ^1 + 0 * 256 ^ 0
    == 3640655872


    So given a range like the above - first convert them both, such that you've got a start and end. Then compare any incoming IPs to see if they 'fit'.



    So something like this (illustrating algorithm):



    #!/usr/bin/env perl
    use strict;
    use warnings;

    my $ip_to_check = "204.12.5.10";
    my $dword = 0;
    for ( split( '.', $ip_to_check ) ) $dword *= 256; $dword += $_
    print "Checking $dwordn";

    while (<DATA>)
    my ( $start, $finish ) = m/([d.]+)/g;
    my $start_dword = 0;
    for ( split '.', $start ) $start_dword *= 256; $start_dword += $_
    my $end_dword = 0;
    for ( split '.', $finish ) $end_dword *= 256; $end_dword += $_
    print "Range:n";
    print "t$start t=> $start_dwordn";
    print "t$finish t=> $end_dwordn";

    print "$ip_to_check is in $_n" if $dword >= $start_dword and $dword <= $end_dword;


    __DATA__
    "217.29.0.0-217.29.255.255",
    "204.12.0.0-204.12.255.255",
    "198.54.223.0-198.54.223.255",


    Could quite easily do that as a 'check script' - by reading a file (rather than DATA) and getting $ip_to_check from STDIN).



    (note - as pure perl could be turned into a one liner fairly easily, or a script to call. Or re-written - I daresay you could do this with expr easily enough).






    share|improve this answer













    The useful thing to remember with IP addresses is that they're actually just representations of a 32bit number.



    So you can convert them to a decimal by multiplying the octets as base 256.



    E.g.:



    217.29.0.0 == 216 * 256 ^ 3 + 29 * 256 ^2 + 0 * 256 ^1 + 0 * 256 ^ 0
    == 3640655872


    So given a range like the above - first convert them both, such that you've got a start and end. Then compare any incoming IPs to see if they 'fit'.



    So something like this (illustrating algorithm):



    #!/usr/bin/env perl
    use strict;
    use warnings;

    my $ip_to_check = "204.12.5.10";
    my $dword = 0;
    for ( split( '.', $ip_to_check ) ) $dword *= 256; $dword += $_
    print "Checking $dwordn";

    while (<DATA>)
    my ( $start, $finish ) = m/([d.]+)/g;
    my $start_dword = 0;
    for ( split '.', $start ) $start_dword *= 256; $start_dword += $_
    my $end_dword = 0;
    for ( split '.', $finish ) $end_dword *= 256; $end_dword += $_
    print "Range:n";
    print "t$start t=> $start_dwordn";
    print "t$finish t=> $end_dwordn";

    print "$ip_to_check is in $_n" if $dword >= $start_dword and $dword <= $end_dword;


    __DATA__
    "217.29.0.0-217.29.255.255",
    "204.12.0.0-204.12.255.255",
    "198.54.223.0-198.54.223.255",


    Could quite easily do that as a 'check script' - by reading a file (rather than DATA) and getting $ip_to_check from STDIN).



    (note - as pure perl could be turned into a one liner fairly easily, or a script to call. Or re-written - I daresay you could do this with expr easily enough).







    share|improve this answer












    share|improve this answer



    share|improve this answer










    answered Oct 5 '15 at 12:31









    SobriqueSobrique

    3,839519




    3,839519












    • Though perl and not bash, this did work for my purposes. Thank you.

      – wbruan
      Oct 7 '15 at 5:08











    • Yes, I'm afraid I defected to perl many years ago when I started to stretch the limits of what could be done in bash. Fortunately, it's almost as ubiquitous, so you're not really inhibiting yourself much. (And in some cases - it's more common, for example if you're ever having to interact with AIX or another OS that doesn't do bash by default)

      – Sobrique
      Oct 7 '15 at 9:09

















    • Though perl and not bash, this did work for my purposes. Thank you.

      – wbruan
      Oct 7 '15 at 5:08











    • Yes, I'm afraid I defected to perl many years ago when I started to stretch the limits of what could be done in bash. Fortunately, it's almost as ubiquitous, so you're not really inhibiting yourself much. (And in some cases - it's more common, for example if you're ever having to interact with AIX or another OS that doesn't do bash by default)

      – Sobrique
      Oct 7 '15 at 9:09
















    Though perl and not bash, this did work for my purposes. Thank you.

    – wbruan
    Oct 7 '15 at 5:08





    Though perl and not bash, this did work for my purposes. Thank you.

    – wbruan
    Oct 7 '15 at 5:08













    Yes, I'm afraid I defected to perl many years ago when I started to stretch the limits of what could be done in bash. Fortunately, it's almost as ubiquitous, so you're not really inhibiting yourself much. (And in some cases - it's more common, for example if you're ever having to interact with AIX or another OS that doesn't do bash by default)

    – Sobrique
    Oct 7 '15 at 9:09





    Yes, I'm afraid I defected to perl many years ago when I started to stretch the limits of what could be done in bash. Fortunately, it's almost as ubiquitous, so you're not really inhibiting yourself much. (And in some cases - it's more common, for example if you're ever having to interact with AIX or another OS that doesn't do bash by default)

    – Sobrique
    Oct 7 '15 at 9:09













    1














    Here's an awk version:



    want=204.12.77.5
    awk -v want=$want -F- '
    function canon(ip)
    split(" "ip,x,/[^0-9]+/)
    return sprintf("%03d%03d%03d%03d",x[2],x[3],x[4],x[5])

    BEGIN val = canon(want)
    low = canon($1); high = canon($2);
    if(val>=low && val<=high)print "in range " $0
    ' mylogfile


    The function canon takes an ip address, splits out the number fields,
    then extends each to 3 digits and returns the string.
    It is called for the 2 values on each line, and these are
    compared with the wanted ip address (set at the start), which
    has also been "canonified".






    share|improve this answer



























      1














      Here's an awk version:



      want=204.12.77.5
      awk -v want=$want -F- '
      function canon(ip)
      split(" "ip,x,/[^0-9]+/)
      return sprintf("%03d%03d%03d%03d",x[2],x[3],x[4],x[5])

      BEGIN val = canon(want)
      low = canon($1); high = canon($2);
      if(val>=low && val<=high)print "in range " $0
      ' mylogfile


      The function canon takes an ip address, splits out the number fields,
      then extends each to 3 digits and returns the string.
      It is called for the 2 values on each line, and these are
      compared with the wanted ip address (set at the start), which
      has also been "canonified".






      share|improve this answer

























        1












        1








        1







        Here's an awk version:



        want=204.12.77.5
        awk -v want=$want -F- '
        function canon(ip)
        split(" "ip,x,/[^0-9]+/)
        return sprintf("%03d%03d%03d%03d",x[2],x[3],x[4],x[5])

        BEGIN val = canon(want)
        low = canon($1); high = canon($2);
        if(val>=low && val<=high)print "in range " $0
        ' mylogfile


        The function canon takes an ip address, splits out the number fields,
        then extends each to 3 digits and returns the string.
        It is called for the 2 values on each line, and these are
        compared with the wanted ip address (set at the start), which
        has also been "canonified".






        share|improve this answer













        Here's an awk version:



        want=204.12.77.5
        awk -v want=$want -F- '
        function canon(ip)
        split(" "ip,x,/[^0-9]+/)
        return sprintf("%03d%03d%03d%03d",x[2],x[3],x[4],x[5])

        BEGIN val = canon(want)
        low = canon($1); high = canon($2);
        if(val>=low && val<=high)print "in range " $0
        ' mylogfile


        The function canon takes an ip address, splits out the number fields,
        then extends each to 3 digits and returns the string.
        It is called for the 2 values on each line, and these are
        compared with the wanted ip address (set at the start), which
        has also been "canonified".







        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Oct 5 '15 at 13:27









        meuhmeuh

        32.5k12255




        32.5k12255



























            draft saved

            draft discarded
















































            Thanks for contributing an answer to Unix & Linux Stack Exchange!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid


            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.

            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f234008%2fcheck-whether-an-ip-belongs-to-a-specific-range%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            -bash, ip, scripting

            Popular posts from this blog

            Identify plant with long narrow paired leaves and reddish stems Planned maintenance scheduled April 17/18, 2019 at 00:00UTC (8:00pm US/Eastern) Announcing the arrival of Valued Associate #679: Cesar Manara Unicorn Meta Zoo #1: Why another podcast?What is this plant with long sharp leaves? Is it a weed?What is this 3ft high, stalky plant, with mid sized narrow leaves?What is this young shrub with opposite ovate, crenate leaves and reddish stems?What is this plant with large broad serrated leaves?Identify this upright branching weed with long leaves and reddish stemsPlease help me identify this bulbous plant with long, broad leaves and white flowersWhat is this small annual with narrow gray/green leaves and rust colored daisy-type flowers?What is this chilli plant?Does anyone know what type of chilli plant this is?Help identify this plant

            fontconfig warning: “/etc/fonts/fonts.conf”, line 100: unknown “element blank” The 2019 Stack Overflow Developer Survey Results Are In“tar: unrecognized option --warning” during 'apt-get install'How to fix Fontconfig errorHow do I figure out which font file is chosen for a system generic font alias?Why are some apt-get-installed fonts being ignored by fc-list, xfontsel, etc?Reload settings in /etc/fonts/conf.dTaking 30 seconds longer to boot after upgrade from jessie to stretchHow to match multiple font names with a single <match> element?Adding a custom font to fontconfigRemoving fonts from fontconfig <match> resultsBroken fonts after upgrading Firefox ESR to latest Firefox

            Shilpa Shastras Contents Description In painting In carpentry In metallurgy Shilpa Shastra education in ancient India Treatises on Shilpa Shastras See also References Further reading External links Navigation menueOverviewTraditions of the Indian Craftsman251930242ŚilpinŚilpiniTraditions of the Indian CraftsmanThe Technique of Wall Painting in Ancient IndiaEssay on the Architecture of the HindusThe Journal of the Society of Arts10.1007/s11837-998-0378-3The role of India in the diffusion of early culturesTraditions of the Indian CraftsmanAn Encyclopedia of Hindu ArchitectureBibliography of Vastu Shastra Literature, 1834-2009The Technique of Wall Painting in Ancient India4483067Les lapidaires indiens