0

0

如何在网站上显示用户上次访问的城市和国家

心靈之曲

心靈之曲

发布时间:2026-02-01 20:51:10

|

879人浏览过

|

来源于php中文网

原创

如何在网站上显示用户上次访问的城市和国家

通过前端获取地理位置并结合后端存储,实现“上次访问来自xx城市,xx国家”的动态提示功能。需借助ip定位服务、服务器端持久化及前端展示逻辑。

要在网页右下角(或其他位置)显示类似 “Last visit from Tokyo, Japan” 的提示,仅靠纯前端 JavaScript(如 navigator.geolocation.getCurrentPosition())是无法实现的——因为该 API 仅能获取当前会话的精确地理位置,且需用户授权、不适用于无 GPS 的桌面环境,更无法追溯“上次访问”信息。

真正的解决方案依赖前后端协同

PHP168  行业B2B
PHP168 行业B2B

解决问题如下:只列举最近用户提交问题,其余问题前面几次补丁已经解决,不在复述。1、解决搜索问题。以前搜索一定要确定到省下面的某个市,这个不符合用户体验。 现在改为,省--所有城市(默认为所有城市,也可以自己选择某个市)。2、解决首页推荐产品部显示问题。(以前没有考虑多个其他浏览器)3、解决供应、求购 今日产品显示问题。(理由同上)4、解决收藏商家、供应、求购问题。 (链接错误)5、解决后台分类过

下载

✅ 核心逻辑流程

  1. 每次用户访问页面时,前端向你的后端发起请求(如 /api/track-visit);
  2. 后端通过请求的 IP 地址调用第三方 IP 归属地服务(如 ipapi.coipgeolocation.ioMaxMind GeoLite2),解析出 city 和 country_name;
  3. 后端将该地理位置信息连同时间戳存入数据库(如 Redis 快速缓存或 PostgreSQL 持久表),并更新为该用户的“最新访问记录”;
  4. 前端在页面加载时,再发起一次轻量请求(如 /api/last-visit)获取已存储的上一次有效位置,并渲染到 DOM 中。

? 示例:简易后端(Node.js + Express)

// server.js(需安装 axios)
app.get('/api/last-visit', (req, res) => {
  // 假设使用 Redis 存储:key = 'last_visit:123.45.67.89'
  const ip = req.ip || req.connection.remoteAddress;
  redis.get(`last_visit:${ip}`, (err, data) => {
    if (data) {
      res.json(JSON.parse(data)); // { city: "Berlin", country: "Germany", timestamp: "2024-05-20T14:22:00Z" }
    } else {
      res.json({ city: "Unknown", country: "Unknown" });
    }
  });
});

app.get('/api/track-visit', async (req, res) => {
  const ip = req.ip || req.connection.remoteAddress;
  try {
    const geoRes = await axios.get(`https://www.php.cn/link/8e9368bb8083221506d9b1c83c5c7d95${ip}/json/`, {
      headers: { 'User-Agent': 'YourSite/1.0' }
    });
    const { city, country_name } = geoRes.data;
    const record = { city, country: country_name, timestamp: new Date().toISOString() };
    redis.setex(`last_visit:${ip}`, 60 * 60 * 24 * 7, JSON.stringify(record)); // 缓存7天
    res.json(record);
  } catch (e) {
    res.json({ city: "Unknown", country: "Unknown" });
  }
});

?️ 前端展示(HTML + JS)

Last visit from ,
// 在页面加载完成后执行
async function loadLastVisit() {
  try {
    const res = await fetch('/api/last-visit');
    const data = await res.json();
    document.getElementById('lv-city').textContent = data.city || '—';
    document.getElementById('lv-country').textContent = data.country || '—';
  } catch (e) {
    console.warn('Failed to load last visit info', e);
  }
}
loadLastVisit();

// 可选:每次页面可见时刷新追踪(提升准确性)
document.addEventListener('visibilitychange', () => {
  if (!document.hidden) fetch('/api/track-visit').catch(() => {});
});

⚠️ 注意事项

  • 隐私合规:根据 GDPR / CCPA,需在使用 IP 定位前明确告知用户并获得同意(可在 Cookie Banner 中说明);
  • IP 精度限制:IP 定位通常精确到城市级,无法替代 GPS,且企业网络、代理、CDN 可能返回网关位置;
  • 免费额度:如使用 ipapi.co 免费版(1000 次/日),注意请求频控;生产环境建议搭配缓存(Redis)降低调用次数;
  • 不要依赖 navigator.geolocation 实现“上次访问”:它只提供本次实时位置,且拒绝率高、移动端体验差。

通过这一架构,你就能像 rauno.me 那样,在页面角落优雅呈现带有地理语义的访问记忆——既专业,又尊重用户数据边界。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
cookie
cookie

Cookie 是一种在用户计算机上存储小型文本文件的技术,用于在用户与网站进行交互时收集和存储有关用户的信息。当用户访问一个网站时,网站会将一个包含特定信息的 Cookie 文件发送到用户的浏览器,浏览器会将该 Cookie 存储在用户的计算机上。之后,当用户再次访问该网站时,浏览器会向服务器发送 Cookie,服务器可以根据 Cookie 中的信息来识别用户、跟踪用户行为等。

6432

2023.06.30

document.cookie获取不到怎么解决
document.cookie获取不到怎么解决

document.cookie获取不到的解决办法:1、浏览器的隐私设置;2、Same-origin policy;3、HTTPOnly Cookie;4、JavaScript代码错误;5、Cookie不存在或过期等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

349

2023.11.23

阻止所有cookie什么意思
阻止所有cookie什么意思

阻止所有cookie意味着在浏览器中禁止接受和存储网站发送的cookie。阻止所有cookie可能会影响许多网站的使用体验,因为许多网站使用cookie来提供个性化服务、存储用户信息或跟踪用户行为。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

415

2024.02.23

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

95

2025.08.19

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

516

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

246

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

361

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

5358

2023.08.17

go语言 注释编码
go语言 注释编码

本专题整合了go语言注释、注释规范等等内容,阅读专题下面的文章了解更多详细内容。

30

2026.01.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

相关下载

更多

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4.5万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.6万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号