docker PHP容器安装sqlserver扩展,,SSL routines:ssl_choose_client_version:unsupported protocol

完整错误信息

Uncaught PDOException: SQLSTATE[08001]: [Microsoft][ODBC Driver 17 for SQL Server]SSL Provider: [error:1425F102:SSL routines:ssl_choose_client_version:unsupported protocol]

场景描述

这个错误是
我在用docker pull php:7.2-fpm部署PHP环境把sqlserver 安装好后
pdo连接sqlserver报出的错误

本以为是因为odbc 没有安装好。。。
后Google查找解决了
原文

解决方法

下面是Google翻译出来的原文将就看

您列出的SQL Server版本包括TLS 1.2支持,因此您现在已经是客户端问题,这是正确的。之所以这样

RUN apt-get update -yqq \
&& apt-get install -y --no-install-recommends openssl \ 
&& 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在 Linux 的 Docker 容器中已有 PHP 环境的情况下,可以通过在容器安装 MSSQL 驱动程序以及 pdo_sqlsrv 和 sqlsrv 两个扩展来连接 SQL Server 数据库。以下是安装步骤: 1. 进入容器 执行以下命令进入容器: ``` docker exec -it container_name /bin/bash ``` 其中 container_name 是容器的名称或 ID。 2. 安装必要的依赖项 在容器中执行以下命令安装必要的依赖项: ``` apt-get update apt-get install -y \ unixodbc-dev \ gnupg2 \ curl ``` 3. 添加 Microsoft 的存储库并安装 MSSQL 驱动程序 在容器中执行以下命令添加 Microsoft 的存储库并安装 MSSQL 驱动程序: ``` curl https://packages.microsoft.com/keys/microsoft.asc | apt-key add - curl https://packages.microsoft.com/config/debian/10/prod.list > /etc/apt/sources.list.d/mssql-release.list apt-get update ACCEPT_EULA=Y apt-get install -y \ msodbcsql17 \ mssql-tools \ libgssapi-krb5-2 ``` 4. 安装 pdo_sqlsrv 和 sqlsrv 扩展容器中执行以下命令安装 pdo_sqlsrv 和 sqlsrv 扩展: ``` pecl install pdo_sqlsrv sqlsrv docker-php-ext-enable pdo_sqlsrv sqlsrv ``` 5. 重启 Apache 服务 在容器中执行以下命令重启 Apache 服务: ``` apachectl -k restart ``` 6. 测试连接 SQL Server 数据库 在 PHP 代码中使用如下方式连接 SQL Server 数据库: ```php $serverName = "your_server_name"; // SQL Server 服务器名称 $connectionOptions = array( "Database" => "your_database_name", // 数据库名称 "Uid" => "your_username", // 用户名 "PWD" => "your_password" // 密码 ); // 创建连接 $conn = sqlsrv_connect($serverName, $connectionOptions); // 检查连接是否成功 if ($conn === false) { die(print_r(sqlsrv_errors(), true)); } else { echo "Connected successfully."; } // 关闭连接 sqlsrv_close($conn); ``` 如果运行结果输出 Connected successfully.,则表示连接成功。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

成长中de大神

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值