Source Code



Subnet Calculator

  • anonymous
  • Dec 19' 13
  • PHP
  • 497
  • 26
  • United States

Calculate syntax : input the IP Address

 

<!--
PK Subnet Itunger
www.pasarkode.com
<Common > Source for </Everyone> A portal that has dedication and 
concentration in the development of computer programming and more 
resource for help people such as open project, jobs, question & answer, 
additional tools, and many more. Collection of various kinds of code 
programming language from desktop to web programming.
-->
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
		"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
  <title>PHP Subnet Calculator</title>
  <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<style type="text/css">
a {
	text-decoration: none; color:white;
}
a:hover {
	text-decoration: none;
	color:#000;
}
.data{box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.1); width:700px;
background-color:#00A3E7; padding-top:10px}

</style>
</head>
<body >
<center>
<div class="data">
  <h2><a href="http://pasarkode.com">Pasar Kode Subnet Itunger</a></h2>
<div>
<form method="post" action="<?php print $_SERVER['PHP_SELF'] ?> ">

<table>
  <tr>
        <td>IP Address &amp; Mask or CIDR:&nbsp;&nbsp;&nbsp;</td>
        <td><input type="text" name="my_net_info" value="" size="31" maxlength="32"></td>
        <td>&nbsp;&nbsp;&nbsp;&nbsp;<input type="submit" value="Calculate" name="subnetcalc">
            &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
            &nbsp;</td>
  </tr>
</table></form>

</div>
</div>


<?php
//Start table
print "<table cellpadding=\"2\">\n<COL span=\"4\" align=\"left\">\n" ;

$end='</table><table width="700px" align=center cellpadding=2 cellspacing=2 border=0>
      <tr><td bgcolor="#999999"></td><tr><td align="center"><a href="http://pasarkode.com">
      

<img src="
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
Mid4lgAAAABJRU5ErkJggg==">



</a>
      </td></tr></table></center></body></html>';

if (empty($_POST['my_net_info'])){
	tr('Use IP & CIDR Netmask:&nbsp;', '10.0.0.1/22');
	tr('Or IP & Netmask:','10.0.0.1 255.255.252.0');
	tr('Or IP & Wildcard Mask:','10.0.0.1 0.0.3.255');
	print $end ;
	exit ;
}

$my_net_info=rtrim($_POST['my_net_info']);


if (! preg_match('/^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}\z/',$my_net_info)){
	tr("Invalid Input.");
	tr('Use IP & CIDR Netmask:&nbsp;', '10.0.0.1/22');
	tr('Or IP & Netmask:','10.0.0.1 255.255.252.0');
	tr('Or IP & Wildcard Mask:','10.0.0.1 0.0.3.255');
	print $end ;
	exit ;
}

if (preg_match("//",$my_net_info)){  //if cidr type mask
	$dq_host = strtok("$my_net_info", "/");
	$cdr_nmask = strtok("/");
	if (!($cdr_nmask >= 0 && $cdr_nmask <= 32)){
		tr("Invalid CIDR value. Try an integer 0 - 32.");
		print "$end";
		exit ;
	}
	$bin_nmask=cdrtobin($cdr_nmask);
	$bin_wmask=binnmtowm($bin_nmask);
} else { //Dotted quad mask?
    $dqs=explode(" ", $my_net_info);
	$dq_host=$dqs[0];
	$bin_nmask=dqtobin($dqs[1]);
	$bin_wmask=binnmtowm($bin_nmask);
	if (ereg("0",rtrim($bin_nmask, "0"))) {  //Wildcard mask then? hmm?
		$bin_wmask=dqtobin($dqs[1]);
		$bin_nmask=binwmtonm($bin_wmask);
		if (ereg("0",rtrim($bin_nmask, "0"))){ //If it's not wcard, whussup?
			tr("Invalid Netmask.");
			print "$end";
			exit ;
		}
	}
	$cdr_nmask=bintocdr($bin_nmask);
}

//Check for valid $dq_host d{1,3}\.
if(! preg_match('/^[0]./',$dq_host)){
	foreach( explode(".",$dq_host) as $octet ){
 		if($octet > 255){ 
			tr("Invalid IP Address");
			print $end ;
			exit;
		}
	
	}
}

$bin_host=dqtobin($dq_host);
$bin_bcast=(str_pad(substr($bin_host,0,$cdr_nmask),32,1));
$bin_net=(str_pad(substr($bin_host,0,$cdr_nmask),32,0));
$bin_first=(str_pad(substr($bin_net,0,31),32,1));
$bin_last=(str_pad(substr($bin_bcast,0,31),32,0));
$host_total=(bindec(str_pad("",(32-$cdr_nmask),1)) - 1);

if ($host_total <= 0){  //Takes care of 31 and 32 bit masks.
	$bin_first="N/A" ; $bin_last="N/A" ; $host_total="N/A";
	if ($bin_net === $bin_bcast) $bin_bcast="N/A";
}

