帝国cms会员空间模板显示最近来访访客信息

news/2025/7/9 10:44:20/文章来源:https://www.cnblogs.com/hwrex/p/18447887

为了实现用户登录状态下的信息记录以及未登录状态下的IP地区记录功能,你可以按照以下步骤操作:

第一步:创建数据表

在帝国CMS后台执行以下SQL语句创建数据表:

CREATE TABLE `{$dbtbpre}_userkjf` (`id` int(11) NOT NULL AUTO_INCREMENT,`lfuserid` varchar(20) CHARACTER SET gbk DEFAULT NULL,`bfuserid` varchar(100) CHARACTER SET gbk NOT NULL,`ip` char(50) CHARACTER SET gbk DEFAULT NULL,`ipdl` char(50) CHARACTER SET gbk DEFAULT NULL,`lftime` char(20) CHARACTER SET gbk NOT NULL,PRIMARY KEY (`id`),UNIQUE KEY `id` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=65 DEFAULT CHARSET=latin1 AUTO_INCREMENT=65;

第二步:复制代码到 header.temp.php

将以下代码复制到 e/space/template/default/header.temp.php 文件中:

<?php
// 取得登陆者信息
$userid = getcvar('mluserid');    // 会员ID
$uid = $_GET['userid']; // 当前空间的主人IDif ($uid != $userid) {// 如果访客已登陆,则记录访客信息if ($userid) {$lfUname = $_COOKIE["lfUname"]; // 获取访客信息$fkdd = $empire->fetch1("SELECT * FROM {$dbtbpre}userkjf WHERE bfuserid='{$uid}' AND lfuserid='{$userid}'");if (!$fkdd) {$empire->query("INSERT INTO {$dbtbpre}userkjf (lfuserid, bfuserid, lftime) VALUES ('{$userid}', '{$uid}', '".date('Y-m-d H:i:s')."')");}} else { // 如果访客未登陆,则记录IP和地区信息// 取得IP 和地区$gifo = new get_gust_info();$ip = $gifo->Getip();$ipadds = $gifo->Getaddress();$ipdl = '';foreach ($ipadds[0] as $value) {$ipdl .= iconv("utf-8", "gbk", $value);}// 获取访客信息$lfUname = $_COOKIE["lfUname"];if ($lfUname == '') {$empire->query("INSERT INTO {$dbtbpre}userkjf (bfuserid, ip, ipdl, lftime) VALUES ('{$uid}', '{$ip}', '{$ipdl}', '".date('Y-m-d H:i:s')."')");setcookie("lfUname", "游客", time() + 1200); // 创建来访客信息,20分钟过期}}
}
?><?php
// 作用取得客户端的ip、地理信息、浏览器、本地真实IP
class get_gust_info {// 获得访客真实ipfunction Getip() {if (!empty($_SERVER["HTTP_CLIENT_IP"])) {$ip = $_SERVER["HTTP_CLIENT_IP"];}if (!empty($_SERVER['HTTP_X_FORWARDED_FOR'])) { // 获取代理ip$ips = explode(',', $_SERVER['HTTP_X_FORWARDED_FOR']);}if ($ip) {array_unshift($ips, $ip);}$count = count($ips);for ($i = 0; $i < $count; $i++) {if (!preg_match("/^(10|172.16|192.168)./i", $ips[$i])) { // 排除局域网ip$ip = $ips[$i];break;}}$tip = empty($_SERVER['REMOTE_ADDR']) ? $ip : $_SERVER['REMOTE_ADDR'];if ($tip == "127.0.0.1") { // 获得本地真实IPreturn $this->get_onlineip();} else {return $tip;}}// 获得本地真实IPfunction get_onlineip() {$mip = file_get_contents("http://city.ip138.com/city0.asp");if ($mip) {preg_match("/[.*]/", $mip, $sip);$p = array("/[/", "/]/");return preg_replace($p, "", $sip[0]);} else {return "获取本地IP失败!";}}// 根据ip获得访客所在地地名function Getaddress($ip = '') {if (empty($ip)) {$ip = $this->Getip();}$ipadd = file_get_contents("http://int.dpool.sina.com.cn/iplookup/iplookup.php?ip=" . $ip); // 根据新浪api接口获取if ($ipadd) {$charset = iconv("gbk", "utf-8", $ipadd);preg_match_all("/[\x{4e00}-\x{9fa5}]+/u", $charset, $ipadds);return $ipadds; // 返回一个二维数组} else {return "地址未知";}}
}
?><?php
// 会员空间访客显示开始
$fkSQL = "SELECT * FROM {$dbtbpre}userkjf WHERE bfuserid='{$uid}' ORDER BY id DESC LIMIT 5";
$fkSQL = $empire->query($fkSQL);while ($rs = $empire->fetch($fkSQL)) {if ($rs['lfuserid']) {$fkxxrs = $empire->fetch1("SELECT userid, truename, userpic FROM {$dbtbpre}enewsmemberadd WHERE userid='{$rs['lfuserid']}' LIMIT 1");?><li><a href="/e/space/index.php?userid=<?=$fkxxrs['userid']?>"><img src="<?=$fkxxrs['userpic'] ? $fkxxrs['userpic'] : '/templets/member/common/images/dfboy.png'?>" alt="<?=$fkxxrs['truename']?>" /></a><a href="/e/space/index.php?userid=<?=$fkxxrs['userid']?>"><?=$fkxxrs['truename']?></a></li><?php} else {?><li><a href="#"><img src="../data/images/nouserpic.gif" /></a><span><div><?= $rs['ipdl'] ? "来自: " . $rs['ipdl'] : "未知地区" ?></div><br><div><?= $rs['lftime'] ?></div></span></li><?php}
}
// 会员空间访客显示结束
?>

