php 获取本机外网/公网IP的代码
一般都是用 $_SERVER['REMOTE_ADDR'] 获取用户IP,
但如果使用了反向代理的,HTTP头中 REMOTE_ADDR 就不是用户的地址,反而是上一级代理的地址了。
获取用户的真实外网IP
1 2 3 4 5 6 7 8 9 10 11 12 13 | function getRealIp() { $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; } |
赶紧试一下吧 ~
备注:
getenv(string varname) ,函数定义:获取系统的环境变量,根据提供不同的参数可以获取不同的环境变量。
具体参数: “PHP_SELF” 当前正在执行脚本的文件名,与document root 相关。如果 PHP 以命令行方式运行,该变量在PHP 4.3.0 之前无效。 “argv” 传递给该脚本的参数。当脚本运行在命令行方式时,argv 变量传递给程序C 语言样式的命令行参数。当调用GET 方法时,该变量包含请求的数据。 “argc” 包含传递给程序的命令行参数的个数(如果运行在命令行模式)。 “GATEWAY_INTERFACE” 服务器使用的CGI 规范的版本。例如,“CGI/1.1”。 “SERVER_NAME” 当前运行脚本所在服务器主机的名称。如果该脚本运行在一个虚拟主机上,该名称是由那个虚拟主机所设置的值决定。 “SERVER_SOFTWARE” 服务器标识的字串,在响应请求时的头信息中给出。 “SERVER_PROTOCOL” 请求页面时通信协议的名称和版本。例如,“HTTP/1.0”。 “REQUEST_METHOD” 访问页面时的请求方法。例如:“GET”、“HEAD”,“POST”,“PUT”。 注: 如果请求的方式是HEAD,PHP 脚本将在送出头信息后中止(这意味着在产生任何输出后,不再有输出缓冲)。 “REQUEST_TIME” 请求开始时的时间戳。从PHP 5.1.0 起有效。 “QUERY_STRING” 查询(query)的字符串(URL 中第一个问号? 之后的内容)。 “DOCUMENT_ROOT” 当前运行脚本所在的文档根目录。在服务器配置文件中定义。 “HTTP_ACCEPT” 当前请求的Accept: 头信息的内容。 “HTTP_ACCEPT_CHARSET” 当前请求的Accept-Charset: 头信息的内容。例如:“iso-8859-1,*,utf-8”。 “HTTP_ACCEPT_ENCODING” 当前请求的Accept-Encoding: 头信息的内容。例如:“gzip”。 “HTTP_ACCEPT_LANGUAGE” 当前请求的Accept-Language: 头信息的内容。例如:“en”。 “HTTP_CONNECTION” 当前请求的Connection: 头信息的内容。例如:“Keep-Alive”。 “HTTP_HOST” 当前请求的Host: 头信息的内容。 “HTTP_REFERER” 链接到当前页面的前一页面的URL 地址。不是所有的用户代理(浏览器)都会设置这个变量,而且有的还可以手工修改HTTP_REFERER。因此,这个变量不总是真实正确的。 “HTTP_USER_AGENT” 当前请求的User-Agent: 头信息的内容。该字符串表明了访问该页面的用户代理的信息。
一个典型的例子是:Mozilla/4.5 [en] (X11; U; Linux 2.2.9 i586)。也可以使用get_browser() 得到此信息。 “HTTPS” 如果脚本是通过HTTPS 协议被访问,则被设为一个非空的值。 “REMOTE_ADDR” 正在浏览当前页面用户的IP 地址。 “REMOTE_HOST” 正在浏览当前页面用户的主机名。反向域名解析基于该用户的REMOTE_ADDR。
注: 必须配置Web 服务器来建立此变量。例如Apache 需要在httpd.conf 中有HostnameLookups On。参见gethostbyaddr()。 “REMOTE_PORT” 用户连接到服务器时所使用的端口。 “SCRIPT_FILENAME” 当前执行脚本的绝对路径名。 注: 如果脚本在CLI 中被执行,作为相对路径,例如file.php 或../file.php,$_SERVER[‘SCRIPT_FILENAME’] 将包含用户指定的相对路径。 “SERVER_ADMIN” 该值指明了Apache 服务器配置文件中的SERVER_ADMIN 参数。如果脚本运行在一个虚拟主机上,则该值是那个虚拟主机的值。 “SERVER_PORT” 服务器所使用的端口。默认为“80”。如果使用SSL 安全连接,则这个值为用户设置的HTTP 端口。 “SERVER_SIGNATURE” 包含服务器版本和虚拟主机名的字符串。 “PATH_TRANSLATED” 当前脚本所在文件系统(不是文档根目录)的基本路径。这是在服务器进行虚拟到真实路径的映像后的结果。 注: PHP 4.3.2 之后,PATH_TRANSLATED 在Apache 2 SAPI 模式下不再和 Apache1 一样隐含赋值,而是若 Apache 不生成此值,PHP 便自己生成并将其值放入SCRIPT_FILENAME 服务器常量中。
这个修改遵守了CGI 规范,PATH_TRANSLATED 仅在PATH_INFO 被定义的条件下才存在。 Apache 2 用户可以使用httpd.conf 中的AcceptPathInfo On 来定义PATH_INFO。 “SCRIPT_NAME” 包含当前脚本的路径。这在页面需要指向自己时非常有用。FILE 包含当前文件的绝对路径和文件名(例如包含文件)。 “REQUEST_URI” 访问此页面所需的URI。例如,“/index.html”。 “PHP_AUTH_DIGEST” 当作为Apache 模块运行时,进行HTTP Digest 认证的过程中,此变量被设置成客户端发送的“Authorization”HTTP 头内容(以便作进一步的认证操作)。 “PHP_AUTH_USER” 当PHP 运行在Apache 或IIS(PHP 5 是ISAPI)模块方式下,并且正在使用HTTP 认证功能,这个变量便是用户输入的用户名。 “PHP_AUTH_PW” 当PHP 运行在Apache 或IIS(PHP 5 是ISAPI)模块方式下,并且正在使用HTTP 认证功能,这个变量便是用户输入的密码。 HTTP_CLIENT_IP 取得用户的IP代码;
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 25岁的心里话
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
2020-11-18 时间计算
2020-11-18 MySQL索引