PHP没有php485或php232扩展,串口通信统一通过fopen或dio_open操作设备文件;RS-232与RS-485差异在于硬件接线、电平芯片及RS-485需手动控制DE/RE引脚切换收发方向,否则通信阻塞。
PHP 本身没有原生的 php485 或 php232 扩展——这两个名字是常见误解,实际并不存在独立命名的“PHP485”或“PHP232”模块。你真正要操作的,是 PHP 通过串口(UART)与 RS-232 或 RS-485 设备通信,而区别完全来自底层硬件接口和驱动方式,不是 PHP 语言本身的分支。
fopen("php://dev/ttyS0") 或 dio_open()
PHP 操作串口依赖系统级设备文件(如 Linux 下的 /dev/ttyUSB0、/dev/ttyS0)或扩展(如 dio、php-serial)。它不区分 RS-232 还是 RS-485——只管发字节、收字节。真正的差异发生在:
MAX3232 类芯片升压到 ±12V;RS-485 用 SP3485 或 SN65HVD72 实现差分驱动dio 扩展读写 RS-485 设备时必须加 GPIO 控制Linux 下用 USB-RS485 转换器(如 CH340+SP3485 方案)时,多数模块把 DE/RE 引脚连到一个 GPIO 上。PHP 不能直接操作该引脚,需配合 shell 命令或 sysfs 接口切换方向:
echo 1 > /sys/class/gpio/gpio12/value # 拉高 DE,进入发送模式 fwrite($fd, "\x01\x03\x00\x00\x00\x02\xC4\x0B"); // 发送 Modbus RTU 帧 usleep(10000); echo 0 > /sys/class/gpio/gpio12/value # 拉低 DE,进入接收模式 $response = fread($fd, 10);
漏掉这步,设备永远只发不收,或只收不发——现象就是 fread() 一直阻塞或返回空。
RS-232 在 9600–115200 波特下容错较强;RS-485 在长距离(>100m)或高速(>19200)时,轻微的时钟偏差或布线不匹配就会导致 CRC 校验失败。务必注意:
9600,8,N,1(9600 波特、8 数据位、无校验、1 停止位)120Ω 终端电阻,否则远端信号反射会导致帧错误php-serial 库,记得调用 $serial->setBlocking(false) 避免 fread() 卡死绝大多数 RS-485 工业设备(温控器、电表、IO 模块)用 Modbus RTU 协议,而 RS-232 设备多为自定义 ASCII 帧。PHP 解析时关键差异在于:
"AT+READ\r\n"),可用 fgets() 直接读0xA001(反向),不是通用 CRC16-CCITTpack("C*", ...) 拼包,而非字符串拼接
真正难的从来不是 PHP 写几行 fwrite,而是搞清硬件怎么连、DE 引脚谁来控、CRC 怎么算、终端电阻焊没焊——这些地方错一点,PHP 就只能收到乱码或超时。