运维
  • 知识体系
    • 运维体系
    • 缓存体系
    • 安全体系
  • 自动化
    • 服务器初始化
      • 用户操作记录监控
    • 自动化运维
      • 自动化生成域名信息
    • JAVA后端自动化构建发布
    • PHP-laravel自动化构建发布
    • EXE自动化构建发布(CocosCreator)
    • 前端自动化构建发布
    • 苹果自动化构建发布
    • 安卓自动化构建发布
      • VirtualBox 安卓自动化构建发布
      • Docker 安卓自动化构建发布
    • 项目自动化构建发布
    • 自动化下注
    • 常见下载器 docker 启动方式
  • 监控
    • 服务器负载监控
      • 监控CPU
      • 监控磁盘
      • 监控内存
    • 域名跳炸监控
    • serverstatus
    • 接口监控报警
    • zabbix监控部署
      • zabbix-dockerfile.sh
      • zabbix-install.sh
    • glances监控部署
      • glances.sh
      • glances_alert.sh
    • ssh 登录/登出监控
    • 文件变动监控
    • 宝塔时时监控域名
    • 飞书日志监控
    • 监控进程
  • 服务
    • go-install.sh
    • jenkins-install.sh
      • k8s.jenkins
    • redis-install.sh
      • k8s.redis
    • node-install.sh
      • k8s.node
    • nginx-install.sh
      • k8s.nginx
    • NGINX
      • nginx+GeoIP2模块编译
      • Nginx根据不同浏览器语言配置跳转
      • Nginx根据用户ip返回对应地区语言
      • nginx log 正则分析
      • 应对网站扫描/攻击/采集方法
    • 自建fiora聊天服务器
    • Laravel 部署
      • Laravel 部署:环境一键安装
      • Laravel 部署:Nginx 配置
      • Laravel 部署:文件夹权限
      • Laravel 部署:PHP-fpm 配置调优
      • Laravel 部署:服务器优化清单
    • ELK传统方式部署
    • ELK 分析nginx日志
    • GitLab迁移数据
  • 区块链
    • 区块链威胁情报共享平台
    • 以太坊公链私链geth同步
    • 比特节点同步
    • BTC节点错误解决方法
    • eth硬分叉
    • omni钱包节点搭建
    • 区块链钱包系统设计架构
  • Docker
    • Centos7
      • 安装docker
      • 安装redis
      • 搭建Nginx
      • 搭建Jenkins
      • 搭建Zookeeper
        • zookeeper集群
      • 搭建Tomcat
      • 搭建Mysql
      • 搭建PHP环境
      • 搭建Swagger
      • 部署owncloud云盘
      • 部署ES
        • ELK 分析 Laravel 日志
      • java容器运行外置jar
      • 部署etcd节点
    • docker阿里云私有仓库
    • Docker-compose
      • 启动gitlab
      • 创建mysql数据库
      • gitlab-docker-compose.yml
      • nginx-docker-compose.yml
  • showdoc
  • 数据库
    • 授权
    • 开启远程访问及相关权限控制
    • 快速导出导入大数据
    • 单机备份
    • 加密并切片备份到飞机群
    • 异地备份
    • binlog日志
    • docker 搭建mysq主从
    • docker搭建主从数据库及读写分离
    • docker快速恢复备份数据库
  • Telegram机器人
    • SHELL命令完成信息推送
    • Javacript创建信息推送页面
    • node远程执行shell命令
  • 安全
    • 后台安全登陆
    • github渗透测试工具库
    • 漏洞扫描-AWVS-Nessus-Docker版
    • AWVS13.X 破解版Windows、Linux、Docker
    • 操作图片元信息(Megadata)
    • 一键测试服务器到国内外各地速度脚本
  • 翻墙
    • 4K高清看P站和X站翻墙教程
    • 翻墙后重度使用的13个网站及app,深度适合国人
  • 色站自动化
    • 自动化下载片源
    • 自动化按照 AV 分类下载种子 脚本
    • 自动化切片打水印字幕
    • 自动化发布片源
    • ffmpeg一键切片并发布
  • 进阶技术
    • 哈希hash下注
    • 翻译 php 代码内 中文 为 泰语
      • bash 版
      • python 版
    • shell实现多线程
    • 多线程parallel命令 「纯干货」
    • 6our.com 刷评论广告
    • 90tiyu.com 撞库出电话
      • 90tiyu.com_guangzhou.sh
      • 90tiyu.com_guiyang.sh
      • 90tiyu.com_guilin.sh
    • tianhoo.cn 撞库出邮箱
    • 俄罗斯方块游戏
  • go开发环境
  • VPN
  • 生产环境docker部署