//Determine Class
if (preg_match('/^[0]/',$bin_net)){
	$class="A";
	$dotbin_net= "<font color=\"Green\">0</font>" . substr(dotbin($bin_net,$cdr_nmask),1) ;
}elseif (ereg('^10',$bin_net)){
	$class="B";
	$dotbin_net= "<font color=\"Green\">10</font>" . substr(dotbin($bin_net,$cdr_nmask),2) ;
}elseif (ereg('^110',$bin_net)){
  	$class="C";
	$dotbin_net= "<font color=\"Green\">110</font>" . substr(dotbin($bin_net,$cdr_nmask),3) ;
}elseif (ereg('^1110',$bin_net)){
  	$class="D";
	$dotbin_net= "<font color=\"Green\">1110</font>" . substr(dotbin($bin_net,$cdr_nmask),4) ;
	$special="<font color=\"Green\">Class D = Multicast Address Space.</font>";
}else{
  	$class="E";
	$dotbin_net= "<font color=\"Green\">1111</font>" . substr(dotbin($bin_net,$cdr_nmask),4) ;
	$special="<font color=\"Green\">Class E = Experimental Address Space.</font>";
}
///^[0]./
if (preg_match('/^(00001010)|(101011000001)|(1100000010101000)/',$bin_net)){
  	 $special='<a href="http://www.ietf.org/rfc/rfc1918.txt">( RFC-1918 Private Internet Address. )</a>';
}

// Print Results
tr('Address:',"<font color=\"blue\">$dq_host</font>",
	'<font color="brown">'.dotbin($bin_host,$cdr_nmask).'</font>');
tr('Netmask:','<font color="blue">'.bintodq($bin_nmask)." = $cdr_nmask</font>",
	'<font color="red">'.dotbin($bin_nmask, $cdr_nmask).'</font>');
tr('Wildcard:', '<font color="blue">'.bintodq($bin_wmask).'</font>',
	'<font color="brown">'.dotbin($bin_wmask, $cdr_nmask).'</font>');
tr('Network:', '<font color="blue">'.bintodq($bin_net).'</font>',
	"<font color=\"brown\">$dotbin_net</font>","<font color=\"Green\">(Class $class)</font>");
tr('Broadcast:','<font color="blue">'.bintodq($bin_bcast).'</font>',
	'<font color="brown">'.dotbin($bin_bcast, $cdr_nmask).'</font>');
tr('HostMin:', '<font color="blue">'.bintodq($bin_first).'</font>',
	'<font color="brown">'.dotbin($bin_first, $cdr_nmask).'</font>');
tr('HostMax:', '<font color="blue">'.bintodq($bin_last).'</font>',
	'<font color="brown">'.dotbin($bin_last, $cdr_nmask).'</font>');
@tr('Hosts/Net:', '<font color="blue">'.$host_total.'</font>', "$special");
print "$end";

function binnmtowm($binin){
	$binin=rtrim($binin, "0");
	if (!preg_match("/^[0]*$/",$binin) ){
		return str_pad(str_replace("1","0",$binin), 32, "1");
	} else return "1010101010101010101010101010101010101010";
}

function bintocdr ($binin){
	return strlen(rtrim($binin,"0"));
}

function bintodq ($binin) {
	if ($binin=="N/A") return $binin;
	$binin=explode(".", chunk_split($binin,8,"."));
	for ($i=0; $i<4 ; $i++) {
		$dq[$i]=bindec($binin[$i]);
	}
        return implode(".",$dq) ;
}

function bintoint ($binin){
        return bindec($binin);
}

function binwmtonm($binin){
	$binin=rtrim($binin, "1");
	if (!ereg("1",$binin)){
		return str_pad(str_replace("0","1",$binin), 32, "0");
	} else return "1010101010101010101010101010101010101010";
}

function cdrtobin ($cdrin){
	return str_pad(str_pad("", $cdrin, "1"), 32, "0");
}

function dotbin($binin,$cdr_nmask){
	// splits 32 bit bin into dotted bin octets
	if ($binin=="N/A") return $binin;
	$oct=rtrim(chunk_split($binin,8,"."),".");
	if ($cdr_nmask > 0){
		$offset=sprintf("%u",$cdr_nmask/8) + $cdr_nmask ;
		return substr($oct,0,$offset ) . "&nbsp;&nbsp;&nbsp;" . substr($oct,$offset) ;
	} else {
	return $oct;
	}
}

function dqtobin($dqin) {
        $dq = explode(".",$dqin);
        for ($i=0; $i<4 ; $i++) {
           $bin[$i]=str_pad(decbin($dq[$i]), 8, "0", STR_PAD_LEFT);
        }
        return implode("",$bin);
}

function inttobin ($intin) {
        return str_pad(decbin($intin), 32, "0", STR_PAD_LEFT);
}

function tr(){
	echo "\t<tr>";
	for($i=0; $i<func_num_args(); $i++) echo "<td>".func_get_arg($i)."</td>";
	echo "</tr>\n";
}
?>
  • Tags : php, ip, calculator, subnet
comments powered by Disqus

Related Code

Execute a JavaScript Code on a TWebBrowser Document

Get MAC Address of Network Card

Get Meta Tag Information

Vulnerable Scan Web

Resizable forms and size grip

CSS Pop UP with Javascript

Color Picker

Using WinZip as a backup tool



Category

Tag Linked