PHP Google Api 客户端 SQL 管理员未启用身份验证 IP

标签 php mysql google-api google-cloud-platform google-api-php-client

我有这段代码可以更新我的 Google MySQL 实例授权 IP,连接正常,代码会打印当前 IP,但无法将新 IP 添加到设置中我尝试了很多方法,但仍然不起作用。不要对实例配置进行任何更改。

$client = new Google_Client();
    $client->setAuthConfig('../config/service-account.json');
    $client->setApplicationName(env("APP_NAME"));
    $projectName = env("GOOGLE_PROJECT_NAME");
    $instanceName = env("SQL_INSTANCE_NAME");
    $scopes = [
        "https://www.googleapis.com/auth/sqlservice.admin",
        "https://www.googleapis.com/auth/compute",
    ];
    $client->addScope($scopes);
    $sql = new Google_Service_SQLAdmin($client);
    $sqlAdmin = new Google_Service_SQLAdmin_Settings($client);
    $instanceSettings = $sql->instances->get($projectName, $instanceName)->getSettings();
    $authNetworks = $instanceSettings->getIpConfiguration();
    $newAuthNetwork = new Google_Service_SQLAdmin_AclEntry($client);
    $newAuthNetwork->setName("tmp_ip_connection");
    $newAuthNetwork->setKind("sql#aclEntry");
    $authNetworks->setAuthorizedNetworks($newAuthNetwork);
    $ipv4 = file_get_contents('https://api.ipify.org');
    $newAuthNetwork->setValue($ipv4);
    $ipConfiguration = new Google_Service_SQLAdmin_IpConfiguration($client);
    $ipConfiguration->setIpv4Enabled(true);
    $ipConfiguration->setAuthorizedNetworks([$newAuthNetwork]);
    $instanceSettings->setIpConfiguration($ipConfiguration);
    $sql->instances->get($projectName, $instanceName)->setSettings($instanceSettings);
    //TODO why it is not working??
    print_r($sql->instances->get($projectName, $instanceName)->getSettings()->getIpConfiguration()->getAuthorizedNetworks());

最佳答案

您的主要缺失是您在进行更改后从未更新过实例。

工作示例:

$client = new Google_Client();
$client->setAuthConfig('../config/service-account.json');
$client->setApplicationName(env("APP_NAME"));
$projectName = env("GOOGLE_PROJECT_NAME");
$instanceName = env("SQL_INSTANCE_NAME");
$scopes = [
    "https://www.googleapis.com/auth/sqlservice.admin",
    "https://www.googleapis.com/auth/compute",
];
$client->addScope($scopes);
$sql = new Google_Service_SQLAdmin($client);

$instances = $sql->instances;
$instance = $instances->get('projectId', 'instanceId');
$networks = $instance->getSettings()->getIpConfiguration()->getAuthorizedNetworks();

$values = [];
foreach ($networks as $network) {
    $values[$network->getName()] = $network;
}

$values['1.production'] = array_get($values, '1.production', clone head($values));
$external_ip = @file_get_contents('http://ipecho.net/plain');
$values['1.production']->setValue("$external_ip/32");
$values['1.production']->setName('1.production');

$instance->getSettings()->getIpConfiguration()->setAuthorizedNetworks(array_values($values));

$instances->update('projectId', 'instanceId', $instance);

关于PHP Google Api 客户端 SQL 管理员未启用身份验证 IP,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48457236/

相关文章:

php - 如何通过检查当前函数名添加一个 "active"类

php - 如何在MYSQL数据库中创建事件?

php - Mysql longtext不会保存某些文本?

php - 如何使用 PHP 统计 MySQL 连接数

python - 在程序的某些部分显式禁用 MySQL 查询缓存

google-api - 针对不同 API 和限制的 Google API 和批处理请求

php - 将页眉和页脚分离到各自的文件中

Mysql查询优化

javascript - 使用适用于网络浏览器的 Google URL Shortener API

python - Google API OAuth - 尝试上传到 YouTube 时收到 401(未经授权)