# JavaScript-Javascript如何实现php的ip2long和long2ip功能

Javascript如何实现php的ip2long和long2ip功能。

### 评论（3）

2017-10-05 3 楼

function int2ip(i)
{
return [i >> 24 & 0xFF, i >> 16 & 0xFF, i >> 8 & 0xFF, i & 0xFF].join(".");
}

2017-09-13 2 楼

phpjs.org上有大部分js封装实现php的函数：

function ip2long (IP) {
var i = 0;
// PHP allows decimal, octal, and hexadecimal IP components.
// PHP allows between 1 (e.g. 127) to 4 (e.g 127.0.0.1) components.
IP = IP.match(/^([1-9]d|0[0-7]|0x[da-f]+)(?:.([1-9]d|0[0-7]|0x[da-f]+))?(?:.([1-9]d|0[0-7]|0x[da-f]+))?(?:.([1-9]d|0[0-7]|0x[da-f]+))?\$/i); // Verify IP format.
if (!IP) {
return false; // Invalid format.
}
// Reuse IP variable for component counter.
IP[0] = 0;
for (i = 1; i < 5; i += 1) {
IP[0] += !! ((IP[i] || '').length);
IP[i] = parseInt(IP[i]) || 0;
}
// Continue to use IP for overflow values.
// PHP does not allow any component to overflow.
IP.push(256, 256, 256, 256);
// Recalculate overflow of last component supplied to make up for missing components.
IP[4 + IP[0]] = Math.pow(256, 4 - IP[0]);
if (IP[1] >= IP[5] || IP[2] >= IP[6] || IP[3] >= IP[7] || IP[4] >= IP[8]) {
return false;
}
return IP[1]
(IP[0] === 1 || 16777216) + IP[2] (IP[0] <= 2 || 65536) + IP[3] (IP[0] <= 3 || 256) + IP[4] * 1;

``````function long2ip (proper_address) {

var output = false;

output = Math.floor(proper_address / Math.pow(256, 3)) + '.' + Math.floor((proper_address % Math.pow(256, 3)) / Math.pow(256, 2)) + '.' + Math.floor(((proper_address % Math.pow(256, 3)) % Math.pow(256, 2)) / Math.pow(256, 1)) + '.' + Math.floor((((proper_address % Math.pow(256, 3)) % Math.pow(256, 2)) % Math.pow(256, 1)) / Math.pow(256, 0));
}

return output;``````

}

ip2long

long2ip

2017-08-26 1 楼

var output = false;
var output = 0;
output = (parts[0] Math.pow(256, 3)) +
(parts[1]
Math.pow(256, 2)) +
(parts[2] Math.pow(256, 1)) +
(parts[3]
Math.pow(256, 0));
}
return output<<0;
}

var output = false;
output = Math.floor(proper_address / Math.pow(256, 3)) + '.' +
Math.floor((proper_address % Math.pow(256, 3)) / Math.pow(256, 2)) + '.' +
Math.floor(((proper_address % Math.pow ( 256, 3)) % Math.pow(256, 2)) / Math.pow(256, 1)) + '.' +
Math.floor((((proper_address % Math.pow ( 256, 3)) % Math.pow(256, 2)) % Math.pow(256, 1)) / Math.pow(256, 0));
}
return output;
}

1193 主题
2608 回复
15559 人气