Nginx 删除访问的不必要的参数

  问题:前端开发报表,需要从我这边数据组拿数据,但是跨域了。

  解决跨域:后端做代理,把url请求代理到我们数据组的url。

  解决了跨域后,又有新的问题出现。前端服务端每次请求数据组数据的url,都会携带token参数。我们后端的对于token这个不能识别的参数报参数异常。

解决办法是,通过nginx代理修改请求参数,也就是在server里面修改nginx全局参数,也就是修改nginx中$args变量 

    学习下nginx的参数

  • $args : #这个变量等于请求行中的参数,同$query_string
  • $content_length : 请求头中的Content-length字段。
  • $content_type : 请求头中的Content-Type字段。
  • $document_root : 当前请求在root指令中指定的值。
  • $host : 请求主机头字段,否则为服务器名称。
  • $http_user_agent : 客户端agent信息
  • $http_cookie : 客户端cookie信息
  • $limit_rate : 这个变量可以限制连接速率。
  • $request_method : 客户端请求的动作,通常为GET或POST。
  • $remote_addr : 客户端的IP地址。
  • $remote_port : 客户端的端口。
  • $remote_user : 已经经过Auth Basic Module验证的用户名。
  • $request_filename : 当前请求的文件路径,由root或alias指令与URI请求生成。
  • $scheme : HTTP方法(如http,https)。
  • $server_protocol : 请求使用的协议,通常是HTTP/1.0或HTTP/1.1。
  • $server_addr : 服务器地址,在完成一次系统调用后可以确定这个值。
  • $server_name : 服务器名称。
  • $server_port : 请求到达服务器的端口号。
  • $request_uri : 包含请求参数的原始URI,不包含主机名,如:”/foo/bar.php?arg=baz”。
  • $uri : 不带请求参数的当前URI,$uri不包含主机名,如”/foo/bar.html”。
  • $document_uri : 与$uri相同。

nginx配置:

    location / {
            if ($args ~ "^(.*)(&token=.*)(&*.*)$") {
             set $args $1$3;
}
            proxy_pass http://localhost:00000;
                        proxy_http_version 1.1;
                        proxy_set_header Upgrade $http_upgrade;
                        proxy_set_header Connection 'upgrade';
                        proxy_set_header Host $host;
                        proxy_cache_bypass $http_upgrade;
                        add_header Access-Control-Allow-Origin *;
        }

   $args 是请求的参数,

   if 是正则匹配请求的参数

  ^$表示正则表达式的开头结尾

  这个正则表达式分为三个部分:

(.*) 表示开头,(&token=.*)表示token参数匹配(&*.*)$  表示结尾的匹配

  我们是要删除token参数,所有给$args重新赋值,三个分别的匹配用$1,$2,$3表示,

 set $args $1$3表示的是剔除$2的值。 

 如果需要添加参数的话可以: set  $args $1$3&aaa=1111

 

nginx还有rewrite,location的用法等。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值