byjg/soap-server 问题修复 & 功能扩展

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

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

byjg/soap-server

最新稳定版本:6.0.0

Composer 安装命令:

composer require byjg/soap-server

包简介

A lightweight and modern SOAP server implementation for PHP 8.3+

README 文档

README

sidebar_key soap-server
tags
php http

Soap Server

A lightweight and modern SOAP server implementation for PHP 8.3+

Sponsor Build Status Opensource ByJG GitHub source GitHub license GitHub release

Features

  • 🚀 Modern PHP 8.3+ Attributes: Use PHP attributes to define SOAP services declaratively
  • 📝 Auto-generated WSDL: Automatic WSDL generation from your service definitions
  • 🎨 Beautiful Documentation UI: Modern, interactive HTML documentation with Jinja templates
  • 🔧 Flexible Configuration: Support for both attribute-based and programmatic configuration
  • 📊 Type Safety: Full support for complex types, arrays, and optional parameters
  • 🌐 SOAP 1.1 & 1.2: Support for both SOAP versions
  • 🎯 Discovery Support: Built-in DISCO (Discovery) document generation
  • 📱 Responsive Design: Mobile-friendly service documentation interface

Installation

composer require byjg/soap-server

Quick Start

Using PHP Attributes (Recommended)

<?php

use ByJG\SoapServer\Attributes\{SoapService, SoapOperation, SoapParameter};
use ByJG\SoapServer\SoapAttributeParser;
use ByJG\SoapServer\ResponseWriter;

#[SoapService(
    serviceName: 'CalculatorService',
    namespace: 'http://example.com/calculator',
    description: 'A simple calculator web service'
)]
class Calculator
{
    #[SoapOperation(description: 'Adds two numbers together')]
    public function add(
        #[SoapParameter(description: 'First number')] int $a,
        #[SoapParameter(description: 'Second number')] int $b
    ): int {
        return $a + $b;
    }

    #[SoapOperation(description: 'Subtracts second from first')]
    public function subtract(int $a, int $b): int
    {
        return $a - $b;
    }
}

// Start the service
$handler = SoapAttributeParser::parse(Calculator::class);
$response = $handler->handle();
ResponseWriter::output($response);

Using Programmatic Configuration

<?php

use ByJG\SoapServer\{SoapHandler, SoapOperationConfig, SoapParameterConfig, SoapType};
use ByJG\SoapServer\ResponseWriter;

$addOperation = new SoapOperationConfig();
$addOperation->description = 'Adds two numbers';
$addOperation->args = [
    new SoapParameterConfig('a', SoapType::Integer),
    new SoapParameterConfig('b', SoapType::Integer)
];
$addOperation->returnType = SoapType::Integer;
$addOperation->executor = function(array $params) {
    return $params['a'] + $params['b'];
};

$handler = new SoapHandler(
    soapItems: ['add' => $addOperation],
    serviceName: 'CalculatorService'
);
$response = $handler->handle();
ResponseWriter::output($response);

Running the Service

Start PHP's built-in web server:

php -S localhost:8080 calculator.php

Then access:

Running Tests

composer install
composer test

Running Static Analysis

composer psalm

Documentation

Comprehensive documentation is available:

License and Acknowledgments

This project is licensed under the MIT License.

Note: Parts of this codebase were derived from an older PHP class originally licensed under the PHP License. The original code has been modernized and adapted for this project. For detailed information about the licensing and acknowledgments, see License Acknowledgments.

Dependencies

flowchart TD
    byjg/soap-server --> byjg/jinja-php
    byjg/soap-server --> byjg/webrequest
    byjg/soap-server --> byjg/serializer
Loading

Open source ByJG

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-11-03

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固