定制 voryx/wamppost 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

voryx/wamppost

最新稳定版本:0.2.1

Composer 安装命令:

composer require voryx/wamppost

包简介

HTTP to WAMP Publishing Proxy

README 文档

README

Build Status WampPost

WampPost is a WAMP v2 (Web Application Messaging Protocol) Client built with Thruway that allows publishing events and making RPC calls to a realm via HTTP Post.

WampPost is designed to be compatible with the crossbar HTTP pusher service.

There is no security on the HTTP side, so if this is going to be used, it would be best to use it only on localhost or behind some other security measure.

The WAMP side can be configured to use any security mechanism that is supported by Thruway, but any authentication and authorization will be the same for all HTTP events.

Quick Start with Composer

Create a directory for the test project

 $ mkdir wamppost 

Switch to the new directory

 $ cd wamppost 

Download Composer more info

 $ curl -sS https://getcomposer.org/installer | php 

Download WampPost and dependencies

 $ php composer.phar require "voryx/wamppost" "thruway/pawl-transport" 

If you need a WAMP router to test with, then start the sample with:

 $ php vendor/voryx/thruway/Examples/SimpleWsServer.php 

Thruway is now running on 127.0.0.1 port 9090.

PHP WampPost Client Usage

<?php require_once __DIR__ . "/vendor/autoload.php"; // create an HTTP server on port 8181 $wp = new \WampPost\WampPost('realm1', null, '127.0.0.1', 8181); // add a transport to connect to the WAMP router $wp->addTransportProvider(new \Thruway\Transport\PawlTransportProvider('ws://127.0.0.1:9090/')); // start the WampPost client $wp->start();

Publishing messages

Now that you have a WampPost client, you will be able to publish messages to the realm using a standard HTTP post.

An example using curl:

curl -H "Content-Type: application/json" -d '{"topic": "com.myapp.topic1", "args": ["Hello, world"]}' http://127.0.0.1:8181/pub 

Making an RPC Call

curl -H "Content-Type: application/json" \ -d '{"procedure": "com.myapp.my_rpc"}' \ http://127.0.0.1:8181/call 

RPC calls return a JSON object in the body:

{ result: "SUCCESS", args: [] argsKw: {} details: {} } 

Running WampPost Client Internally in Your Thruway Router

This Client can be easily run as an internal client in your Thruway Router.

<?php require_once __DIR__ . "/vendor/autoload.php"; use Thruway\Peer\Router; use Thruway\Transport\RatchetTransportProvider; $router = new Router(); //////// WampPost part // The WampPost client // create an HTTP server on port 8181 - notice that we have to // send in the same loop that the router is running on $wp = new WampPost\WampPost('realm1', $router->getLoop(), '127.0.0.1', 8181); // add a transport to connect to the WAMP router $router->addTransportProvider(new Thruway\Transport\InternalClientTransportProvider($wp)); ////////////////////// // The websocket transport provider for the router $transportProvider = new RatchetTransportProvider("127.0.0.1", 9090); $router->addTransportProvider($transportProvider); $router->start();

统计信息

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

GitHub 信息

  • Stars: 9
  • Watchers: 2
  • Forks: 4
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-04

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固