esolutions/ws 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

esolutions/ws

最新稳定版本:v1.0.0

Composer 安装命令:

composer require esolutions/ws

包简介

HTTP client for WhatsApp API

README 文档

README

Cliente HTTP para WhatsApp API. Envía mensajes de texto y documentos PDF, y gestiona sesiones.

Instalación

composer require esolutions/ws

Namespace

Esolutions\Ws\

Configuración

Agregar en config/esolutions.php:

'ws' => [
    'url'   => env('WS_API_URL'),
    'token' => env('WS_API_TOKEN'),
],

Agregar en .env:

WS_API_URL=http://tu-servidor-whatsapp/api
WS_API_TOKEN=tu_token_aqui

Uso

use Esolutions\Ws\Service as WhatsApp;

Enviar PDF

Envía un archivo PDF como adjunto a un número de WhatsApp.

$pdfContent = file_get_contents('/ruta/al/archivo.pdf');

$result = WhatsApp::sendPdf(
    base64Pdf: base64_encode($pdfContent),
    number: '51987654321',
    message: 'Adjunto su comprobante de pago',
    filename: 'factura_F001-001.pdf'
);

// → ['success' => true, 'messageId' => 'abc123']
// → ['success' => false, 'message' => 'Sesión no disponible']

Enviar texto

$result = WhatsApp::sendText(
    sessionId: 'session-01',
    to: '51987654321',
    text: 'Su pedido fue confirmado. Gracias por su compra.'
);

Listar sesiones

$sessions = WhatsApp::getSessions();

// → [
//     'success' => true,
//     'data' => [
//         ['id' => 'session-01', 'status' => 'connected'],
//         ['id' => 'session-02', 'status' => 'disconnected'],
//     ]
// ]

Estado de una sesión

$status = WhatsApp::getSessionStatus('session-01');

// → ['success' => true, 'data' => ['status' => 'connected']]

Estado de entrega de un mensaje

$status = WhatsApp::getMessageStatus('abc123');

// → ['success' => true, 'data' => ['status' => 'delivered']]

Métodos

Método Timeout Descripción
sendPdf($base64, $number, $message, $filename) 30s Envía un PDF como archivo adjunto
sendText($sessionId, $to, $text) 15s Envía mensaje de texto plano
getSessions() 15s Lista todas las sesiones disponibles
getSessionStatus($sessionId) 15s Estado de una sesión específica
getMessageStatus($messageId) 15s Estado de entrega de un mensaje

Comportamiento

  • Todos los métodos retornan array con success como clave principal.
  • Los errores de red o de la API se capturan internamente — nunca lanza excepciones.
  • SSL verify desactivado para compatibilidad con servidores locales/privados.
  • Timeout de PDF es mayor (30s) porque el servidor puede tardar en procesar archivos grandes.

Formato del número

El número de destino debe incluir el código de país sin +:

51987654321   ✅  Perú
1234567890    ❌  Sin código de país
+51987654321  ❌  Con símbolo +

统计信息

  • 总下载量: 0
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 3
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: proprietary
  • 更新时间: 2026-06-11

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固