nuxt服务器端渲染请求接口获取用户真实ip对应国家

nuxt服务器端渲染请求接口获取用户真实ip对应国家

一、目的

通过用户接口获取其真实的ip地址,最终获取到用户所在国家。

针对情况包括: 1、ssr node端请求后端接口 获取ip

2、客户端请求后端接口 获取ip

二、问题

目前通过接口获取不到外网ip而是内网ip

原因:

  • 接口是nuxt的ssr服务器端渲染接口,而非普通客户端请求接口(原理为从node服务器端,发起的请求,其ip必定为咱们服务器的内网ip地址)

三、方案

主要是依赖于nginx,获取其真实ip

1、nginx 转发到node服务的location中, header里面设置 x-real-ip 为 $remote_addrX-Forwarded-For 设为 $proxy_add_x_forwarded_for;

location / {                                                                                               
                 proxy_pass   http://10.10.50.191:88;                                                      
                proxy_set_header Host  $host;
                # need set x-real-ip and x-forwarded-for to get user ip 
                proxy_set_header X-Real-Ip $remote_addr;
                 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}

  # nginx代理接口
  location ^~ /baseUrl/ {                                                                                                                                                 
      proxy_pass   http://域名:19000/;                                                                                                                          
      proxy_cookie_path /baseUrl/ /;                                                                                                                                     
      proxy_pass_header Set-Cookie;             
      proxy_set_header Host  $host;
      proxy_set_header X-Real-Ip $remote_addr;
      proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  }

2、前端 从 服务器端渲染代码处, async nuxtServerInit (或者async asyncData) 里面获取 req

image-20210823142311073

3、req里面会有 nginx设置进去的header,x-real-ip x-forwarded-for,值为ip地址

4、把它重新设置到axios的header中

image-20210823142322254

5、后端从接口header里面就可以拿到一开始设置的remote_addr了

image-20210823142452628

以上方案针对于 服务器渲染请求的接口,后端从接口中获取其用户的真实ip的情况。主要是依赖前端(req中获取header,重新设入)、nginx、后端配合实现。

对于普通的客户端请求接口,后端从接口中获取其用户的真实ip的情况,也是同样适用。主要是依赖nginx的代理转发,设置header,后端直接获取就可以实现。

获取ip对应的国家(后端逻辑)

后端有ip数据表,里面有很多国家的ip地址,通过查表来获取对应国家简码,如US、CN

ssr服务端接口请求获取国家(通过ip)整个逻辑

image-20210902163258010

客户端请求获取国家整个逻辑

image-20210902163624779

参考代码

nginx配置

user  nginx;
worker_processes  1;

error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;


events {
 worker_connections  1024;
}


http {
 include       /etc/nginx/mime.types;
 default_type  application/octet-stream;

 log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
 '$status $body_bytes_sent "$http_referer" '
 '"$http_user_agent" "$http_x_forwarded_for" - $http_x_real_ip - $proxy_add_x_forwarded_for';

 access_log  /var/log/nginx/access.log  main;

 client_max_body_size   200m;

 sendfile        on;
 #tcp_nopush     on;

 keepalive_timeout  65;

 #gzip  on;

 server {
 listen      80;
 server_name  localhost;

 #charset koi8-r;

 #access_log  logs/host.access.log  main;

 # nginx转发到node
 location / {
 proxy_pass   http://10.10.50.97:88;
 proxy_set_header Host  $host;
 # need set x-real-ip and x-forwarded-for to get user ip 
 proxy_set_header X-Real-Ip $remote_addr;
 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

 }

 #error_page  404              /404.html;

 # redirect server error pages to the static page /50x.html
 #
 error_page   500 502 503 504  /50x.html;
 location = /50x.html {
 root   html;
 }

 # nginx代理接口
 location ^~ /baseUrl/ { 
 proxy_pass   http://域名:19000/;
 proxy_cookie_path /baseUrl/ /; 
 proxy_pass_header Set-Cookie; 
 proxy_set_header Host  $host;
 proxy_set_header X-Real-Ip $remote_addr;
 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
 }
 }

 include /etc/nginx/conf.d/*.conf;
}

java

public final class NetUtils {
 private NetUtils() {
 }

 public static String getRealIp(HttpServletRequest request) {
 String ip = request.getHeader("x-forwarded-for");
 if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
 ip = request.getHeader("X-Real-IP");
 }

 if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
 ip = request.getHeader("Proxy-Client-IP");
 }

 if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
 ip = request.getHeader("WL-Proxy-Client-IP");
 }

 if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
 ip = request.getHeader("HTTP_CLIENT_IP");
 }

 if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
 ip = request.getHeader("HTTP_X_FORWARDED_FOR");
 }

 if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
 ip = request.getRemoteAddr();
 if ("127.0.1".equals(ip) || "0:0:0:0:0:0:0:1".equals(ip)) {
 InetAddress address = (InetAddress)Safe.call(InetAddress::getLocalHost);
 ip = address.getHostAddress();
 }
 }

 if (ip != null && ip.length() > 15) {
 int i = ip.indexOf(",");
 if (i > 0) {
 ip = ip.substring(0, i);
 }
 }

 return ip;
 }
}

参考资料

https://segmentfault.com/a/1190000022240278

https://www.jianshu.com/p/a37fd499f0c1

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 161,326评论 4 369
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 68,228评论 1 304
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 110,979评论 0 252
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,489评论 0 217
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,894评论 3 294
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,900评论 1 224
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 32,075评论 2 317
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,803评论 0 205
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,565评论 1 249
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,778评论 2 253
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,255评论 1 265
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,582评论 3 261
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,254评论 3 241
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,151评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,952评论 0 201
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 36,035评论 2 285
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,839评论 2 277

推荐阅读更多精彩内容