Remix 中这样获取 ip 地址

一、Remix 请求对象与 express request 不一样

Remix 遵循 Web 标准的 request和 response,而 Express 没有遵循。

Remix request 对象中并没有包含 ip 地址,但是社区中已经有了 ip 地址的获取方法。但是值得注意的是 remix 服务的 ip 地址是随 headers 一起。

本地开发的时候,headers 上是没有携带 ip 的 header,所以我们不能获取。

二、remix-utils

2.1)安装 remix- utils

sh 复制代码
pnpm add remix-utils

2.2)使用

ts 复制代码
import { getClientIPAddress } from 'remix-utils/get-client-ip-address'

三、以 nginx 为例

3.1)拥有一台服务器

最好有一台测试服务器,用于简单的测试。

3.2)nginx 相关命令

sh 复制代码
yum install nginx # 安装
sudo systemctl restart nginx # 重启

vim /etc/nginx/nginx.conf # 进入配置文件

3.3)打开服务器防火墙端口 5173,用于跑测试服务。

使用云服务器在后台配置以下即可。

3.4)写一个 nginx 简单的配置

sh 复制代码
server {
    listen 5173; # 监听的端口

    location / {
        proxy_pass http://127.0.0.1:5174; # 转发到本地的 5173 端口
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
    }
}

我们监听 5173 端口,代理到本地的 5174 端口,这意味着我们的 remix 服务要启动到 5174 端口。

sh 复制代码
# 使用脚手架创建一个 remix 应用
npx create-remix@latest

接下来在 root.tsx 中添加 loader 看 ip 能够正常

ts 复制代码
import { getClientIPAddress } from "remix-utils/get-client-ip-address";

export async function loader({ request }: LoaderArgs) {
        let ipAddress = getClientIPAddress(request.headers);
        console.log("ipAddress", ipAddress)
        return null
}

指定端口启动:

sh 复制代码
pnpm run build # 在服务端构建
PORT=5174 pnpm run start --host # 指定端口和 host 显示 

四、访问

经过实际云服务检测,通过 nginx 是能够拿到 ip 地址的。所以在开发环境返回的 null 也是正常。

五、小结

在开发的时候,remix 框架可能会带来一些疑惑,我们可以在配合云服务器,迅速的测试我们的示例。希望能够帮助到读者朋友。

相关推荐
L0CK几秒前
高级篇 05. 多级缓存 - JVM 进程缓存之实现业务缓存
后端
深念Y几秒前
Chrome MCP Server 配置失败全记录:一场历时数小时的“fetch failed”排查之旅
前端·自动化测试·chrome·http·ai·agent·mcp
Oneslide1 分钟前
基于Nginx实现目录列表展示与文件下载服务(K8s ConfigMap配置版)
后端
Java编程爱好者2 分钟前
对于java工程师(高级)的面试如果只考3道题,就能看出他的真实水平
后端
一个有故事的男同学2 分钟前
从零打造专业级前端 SDK (四):错误监控与生产发布
前端
2601_948606183 分钟前
从 jQuery → V/R → Lit:前端架构的 15 年轮回
前端·架构·jquery
PFinal社区_南丞3 分钟前
Go-1.26-五年最差版本-Bug 深度分析
后端
wuhen_n9 分钟前
Vite 核心原理:ESM 带来的开发时“瞬移”体验
前端·javascript·vue.js
nibabaoo10 分钟前
前端开发攻略---vue3长列表性能优化终极指南:虚拟滚动、分页加载、时间分片等6种方案详解与代码实现
前端·javascript·vue.js·虚拟滚动·分页加载·长列表·时间分片
三水不滴11 分钟前
Elasticsearch 实战系列(一):从核心基础概念入门到实战落地
后端·elasticsearch