nowise/uup-ews 问题修复 & 功能扩展

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

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

nowise/uup-ews

Composer 安装命令:

composer require nowise/uup-ews

包简介

Microsoft Exchange Web Service (EWS) Library

README 文档

README

SOAP client library for communication with the EWS. Most code is auto-generated from the WSDL/XSD downloaded from the Excahnge server.

This project is not really maintained (missing usecase) and has only been tested agains Exchange 2013, but made available in hope of being useful for someone!

Notice:

The WSDL and XSD-files bundled in config directory might need to be replaced to match the exchange server running in your organization. When updating WSDL, remember to also re-generate the PHP classes in source/UUP/Exchange/Types

Update WSDL/XSD files:

Download service, message and types definitions from the exchange server by running:

for f in services.wsdl messages.xsd types.xsd; do \
  curl -v --ntlm --user user@example.com \
      https://server.example.com/ews/$f > config/$f
done

Append service definition at end of config/services.wsdl. Replace server.example.com with the actual exchange server to provide default host:

<wsdl:service name="ExchangeServices">
  <wsdl:port name="ExchangeServicePort" binding="tns:ExchangeServiceBinding">
    <soap:address location="https://server.example.com/ews/exchange.asmx" />
  </wsdl:port>
</wsdl:service> 

Update PHP classes:

  1. Use the bundled script to generate PHP classes from WSDL. Requires suggested composer package wsdl2phpgenerator to be installed first:
composer require wsdl2phpgenerator/wsdl2phpgenerator
php bin/generate.php
  1. Download the CLI version of wsdl2phpgenerator, then generate the PHP classes from the WSDL file in the config directory:
php ~/wsdl2phpgenerator.phar -i config/services.wsdl \
    -o source/UUP/Exchange/Types -n "UUP\\Exchange\\Types" \
    --noIncludes --constructorNull --createAccessors

See documentation of wsdl2phpgenerator for more information:

Test:

A simple PHP script for testing connection and basic CRUD operations for calendar events can be found in the bin directory:

php bin/client.php --user=user@example.com --pass=secret \
                   --host=exchange.example.com \
                   --find --start="2015-11-25" --end="2015-12-01"
php bin/client.php --user=user@example.com --pass=secret \
                   --host=exchange.example.com \
                   --add --start="2015-11-25" --end="2015-12-01" \
                   --title="TEST" --body="Some text..."
php bin/client.php --user=user@example.com --pass=secret \
                   --host=exchange.example.com \
                   --delete --id="AABCurZhAAA="

Reference:

How to: Create appointments and meetings by using EWS in Exchange 2013

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: Apache-2.0
  • 更新时间: 2019-01-24

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固