Powered by GitBook
On this page
  1. 服务
  2. NGINX

Nginx根据用户ip返回对应地区语言

1 Nginx 编译进 geoip2 模块后更改主配置 http 部分 (geoip2 比geoip 更优秀)

    #Nginx 编译进geoip模块后在主配置http内添加
    #开启CDN后获取访客真实IP地址
    set_real_ip_from 0.0.0.0/0;
    real_ip_header X-Forwarded-For;
    ## GEOIP2 国家
    geoip2 /usr/share/GeoIP/GeoLite2-Country.mmdb {
          $geoip2_Country_code country iso_code;
    }
    ## GEOIP2 城市 
    geoip2 /usr/share/GeoIP/GeoLite2-City.mmdb {
          $geoip2_City_code country iso_code;
    }
    # 好单独为 城市级别 单独设置

2 域名的nginx 配置内添加负载均衡配置

upstream ben {
    ip_hash;
    server 1.1.1.1 weight=1 max_fails=2 fail_timeout=2s;
    server 2.2.2.2 weight=2 max_fails=2 fail_timeout=2s;
    server 3.3.3.3 weight=2 max_fails=2 fail_timeout=2s;
}

3 伪静态内写 ip 地区转化对应语言逻辑

#larvel 框架前台代码加伪静态
location / {
#初始化语言变量
set $language 0;
if ($geoip2_country_code = CN) { #祖国
  set $language "1";
  add_header  accept-language zh-CN;
}
if ($geoip2_country_code = MO) { #澳门
  set $language "2";
  add_header  accept-language zh-TW;
}
if ($geoip2_country_code = HK) { #香港
  set $language "3";
  add_header  accept-language zh-TW;
}
if ($geoip2_country_code = TW) { #台湾
  set $language "4";
  add_header  accept-language zh-TW;
}
if ($geoip2_country_code = VN) { #越南
  set $language "5";
  add_header  accept-language vi-VN;
}
if ($geoip2_country_code = VN) { #神奇的国家
  set $language "5";
  add_header  accept-language zh-CN;
}
#访客ip非上述地区就默认返回英语语言标识
if ($language = 0){
    add_header  accept-language en;
}
        try_files $uri $uri/ /index.html; #larvel 框架前台代码特定伪静态
            #通过负载均衡转发到后台服务器
            proxy_pass http://ben;
            proxy_set_header Host $host:$server_port;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            #携带根据ip地区更改后的语言
            proxy_set_header Accept-Language $http_accept_language; 
            proxy_set_header token $http_token;
   }

4 然后前端就能感觉到用户语言 lang 了

// vue项目的多语言/国际化插件vue-i18n
// 想实现的效果:需要在web中实现多语言的切换,当用户语言切换完成后下次重新打开网页,也是上次设置的语言进行显示

// 1、在用户点击切换语言后,把选择的语言版本保存在cookie或storage中


//写入cookie函数
function setCookie(name,value) {
    var Days = 30;
    var exp = new Date();
    exp.setTime(exp.getTime() + Days*24*60*60*1000);
    document.cookie = name + "="+ escape (value) + ";expires=" + exp.toGMTString();
}

//获取cookie
function getCookie(name) {
    var arr,reg=new RegExp("(^| )"+name+"=([^;]*)(;|$)");
    if(arr=document.cookie.match(reg))
    return unescape(arr[2]);
    else
    return null;
}

