Dateien hochladen nach „“
parent
0b2e02e264
commit
4feb3f83ee
@ -0,0 +1,359 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<style>
|
||||||
|
body{
|
||||||
|
background-color: #ddd;
|
||||||
|
}
|
||||||
|
*{
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
font-family: "Bahnschrift Light";
|
||||||
|
}
|
||||||
|
input{
|
||||||
|
font-size: 1.1rem;
|
||||||
|
}
|
||||||
|
.input-field{
|
||||||
|
height: 97vh;
|
||||||
|
width: 25vw;
|
||||||
|
padding: 3vh 0vw 0vh 3vw;
|
||||||
|
position: absolute;
|
||||||
|
right: 0vw;
|
||||||
|
}
|
||||||
|
.output_field{
|
||||||
|
height: 90vh;
|
||||||
|
width: 50vw;
|
||||||
|
background-color: #eee;
|
||||||
|
padding: 10vh 0vw 0vh 3vw;
|
||||||
|
position: absolute;
|
||||||
|
transform: translate(-50%, -50%);
|
||||||
|
left: 47vw;
|
||||||
|
top: 50vh;
|
||||||
|
|
||||||
|
display: flex;
|
||||||
|
}
|
||||||
|
.output{
|
||||||
|
margin-left: 1.5vw;
|
||||||
|
width: 80%;
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
}
|
||||||
|
.val, .category{
|
||||||
|
height: 1.2vw;
|
||||||
|
padding: .8vh 0vw;
|
||||||
|
margin: 1vh 0vw; /* Paragraphs use only the half of the margin, cause of the overlap of margin-top && margin-bottom. */
|
||||||
|
}
|
||||||
|
.category:nth-child(1), .category:nth-child(2){
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
.val{
|
||||||
|
padding-left: 2%;
|
||||||
|
border: none;
|
||||||
|
border-radius: .6em;
|
||||||
|
background-color: rgba(20, 20, 20, 0.1);
|
||||||
|
margin: 0.5vh 0vw;
|
||||||
|
}
|
||||||
|
.inp{
|
||||||
|
padding: .2em;
|
||||||
|
width: 3em;
|
||||||
|
border-image: linear-gradient(30deg, rgba(20, 20, 20, 1) 1%, rgba(20, 20, 20, 0.2) 60%);
|
||||||
|
border-image-slice: 1;
|
||||||
|
outline: none;
|
||||||
|
}
|
||||||
|
.input_block{
|
||||||
|
height: 3.5em;
|
||||||
|
margin-right: 1em;
|
||||||
|
font-size: 1.5rem;
|
||||||
|
float: right;
|
||||||
|
display: flex;
|
||||||
|
justify-content: space-between;
|
||||||
|
flex-direction: column;
|
||||||
|
}
|
||||||
|
.inp_category{
|
||||||
|
float: left;
|
||||||
|
display: flex;
|
||||||
|
justify-content: space-between;
|
||||||
|
flex-direction: column;
|
||||||
|
}
|
||||||
|
input[type=submit]{
|
||||||
|
margin-top: 2vh;
|
||||||
|
margin-left: .3vw;
|
||||||
|
outline: none;
|
||||||
|
padding: .5em;
|
||||||
|
cursor: pointer;
|
||||||
|
border-image: linear-gradient(30deg, rgba(90, 90, 90, 1) 1%, rgba(20, 20, 20, 0.2) 60%);
|
||||||
|
border-image-slice: 1;
|
||||||
|
background-color: rgba(20, 20, 20, 0.1);
|
||||||
|
transition: .4s ease-out;
|
||||||
|
-o-transition: .4s ease-out;
|
||||||
|
-mo-transition: .4s ease-out;
|
||||||
|
-moz-transition: .4s ease-out;
|
||||||
|
-webkit-transition: .4s ease-out;
|
||||||
|
}
|
||||||
|
input[type=submit]:hover{
|
||||||
|
background-color: rgba(0, 0, 0, 0.0);
|
||||||
|
}
|
||||||
|
img{
|
||||||
|
float: left;
|
||||||
|
width: 2em;
|
||||||
|
margin-right: 1em;
|
||||||
|
filter: grayscale(0.3);
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<body>
|
||||||
|
<main>
|
||||||
|
<div class="output_field">
|
||||||
|
<div class="categories">
|
||||||
|
<p class="category">Actual IP:</p>
|
||||||
|
<p class="category">Subnet:</p>
|
||||||
|
<p class="category">Network size:</p>
|
||||||
|
<p class="category">Network IP:</p>
|
||||||
|
<p class="category">Broadcast:</p>
|
||||||
|
<p class="category">Host-IP from:</p>
|
||||||
|
<p class="category">Host-IP to:</p>
|
||||||
|
</div>
|
||||||
|
<div class="output">
|
||||||
|
<input type="text" disabled class="val" id="ipOut">
|
||||||
|
<input type="text" disabled class="val" id="snmOut">
|
||||||
|
<input type="text" disabled class="val" id="nwSize">
|
||||||
|
<input type="text" disabled class="val" id="ntwOut">
|
||||||
|
<input type="text" disabled class="val" id="firstOut">
|
||||||
|
<input type="text" disabled class="val" id="lastOut">
|
||||||
|
<input type="text" disabled class="val" id="brdOut">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="input-field">
|
||||||
|
<h2>IP-Calculator</h2>
|
||||||
|
<span class="inp_category">
|
||||||
|
<p style="display: flex; align-items: center;"><img src="icon/info.svg"> Actual IP:</p><br>
|
||||||
|
<p style="display: flex; align-items: center;"><img src="icon/info.svg"> Subnet musc:</p>
|
||||||
|
</span>
|
||||||
|
<span class="input_block">
|
||||||
|
<div>
|
||||||
|
<input class="inp" type="num" id="ip1" maxlength="3" value="40">.
|
||||||
|
<input class="inp" type="num" id="ip2" maxlength="3" value="1">.
|
||||||
|
<input class="inp" type="num" id="ip3" maxlength="3" value="1">.
|
||||||
|
<input class="inp" type="num" id="ip4" maxlength="3" value="90">
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<input class="inp" type="num" id="snm1" maxlength="3" value="255">.
|
||||||
|
<input class="inp" type="num" id="snm2" maxlength="3" value="255">.
|
||||||
|
<input class="inp" type="num" id="snm3" maxlength="3" value="255">.
|
||||||
|
<input class="inp" type="num" id="snm4" maxlength="3" value="255">
|
||||||
|
</div>
|
||||||
|
</span>
|
||||||
|
<input type="submit" id="trigger" value="calculate">
|
||||||
|
</div>
|
||||||
|
</main>
|
||||||
|
<script type="text/javascript">
|
||||||
|
const trigger = document.getElementById("trigger")
|
||||||
|
class IPCalc{
|
||||||
|
constructor(ip, subnet){
|
||||||
|
this.ip = ip
|
||||||
|
this.subnet = subnet
|
||||||
|
}
|
||||||
|
calculateSubnet(){
|
||||||
|
|
||||||
|
let subnetPartBinaryArr = []
|
||||||
|
let subnetBinaryArr = []
|
||||||
|
|
||||||
|
let filteredSubnet = ""
|
||||||
|
|
||||||
|
let filter = false
|
||||||
|
|
||||||
|
for(let i = 0; i < this.subnet.length; i++){
|
||||||
|
if(!this.subnet[i]){
|
||||||
|
this.subnet[i] = "0"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for(let i = 0; i < this.subnet.length; i++){
|
||||||
|
this.subnet[i] = parseInt(this.subnet[i]).toString(2)
|
||||||
|
|
||||||
|
for(let j = 0; j < this.subnet[i].length; j++){
|
||||||
|
subnetPartBinaryArr.push(this.subnet[i].charAt(j))
|
||||||
|
}
|
||||||
|
if(subnetPartBinaryArr.length < 8){
|
||||||
|
for(let j = subnetPartBinaryArr.length; j < 8; j++){
|
||||||
|
subnetPartBinaryArr.unshift("0")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if(subnetPartBinaryArr.length > 8){
|
||||||
|
subnetPartBinaryArr = ["1", "1", "1", "1", "1", "1", "1", "1"]
|
||||||
|
}
|
||||||
|
if(i == 0){
|
||||||
|
subnetPartBinaryArr = ["1", "1", "1", "1", "1", "1", "1", "1"]
|
||||||
|
}
|
||||||
|
subnetBinaryArr.push(subnetPartBinaryArr)
|
||||||
|
subnetPartBinaryArr = []
|
||||||
|
}
|
||||||
|
|
||||||
|
for(let i = 0; i < subnetBinaryArr.length; i++){
|
||||||
|
for(let j = 0; j < subnetBinaryArr[i].length; j++){
|
||||||
|
if(subnetBinaryArr[i][j] != "1"){
|
||||||
|
filter = true
|
||||||
|
}
|
||||||
|
if(filter == true){
|
||||||
|
subnetBinaryArr[i][j] = "0"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
filter = false
|
||||||
|
}
|
||||||
|
|
||||||
|
for(let i = 0; i < subnetBinaryArr.length; i++){
|
||||||
|
if(filter != true){
|
||||||
|
let mergedBinaryPart = subnetBinaryArr[i].join().replaceAll(",", "")
|
||||||
|
let decimalPart = parseInt(mergedBinaryPart, 2)
|
||||||
|
if(decimalPart != 255){
|
||||||
|
filter = true
|
||||||
|
}
|
||||||
|
filteredSubnet += decimalPart + "."
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
filteredSubnet += 0 + "."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
filteredSubnet = filteredSubnet.substring(0, filteredSubnet.length - 1)
|
||||||
|
return filteredSubnet
|
||||||
|
}
|
||||||
|
|
||||||
|
calculateAvailableHosts(){
|
||||||
|
let pow = 0
|
||||||
|
let filteredSubnet = document.getElementById("snmOut").value
|
||||||
|
|
||||||
|
filteredSubnet = filteredSubnet.split(".")
|
||||||
|
for(let i = 0; i < filteredSubnet.length; i++){
|
||||||
|
let snmLast = 256 - filteredSubnet[i]
|
||||||
|
for(let j = 1; Math.pow(2, j) <= snmLast; j++){
|
||||||
|
pow++
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return Math.pow(2, pow)
|
||||||
|
}
|
||||||
|
|
||||||
|
calculateRest(){
|
||||||
|
let hosts = this.calculateAvailableHosts()
|
||||||
|
let fltIp = ""
|
||||||
|
|
||||||
|
let min = 0
|
||||||
|
let max = 0
|
||||||
|
let ntw = 0
|
||||||
|
let first = 0
|
||||||
|
let last = 0
|
||||||
|
let brd = 255
|
||||||
|
|
||||||
|
let out = []
|
||||||
|
|
||||||
|
let repeater = true
|
||||||
|
let counter = 0;
|
||||||
|
|
||||||
|
let c = 256
|
||||||
|
let b = 65536
|
||||||
|
let a = 16777216
|
||||||
|
|
||||||
|
for(let i = 0; i < this.ip.length; i++){
|
||||||
|
if(this.ip[i] > 255){
|
||||||
|
this.ip[i] = "255"
|
||||||
|
}
|
||||||
|
else if(this.ip[i] < 0){
|
||||||
|
this.ip[i] = 0
|
||||||
|
}
|
||||||
|
fltIp += this.ip[i] + "."
|
||||||
|
}
|
||||||
|
fltIp = fltIp.substring(0, fltIp.length - 1)
|
||||||
|
|
||||||
|
if(hosts <= 2){
|
||||||
|
while(repeater){
|
||||||
|
if(this.ip[3] - (counter * hosts) < hosts){
|
||||||
|
repeater = false
|
||||||
|
min = counter * hosts
|
||||||
|
max = ++counter * hosts - 1
|
||||||
|
}
|
||||||
|
counter++
|
||||||
|
}
|
||||||
|
ntw = this.ip[0] + "." + this.ip[1] + "." + this.ip[2] + "." + min
|
||||||
|
first = "-"
|
||||||
|
last = "-"
|
||||||
|
brd = this.ip[0] + "." + this.ip[1] + "." + this.ip[2] + "." + max
|
||||||
|
}
|
||||||
|
else if(2 < hosts && hosts <= c){ //C Class
|
||||||
|
while(repeater){
|
||||||
|
if(this.ip[3] - (counter * hosts) < hosts){
|
||||||
|
repeater = false
|
||||||
|
min = counter * hosts
|
||||||
|
max = ++counter * hosts - 1
|
||||||
|
}
|
||||||
|
counter++
|
||||||
|
}
|
||||||
|
ntw = this.ip[0] + "." + this.ip[1] + "." + this.ip[2] + "." + min
|
||||||
|
first = this.ip[0] + "." + this.ip[1] + "." + this.ip[2] + "." + (min + 1)
|
||||||
|
last = this.ip[0] + "." + this.ip[1] + "." + this.ip[2] + "." + (max - 1)
|
||||||
|
brd = this.ip[0] + "." + this.ip[1] + "." + this.ip[2] + "." + max
|
||||||
|
}
|
||||||
|
else if(hosts > c && hosts <= b){ //B Class
|
||||||
|
hosts = hosts / c
|
||||||
|
while(repeater){
|
||||||
|
if(this.ip[2] - (counter * hosts) < hosts){
|
||||||
|
repeater = false
|
||||||
|
min = counter * hosts
|
||||||
|
max = ++counter * hosts
|
||||||
|
}
|
||||||
|
counter++
|
||||||
|
}
|
||||||
|
ntw = this.ip[0] + "." + this.ip[1] + "." + min + "." + 0
|
||||||
|
first = this.ip[0] + "." + this.ip[1] + "." + min + "." + 1
|
||||||
|
last = this.ip[0] + "." + this.ip[1] + "." + (max - 1) + "." + 254
|
||||||
|
brd = this.ip[0] + "." + this.ip[1] + "." + (max - 1) + "." + 255
|
||||||
|
}
|
||||||
|
else if(hosts > b && hosts <= a){ //A Class
|
||||||
|
hosts = hosts / b
|
||||||
|
while(repeater){
|
||||||
|
if(this.ip[1] - (counter * hosts) < hosts){
|
||||||
|
repeater = false
|
||||||
|
min = counter * hosts
|
||||||
|
max = ++counter * hosts
|
||||||
|
}
|
||||||
|
counter++
|
||||||
|
}
|
||||||
|
ntw = this.ip[0] + "." + min + "." + 0 + "." + 0
|
||||||
|
first = this.ip[0] + "." + min + "." + 0 + "." + 1
|
||||||
|
last = this.ip[0] + "." + (max - 1)+ "." + 255 + "." + 254
|
||||||
|
brd = this.ip[0] + "." + (max - 1)+ "." + 255 + "." + 255
|
||||||
|
}
|
||||||
|
out = [fltIp, ntw, brd, first, last]
|
||||||
|
return out
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
output(){
|
||||||
|
document.getElementById("snmOut").value = this.calculateSubnet()
|
||||||
|
document.getElementById("nwSize").value = this.calculateAvailableHosts()
|
||||||
|
document.getElementById("ipOut").value = this.calculateRest()[0]
|
||||||
|
document.getElementById("ntwOut").value = this.calculateRest()[1]
|
||||||
|
document.getElementById("firstOut").value = this.calculateRest()[2]
|
||||||
|
document.getElementById("lastOut").value = this.calculateRest()[3]
|
||||||
|
document.getElementById("brdOut").value = this.calculateRest()[4]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
trigger.addEventListener("click", () => {
|
||||||
|
console.log(document.getElementById("ip2").value)
|
||||||
|
const ip = [document.getElementById("ip1").value,
|
||||||
|
document.getElementById("ip2").value,
|
||||||
|
document.getElementById("ip3").value,
|
||||||
|
document.getElementById("ip4").value]
|
||||||
|
const subnet = [document.getElementById("snm1").value,
|
||||||
|
document.getElementById("snm2").value,
|
||||||
|
document.getElementById("snm3").value,
|
||||||
|
document.getElementById("snm4").value]
|
||||||
|
|
||||||
|
const calc = new IPCalc(ip, subnet)
|
||||||
|
calc.output()
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
</body>
|
||||||
|
</html>
|
Loading…
Reference in New Issue