0

0

php连接postgresql用ssl加密吗_php pg ssl连接配置法【步骤】

星夢妙者

星夢妙者

发布时间:2026-01-30 13:02:02

|

396人浏览过

|

来源于php中文网

原创

pg_connect() 默认不启用 SSL,必须显式配置sslmode;最简加密方式是连接字符串中加sslmode=require;需通过pg_stat_ssl验证是否真走SSL,且服务端须配置ssl=on及hostssl规则。

php连接postgresql用ssl加密吗_php pg ssl连接配置法【步骤】

PHP 的 pg_connect() 默认不启用 SSL

除非显式配置,pg_connect() 建立的连接走的是明文 TCP,即使 PostgreSQL 服务端已开启 SSL 支持。客户端不会自动协商或降级尝试 SSL,必须在连接字符串或选项数组中明确声明 SSL 相关参数。

连接字符串里加 sslmode=require 是最简方式

这是最小可行配置,适用于大多数开发和测试场景,只要服务端证书合法(或自签名但客户端信任),就能建立加密连接:

pg_connect("host=10.0.1.5 port=5432 dbname=test user=app sslmode=require");

常见可选值及含义:

  • disable:完全禁用 SSL(默认值)
  • require:强制加密,不验证证书链(适合内网+自签名)
  • verify-full:校验主机名 + 完整证书链(需配 sslrootcert
  • verify-ca:只校验证书链,不校验主机名

pg_connect() 数组参数更易管理证书路径

当需要 verify-full 或指定自定义 CA/客户端证书时,推荐用关联数组传参,避免连接字符串拼接出错:

立即学习PHP免费学习笔记(深入)”;

玄鲸Timeline
玄鲸Timeline

一个AI驱动的历史时间线生成平台

下载
$options = [
  'host' => 'db.example.com',
  'port' => '5432',
  'dbname' => 'myapp',
  'user' => 'webuser',
  'password' => 'xxx',
  'sslmode' => 'verify-full',
  'sslrootcert' => '/etc/ssl/certs/my-ca.crt',
  'sslcert' => '/etc/ssl/certs/client.crt',
  'sslkey' => '/etc/ssl/private/client.key',
];
pg_connect($options);

注意:

  • sslrootcert 必须是 PEM 格式、且 PHP 进程有读取权限
  • sslkey 文件权限应为 0600,否则 PostgreSQL 客户端库会拒绝加载
  • Windows 下路径用正斜杠或双反斜杠,单反斜杠会被 PHP 解析为转义字符

验证是否真走 SSL:查 pg_stat_ssl 视图

光看连接不报错不等于加密生效。登录数据库后执行:

SELECT * FROM pg_stat_ssl WHERE pid = pg_backend_pid();

若返回一行且 ssl 列为 t,说明当前连接已加密;versioncipher 字段可确认 TLS 版本与加密套件。如果返回空行,说明连接仍是明文 —— 此时要回头检查 sslmode 拼写、服务端 postgresql.confssl = onpg_hba.conf 是否允许该用户通过 hostssl 方式连接。

SSL 配置的真正复杂点不在 PHP 侧,而在于证书生命周期管理与服务端策略匹配。一个 verify-full 连接失败,90% 的情况是证书过期、主机名不匹配,或 pg_hba.conf 里漏写了 hostssl 规则而非 PHP 写法问题。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
require的用法
require的用法

require的用法有引入模块、导入类或方法、执行特定任务。想了解更多require的相关内容,可以阅读本专题下面的文章。

466

2023.11.27

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

319

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1502

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

624

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

653

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

609

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

172

2025.07.29

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

8

2026.01.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 10.2万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号