//setCookie('lan','zh-TW');    繁体中文
//setCookie('lan','zh-CN');    简体中文
//setCookie('lan','en');       英文
//setCookie('lan','vi-VN');    越南语

// 2、在包含静态文本的标签中,添加一个属性:set-lan=”html:name” 
// 属性值中的 html 代表内容的位置,name 代表要替换的文字的标识 

<span set-lan="html:name">名字</span>
<input type="text" value="名字" set-lan="val:name" />

// 这些需要在开发过程中添加进去,并且,要切换语言文字的外面都必须要有一个标签包裹,否则无法进行切换;如:
<span set-lan="html:name"><i class="icon"></i>名字</span>
// 这样的代码,是无法把“名字”替换成“Name”的,会把“名字”前面的i标签也一起替换掉,如果不想把i标签也替换掉,就要在“名字”外面添加一个标签,改成:
<span><i class="icon"></i><lan set-lan="html:name">名字</lan></span>

// 3、定义3个语言的标识+内容的json字符串

var zh-CN = {
            "name" : "姓名",
            "tel" : "电话",
            "email" : "邮箱",
        };

var zh-TW = {
            "name" : "姓名",
            "tel" : "電話",
            "email" : "郵箱",
        };

var en = {
            "name" : "Name",
            "tel" : "Tel",
            "email" : "Email",
        };
var vi-VN = {
            "name" : "不会越南语",
            "tel" : "看不懂越南语",
            "email" : "越南妹子不错",
        };

// 4、遍历带set-lan属性的标签,进行文本替换
$('[set-lan]').each(function(){
    var me = $(this);
    var a = me.attr('set-lan').split(':');
    var p = a[0];   //文字放置位置
    var m = a[1];   //文字的标识

    //用户选择语言后保存在cookie中,这里读取cookie中的语言版本
    var lan = getCookie('lan');

    //选取语言文字
    switch(lan){
        case 'zh-CN':
            var t = zh-CN[m];  //这里cn[m]中的cn是上面定义的json字符串的变量名,m是json中的键,用此方式读取到json中的值
            break;
        case 'zh-TW':
            var t = zh-TW[m];
            break;
        case 'vi-VN':
            var t = vi-VN[m];
            break;
        default:
            var t = en[m];
    }

    //如果所选语言的json中没有此内容就选取其他语言显示
    if(t==undefined) t = zh-CN[m];
    if(t==undefined) t = en[m];
    if(t==undefined) t = zh-TW[m];
    if(t==undefined) t = vi-VN[m];

    if(t==undefined) return true;//文字放置位置有(html,val等,可以自己添加)
    switch(p){
        case 'html':
            me.html(t);
            break;
        case 'val':
        case 'value':
            me.val(t);
            break;
        default:
            me.html(t);
    }

});

// 5、以上是html中的文字替换,但是写在js中的文字怎么办? 可以定义一个函数,来读取
function getLan(m) {
    //获取文字
    var lan = getCookie('lan');     //语言版本
    //选取语言文字
    switch(lan){
        case 'zh-CN':
            var t = zh-CN[m];
            break;
        case 'zh-TW':
            var t = zh-TW[m];
            break;
        case 'vi-VN':
            var t = vi-VN[m];
            break;
        default:
            var t = en[m];

    //如果所选语言的json中没有此内容就选取其他语言显示
    if(t==undefined) t = zh-CN[m];
    if(t==undefined) t = en[m];
    if(t==undefined) t = zh-TW[m];
    if(t==undefined) t = vi-VN[m];

    if(t==undefined) t = m; //如果还是没有就返回他的标识

    return t;
}

//遍历dom来修改文字笨了点,能跑就OK 也可以请求后台返回不同语言的文字 
// 反正NGINX 做了语言标识转发到 后台

// 有空了写再后台接受到 nginx 语言 标识 后 多语言操作方式
PreviousNginx根据不同浏览器语言配置跳转Nextnginx log 正则分析

Last updated 3 years ago