敏感信息直接在 nginx 通过环境变量设置

通常我们在维护PHP线上项目的时候,为了隔离配置和代码,会使用fastcgi_param的形式将环境变量定义在Nginx的配置文件中(Apache可以使用SetEnv指令)。这样在PHP-FPM运行过程中就可以使用getenv函数获取到环境变量的值了。

需要注意的是:这里的PHP代码都必须使用getenv函数获取环境变量,不能单纯依赖全局变量$_ENV。全局变量$_ENV并不总是可用的,除非在php.ini文件中显式设置了variables_order的值包含E,例如variables_order = "EGPCS"

 

另外,总是有人一不小心,就把账号密码提交到 github 了,所以代码应该是脱敏的。

下面这样就是一种简单的选择方案【缺点:php-cli和php-fpm是两个程序,有各自的环境变量,该设置方法无办法在php-cli中使用】:

复制代码
server {
    listen      80;
    server_name mengkang.net;
    access_log  logs/mengkang.net-access.log  main;

    root        /var/www/mengkang.net/public;
    index       index.html index.htm index.php;

    location / {
        try_files $uri $uri/ /index.php?$query_string;
    }

    location ~ \.php$ {
        try_files      $uri =404;
        fastcgi_pass   127.0.0.1:9000;
        fastcgi_index  index.php;
        fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
        include        fastcgi_params;
        fastcgi_param  GLOBAL_CONFIG_FILE /var/www/mengkang.net-global.config.php;
    }
}
复制代码

 

复制代码
$ cat mengkang.net-global.config.php
<?php

return [
    'environment' => 'beta',
    'database' => [
        'global.master' => [
            'dsn'     => '',
            'user'    => '',
            'pass'    => '',
            'options' => []
        ],
        'global.slaver' => [
            'dsn'     => '',
            'user'    => '',
            'pass'    => '',
            'options' => []
        ],
    ],
];
复制代码

 

include getenv('GLOBAL_CONFIG_FILE');

 

posted @   一个人的孤独自白  阅读(376)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
点击右上角即可分享
微信分享提示