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

小组事务管理 小组事务管理 主题:974 回复:1955

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

瑾兮 发布于 2017-08-04 字数 52 浏览 1226 回复 3

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

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

支持 Markdown 语法,需要帮助?

评论(3

甜柠檬 2017-10-05 3 楼

给个简洁的int2Ip
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;

if (!isNaN(proper_address) &amp;&amp; (proper_address &gt;= 0 || proper_address &lt;= 4294967295)) {
    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 楼

给两个个人认为比较简洁的方法:

function ip2long (ip_address) {
var output = false;
if (ip_address.match(/^d{1,3}.d{1,3}.d{1,3}.d{1,3}$/)) {
var parts = ip_address.split('.');
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;
}

function long2ip (proper_address) {
proper_address = proper_address>>>0;
var output = false;
if (!isNaN(proper_address) && (proper_address >= 0 || proper_address <= 4294967295)) {
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;
}