获取客户端(前端)IP地址

1.主要使用场景

查看操作记录等

2.实现原理

在前端的 Vue.js 应用中,通常是无法直接获取到当前电脑的局域网 IP 地址的,因为浏览器限制了这类敏感信息的访问。局域网 IP 地址是客户端(浏览器)到服务器端(通常是后端)的连接信息,而不是直接从浏览器获取的。

一般情况下,你可能需要通过后端接口来获取客户端的 IP 地址。在 Vue.js 中,可以通过向后端发送请求来获取客户端的 IP 地址。后端可以通过读取请求的 IP 地址头部来获取客户端的真实 IP。

3.代码

3.1前端增加登录记录代码示例

向后端发送除IP外的其他需要记录的数据

复制代码
    //添加登陆记录
    insertLoginLog() {
      this.logForm.loginTime=this.getCurrentTime();
      this.logForm.empcode=this.loginForm.loginName
      console.log(this.logForm)
      insertLoginLog(this.logForm)
        .then((res) => {
          if (res.data.code === 200) {
            this.$message({
              message: "登录成功",
              type: "success",
            });
          } else {
            this.$message.error(res.data.message);
          }
        })
        .catch((err) => {
          this.$message.error("添加登录记录异常");
          console.log(err);
        });
    },
3.2后端增加登录记录示例

后端接收请求并获取请求发送的IP地址

复制代码
    /**
     * 新增登陆记录
     * @param
     * @return
     */
    @PostMapping("/api/user/insertLoginLog")
    public Result insertLoginLog(@RequestBody LoginNumber loginNumber,
                                 HttpServletRequest request,
                                 @RequestHeader(value = "X-Forwarded-For", required = false) String clientIp){
        if (clientIp == null) {
            clientIp = request.getRemoteAddr(); // 获取默认的客户端 IP 地址
        }
        loginNumber.setLoginIP(clientIp);
        return new Result(200,"",userService.insertLoginLog(loginNumber));
    }
相关推荐
以太浮标2 分钟前
华为eNSP综合实验之- 通过SSH远程登陆设备
服务器·网络·ssh
枷锁—sha1 小时前
【SRC】前后端分离与API接口渗透
服务器·网络·安全·网络安全·系统安全
Coisinilove1 小时前
数通第三次培训
网络·windows·数通数据通信
仙俊红1 小时前
我亲手抓到了自己的账号密码:一次完整的 HTTP 登录抓包实验
网络·网络协议·http
专业开发者1 小时前
Wi-Fi 技术学习:一文读懂WPA2四次握手的密钥体系与交互逻辑
网络·学习·macos
hans汉斯1 小时前
基于联邦学习的隐私保护和抗投毒攻击方法研究
网络·人工智能·算法·yolo·数据挖掘·聚类·汉斯出版社
德迅云安全杨德俊2 小时前
业务不中断、源站不暴露!DDOS高防 IP 抵御网络攻击
网络·安全·https·ddos
灰子学技术2 小时前
istio从0到1:如何解决同一个应用不同功能的路由聚合问题
运维·服务器·网络·云原生·istio
茶栀(*´I`*)2 小时前
【计算机网络】核心概念辨析:计算机网络、互连网与互联网,你分得清吗?
网络·计算机网络
科技块儿2 小时前
【工具对比】免费IP库用于广告投放是否可靠?误差率实测报告
网络·数据库·tcp/ip