2020-10-28
php和js实现根据子网掩码和ip计算子网功能示例

php和js实现根据子网掩码和ip计算子网功能示例

本文实例讲述了php和js实现根据子网掩码和ip计算子网功能。分享给大家供大家参考,具体如下: php <?php $ip = '192.168.6.1'; $mask = '255.255.2.0'; $sub_net = array();//子网 $ip_explode = explode('.', $ip); $mask_explode = explode('.', $mask); foreach ($ip_explode as $key => $ip_num) { $sub_net[] = (int)$ip_num & (int)$mask_explode[$key]; } $sub_net = implode('.', $sub_net); echo $sub_net; 运行结果: 192.168.2.0 js <script> var ip = '192.168.6.1'; var mask = '255.255.255.0'; var sub_net = [];//子网 var ip_explode = ip.split('.'); var mask_explode = mask.split('.'); console.log('ip_explode='+ip_explode); console.log('mask_explode='+mask_explode); for (var i = 0, num = ip_explode.length; i < num; i++) { c = parseInt(ip_explode[i]) & parseInt(mask_explode[i]); console.log('c='+c); sub_net.push(c); } sub_net = sub_net.join('.'); console.log(sub_net); </script> 运行结果: 感兴趣的朋友可以使用在线HTML/CSS/JavaScript前端代码调试运行工具:http://tools.jb51.net/code/WebCodeRun测试上述代码运行效果。 PS:这里再为大家推荐几款计算工具供大家进一步参考借鉴: 在线一元函数(方程)求解计算工具: http://tools.jb51.net/jisuanqi/equ_jisuanqi 科学计算器在线使用_高级计算器在线计算: http://tools.jb51.net/jisuanqi/jsqkexue 在线计算器_标准计算器: http://tools.jb51.net/jisuanqi/jsq 更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP数学运算技巧总结》、《PHP运算与运算符用法总结》、《php字符串(string)用法总结》、《PHP数组(Array)操作技巧大全》、《PHP数据结构与算法教程》、《php程序设计算法总结》及《php正则表达式用法总结》 希望本文所述对大家PHP程序设计有所帮助。...
技术教程 710次浏览 0条评论
2020-10-28
通过PHP实现获取访问用户IP

通过PHP实现获取访问用户IP

在php中自带了一个非常的简单的获取IP地址的全局变量,很多初学都获取IP都使用它了,但是对于这些我们一般用法是满足了,但是对于要求高精度这个函数还是不行的。 这个是最简单的方法,对于开了透明代理之类的是没有办法的,如果内网访问也不能读取正确的外网IP,不过很省力就是了: $ip = $_SERVER["REMOTE_ADDR"]; 搞定~ 上面方法用来取得客户端的 IP 地址,但如果客户端是使用代理服务器来访问,那取到的就是代理服务器的 IP 地址,而不是真正的客户端 IP 地址 要想透过代理服务器取得客户端的真实 IP 地址,就要使用 getenv("HTTP_X_FORWARDED_FOR") 来读取。 但是如果客户端没有通过代理服务器来访问,那么用getenv("HTTP_X_FORWARDED_FOR") 取到的值将是空的。 else if(getenv("HTTP_X_FORWARDED_FOR")) $ip = getenv("HTTP_X_FORWARDED_FOR"); 表示如果getenv("HTTP_X_FORWARDED_FOR") 取到的值存在不为空(即客户端使用代理服务器的情况下),则变量$ip等于getenv("HTTP_X_FORWARDED_FOR") 取到的真实IP值。 如果上面的else if(getenv("HTTP_X_FORWARDED_FOR"))取得的值为空(即没有使用代理服务器),则不会执行下面的$ip = getenv("HTTP_X_FORWARDED_FOR");这一行语句。 这种情况下已经确认客户端没有使用代理服务器,从而通过 else if(getenv("REMOTE_ADDR")) $ip = getenv("REMOTE_ADDR"); 这两行语句获得客户端的IP地址也是真实的IP地址,根据经验得出 function getIP() { static $realip; if (isset($_SERVER)){ if (isset($_SERVER["HTTP_X_FORWARDED_FOR"])){ $realip = $_SERVER["HTTP_X_FORWARDED_FOR"]; } else if (isset($_SERVER["HTTP_CLIENT_IP"])) { $realip = $_SERVER["HTTP_CLIENT_IP"]; } else { $realip = $_SERVER["REMOTE_ADDR"]; } } else { if (getenv("HTTP_X_FORWARDED_FOR")){ $realip = getenv("HTTP_X_FORWARDED_FOR"); } else if (getenv("HTTP_CLIENT_IP")) { $realip = getenv("HTTP_CLIENT_IP"); } else { $realip = getenv("REMOTE_ADDR"); } } return $realip; } 另外如果我们想获取更精准的使用第三方是一个不错的方法哦 function get_onlineip() { $ch = curl_init('http://www.ip138.com/ip2city.asp'); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); $a = curl_exec($ch); preg_match('/[(.*)]/', $a, $ip); return $ip[1]; } 这样不管理代理还是什么都可以判断IP地址哦 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持梦主博客。...
技术教程 640次浏览 0条评论
微信二维码