【php】获取服务器公网ip,内网ip「建议收藏」

【php】获取服务器公网ip,内网ip「建议收藏」<?php/***CreatedbyPhpStorm.*User:zhudechao*Date:2019/3/20*Time:下午5:27*/namespacezhdcp\ip;classIp{publicfunctionget_outer(){$ch=curl_init(‘http://…

大家好,又见面了,我是你们的朋友全栈君。

<?php
/**
 * Created by PhpStorm.
 * User: zhudechao
 * Date: 2019/3/20
 * Time: 下午5:27
 */

namespace zhdcp\ip;


class Ip
{
    public function get_outer()
    {
        $ch = curl_init('http://2019.ip138.com/ic.asp');
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
        $a  = curl_exec($ch);
        preg_match('/\[(.*)\]/', $a, $ip);
        print_r($ip[1]);
        die();
    }

    function get_inter()
    {
        $onlineip = '';
        if (getenv('HTTP_CLIENT_IP') && strcasecmp(getenv('HTTP_CLIENT_IP'), 'unknown')) {
            $onlineip = getenv('HTTP_CLIENT_IP');
        } elseif (getenv('HTTP_X_FORWARDED_FOR') && strcasecmp(getenv('HTTP_X_FORWARDED_FOR'), 'unknown')) {
            $onlineip = getenv('HTTP_X_FORWARDED_FOR');
        } elseif (getenv('REMOTE_ADDR') && strcasecmp(getenv('REMOTE_ADDR'), 'unknown')) {
            $onlineip = getenv('REMOTE_ADDR');
        } elseif (isset($_SERVER['REMOTE_ADDR']) && $_SERVER['REMOTE_ADDR'] && strcasecmp($_SERVER['REMOTE_ADDR'], 'unknown')) {
            $onlineip = $_SERVER['REMOTE_ADDR'];
        }
        return $onlineip;
    }

    public function get_client_ip()
    {
        if (getenv('HTTP_CLIENT_IP') && strcasecmp(getenv('HTTP_CLIENT_IP'), 'unknown')) {
            $ip = getenv('HTTP_CLIENT_IP');
        } elseif (getenv('HTTP_X_FORWARDED_FOR') && strcasecmp(getenv('HTTP_X_FORWARDED_FOR'), 'unknown')) {
            $ip = getenv('HTTP_X_FORWARDED_FOR');
        } elseif (getenv('REMOTE_ADDR') && strcasecmp(getenv('REMOTE_ADDR'), 'unknown')) {
            $ip = getenv('REMOTE_ADDR');
        } elseif (isset($_SERVER['REMOTE_ADDR']) && $_SERVER['REMOTE_ADDR'] && strcasecmp($_SERVER['REMOTE_ADDR'], 'unknown')) {
            $ip = $_SERVER['REMOTE_ADDR'];
        }
        return preg_match('/[\d\.]{7,15}/', $ip, $matches) ? $matches [0] : '';
    }
}

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/146086.html原文链接:https://javaforall.net

(0)
上一篇 2022年5月15日 下午9:00
下一篇 2022年5月15日 下午9:20


相关推荐

  • 最短路径dijkstra算法精品代码(超详解)

    最短路径dijkstra算法精品代码(超详解)一:简介  这个算法用于解决图中单源最短路径问题。所谓单源节点是指给定源节点,求图中其它节点到此源节点的最短路径。如下图所示:给定源节点a,求节点b到a的最短距离。(图来自于参考资料2)那么如何寻找?还是以上图为例:1)初始化:设定除源节点以外的其它所有节点到源节点的距离为INFINITE(一个很大的数),且这些节点都没被处理过。…

    2022年5月18日
    39
  • 排序算法之 二分法排序

    排序算法之 二分法排序之所以单独来二分法排序 是因为近些天一直在做二分法查找的问题 延伸只二分法排序 做此记录 以便于以后记忆 首先了解下二分法的思想 对于区间 a b 上连续不断且 f a f b lt 0 的函数 y f x 通过不断地把函数 f x 的零点所在的区间一分为二 使区间的两个端点逐步逼近零点 进而得到零点近似值的方法叫二分法 个人理解二分法排序就是利用二分法查找结合插入

    2026年3月16日
    2
  • 八、JDK1.8中HashMap扩容机制

    八、JDK1.8中HashMap扩容机制导读前面文章一、深入理解-Java集合初篇中我们对Java的集合体系进行一个简单的分析介绍,上两篇文章二、Jdk1.7和1.8中HashMap数据结构及源码分析、三、JDK1.7和1.8HashMap数据结构及源码分析-续中我们分别对JDK1.7和JDK1.8中HashMap的数据结构、主要声明变量、构造函数、HashMap的put操作方法做了深入的讲解和源码分析。四、深入理解Java中的HashMap「网易面试快答」文章中主要针对面试中常见的面试问题进行简单解答。五、深入理解JDK1.7中H

    2022年6月16日
    24
  • Python爬虫01——第一个小爬虫

    Python爬虫01——第一个小爬虫第一个python小程序,贴吧图片的爬取

    2022年7月3日
    19
  • js在数组指定位置添加元素_java数组删除指定位置元素

    js在数组指定位置添加元素_java数组删除指定位置元素原文链接:Array:InsertanItemataSpecificIndexwithJavaScript原文日期:2014年07月24日翻译日期:2014年07月26日翻译人员:铁锚很多与数组有关的任务听起来很简单,但实际情况并不总是如此,而开发人员在很多时候也用不到他。最近我碰到了这样一个需求:将一个元素插入到现有数组的特定索引处。听起来很容易和常见,但需要一点时间

    2022年8月11日
    7
  • java jmap 分析_Jmap 分析

    java jmap 分析_Jmap 分析1 命令基本概述 Jmap 是一个可以输出所有内存中对象的工具 甚至可以将 VM 中的 heap 以二进制输出成文本 打印出某个 java 进程 使用 pid 内存内的 所有 对象 的情况 如 产生那些对象 及其数量 使用方法 jmap histopid 如果使用 SHELL 可采用 jmap histopid gt a log 日志将其保存到文件中 在一段时间后 使用文本对比工具 可以对比出 GC 回收了哪

    2026年3月19日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号