注意事项

  1. 表前缀:确保在创建数据表时使用正确的表前缀({$dbtbpre})。
  2. 字符集转换:确保在处理中文数据时使用正确的字符集转换。
  3. API接口:确保使用的IP地址解析API接口有效且能正常访问。
  4. 安全性和隐私:确保在记录用户信息时遵守相关法律法规,并保护用户隐私。

通过以上步骤,你应该能够实现用户登录状态下的信息记录以及未登录状态下的IP地区记录功能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/808500.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

电影《志愿军存亡之战》百度云下载/迅雷磁力下载高清版4K资源8.26GB

电影《志愿军:存亡之战》观后感电影《志愿军:存亡之战》是由陈凯歌执导,张珂编剧,汇聚了朱一龙、张子枫、辛柏青、吴京等众多实力派演员的战争历史剧情片。该片作为《志愿军》系列影片的第二部,于2024年9月30日在中国大陆上映,讲述了抗美援朝战争中第三次战役到第五次战役…

【VMware VCF】使用 PowerVCF 连接和管理 VMware Cloud Foundation 环境。

VMware 有一个非常强大的命令行工具叫 PowerCLI,该工具是基于 PowerShell 开发的模块,主要用于在 Windows 环境中连接和管理传统虚拟化解决方案,比如 vSphere、vSAN 以及 NSX 等。之所以 PowerCLI 非常强大,是因为它几乎可以实现这些解决方案 WEB UI 中的所有管理操作,甚至…

[论文阅读报告] All pairs shortest paths using bridging sets and rectangular matrix multiplication, FOCS 98

$\tilde O(Mn^{\omega(r)})$ 的整数 $(\min, +)$ 矩阵乘,$\tilde O(n^{2.528})$ 的有向图 $\{-1, 0, 1\}$ 边权 APSP 以及 $\tilde O(n^{\omega(r)}\log W / \epsilon)$ 的 $(1 + \epsilon)$ 近似非负实数 $(\min, +)$ 矩阵乘,其中 $W$ 为最大权值和最小权值的比。本篇文章介…

OI for people in 3000 B.C.

大家好,我是 M 先生 受 B 先生之委托,为了给大家最真实的原始人体验,现特将 HZOI 版本回溯至 3000 B.C.,在这个版本中,我们做了如下改动:鉴于大家能够说话,我们特地友善地给予了大家充足的讨论时间,而删去 3000 B.C. 时大家还没有进化出来的远程交流功能 鉴于远古时期纸…

帝国cms搜索页模板关键字结果标题加红的方法

要在帝国CMS的搜索结果页面上实现关键词高亮显示的功能,可以按照以下步骤操作:备份原有模板文件: 在修改任何模板文件之前,请确保备份原有的模板文件,以防修改出错时能够恢复。定位到模板编辑器:登录帝国CMS后台。 导航至“模板”->“模板列表”。 找到需要修改的搜索…

Arduino Nano 和 DHT11 实现 LabVIEW 温湿度采集

Arduino Nano 和 DHT11 实现 LabVIEW 温湿度采集Arduino Nano 和 DHT11 实现 LabVIEW 温湿度采集 Arduino IDE 安装如下库文件 DHT sensor library by AdafruitDHT11 温湿度传感器 Data 引脚与 Arduino Nano 开发板的 D2 引脚连接 代码 #include <DHT.h>#define Temperat…

国庆集训1

省流:亏死(bool 没有返回值 100,数组开小 100->30) 具体情况: T1:数组开小,应该开 1e6,导致质数筛少了。 T2:老师说要开 long long,但我好像也开 long long 了,为什么爆了??? T3:知道思路,然后想了一下,发现不太会。就写了 2 个线段树维护了一下奇数、偶数…