经过两天令人沮丧的日子,我放弃了。我有一台带有 Win2012R2 + Exchange 2013 (Trailversion) 的虚拟机“admx”和一台带有 IIS-Webserver+PHP 的虚拟机“webserver”。
制作一个新的订阅 - sub.php:
<?PHP
function __autoload($class_name)
{
// Start from the base path and determine the location from the class name,
$base_path = 'php-ews';
$include_file = $base_path . '/' . str_replace('_', '/', $class_name) . '.php';
//$include_file = str_replace('_', '/', $class_name) . '.php';
return (file_exists($include_file) ? require_once $include_file : false);
}
$server = "admx";
$host = $server;
$username = "administrator@testdom.local";
$password = "secret123";
$version = "Exchange2013";
$url = "http://webserver/testexchange/log.php";
$keepAliveFrequency = 1;
$ews = new ExchangeWebServices($server, $username, $password, $version);
$subscribe_request = new EWSType_SubscribeType();
$pushSubscription = new EWSType_PushSubscriptionRequestType();
$pushSubscription->StatusFrequency = $keepAliveFrequency;
$pushSubscription->URL = $url;
$folderIDs = new EWSType_NonEmptyArrayOfBaseFolderIdsType();
$eventTypes = new EWSType_NonEmptyArrayOfNotificationEventTypesType();
$folderIDs->DistinguishedFolderId = new EWSType_DistinguishedFolderIdType();
$folderIDs->DistinguishedFolderId->Id = EWSType_DistinguishedFolderIdNameType::INBOX;
$eventTypes->EventType = "NewMailEvent";
$pushSubscription->FolderIds = $folderIDs;
$pushSubscription->EventTypes = $eventTypes;
$subscribe_request->PushSubscriptionRequest = $pushSubscription;
$response = $ews->Subscribe($subscribe_request);
var_dump($response);
?>
输出:
object(stdClass)#10 (1) { ["ResponseMessages"]=> object(stdClass)#11 (1) { ["SubscribeResponseMessage"]=> object(stdClass)#12 (4) { ["ResponseCode"]=> string(7) "NoError" ["ResponseClass"]=> string(7) "Success" ["SubscriptionId"]=> string(64) "EgBhZG14LnRlc3Rkb20ubG9jYWwQAAAA3keYE/U5Mkacz2FAg6DfHKdXyqelf9II" ["Watermark"]=> string(40) "AQAAAF57K7d1ihJLl9odwZ02gVahGgAAAAAAAAA=" } } }
这样,订阅就成功注册了。这是侦听器-log.php
<?PHP
echo "<?xml version=\"1.0\" encoding=\"UTF-8\"?>
<SOAP-ENV:Envelope xmlns:SOAP-ENV=\"http://schemas.xmlsoap.org/soap/envelope/\" xmlns:ns1=\"http://schemas.microsoft.com/exchange/services/2006/messages\">
<SOAP-ENV:Body>
<ns1:SendNotificationResult>
<ns1:SubscriptionStatus>OK</ns1:SubscriptionStatus>
</ns1:SendNotificationResult>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>";
file_put_contents("C:\\exlog\\only_ok_".time().".txt", print_r($_REQUEST,1));
?>
现在我每分钟(因为 $keepAliveFrequency = 1;)从 Exchange-Server 得到一个新的响应/状态检查。当我向 administrator@testdom.local 发送电子邮件时,我也会立即收到新通知(因为收件箱中的“NewMailEvent”)。我用 OK 作为 XML 来确认它,以保持订阅......到目前为止一切都很好。
但是在日志文件中(only_ok_1435488594.txt)只有...
Array()
更新 log.php 以获取通知信息:
<?PHP
class ewsService {
public function SendNotification( $arg ) {
file_put_contents("C:\\exlog\\logfile2_".time().".txt", print_r($arg,1));
$result = new EWSType_SendNotificationResultType();
$result->SubscriptionStatus = 'OK';
//$result->SubscriptionStatus = 'Unsubscribe';
return $result;
}
}
$server = new SoapServer( 'php-ews/wsdl/NotificationService.wsdl', array( 'uri' => 'http://webserver/testexchange/log.php'));
$server->setObject( $service = new ewsService() );
$server->handle();
?>
现在日志文件作为“array()”的更多信息:
stdClass Object
(
[ResponseMessages] => stdClass Object
(
[SendNotificationResponseMessage] => stdClass Object
(
[ResponseCode] => NoError
[ResponseClass] => Success
[Notification] => stdClass Object
(
[SubscriptionId] => EgBhZG14LnRlc3Rkb20ubG9jYWwQAAAAvfY+2ehqCEOXroWYNAsn+mD+ZBQYf9II
[PreviousWatermark] => AQAAAF57K7d1ihJLl9odwZ02gVZNGAAAAAAAAAA=
[MoreEvents] =>
[StatusEvent] => stdClass Object
(
[Watermark] => AQAAAF57K7d1ihJLl9odwZ02gVZNGAAAAAAAAAA=
)
)
)
)
)
问题:订阅丢失了 3 个以上的通知。从我知道的 MSDN 文档中,Exchangeserver 重试状态消息的 3 次以从侦听器获得“OK”。
我已经从 GoogleSearch 下载了 NotificationService.wsdl。
<?xml version="1.0" encoding="utf-8"?>
<!-- Copyright (C) 2007 Microsoft Corporation. All rights reserved. -->
<wsdl:definitions xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/" xmlns:tns="http://schemas.microsoft.com/exchange/services/2006/messages" xmlns:s="http://www.w3.org/2001/XMLSchema" xmlns:soap12="http://schemas.xmlsoap.org/wsdl/soap12/" targetNamespace="http://schemas.microsoft.com/exchange/services/2006/messages" xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/">
<wsdl:types>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema">
<xs:import namespace="http://schemas.microsoft.com/exchange/services/2006/messages" schemaLocation="messages.xsd"/>
</xs:schema>
</wsdl:types>
<wsdl:message name="SendNotificationSoapIn">
<wsdl:part name="request" element="tns:SendNotification" />
</wsdl:message>
<wsdl:message name="SendNotificationSoapOut">
<wsdl:part name="SendNotificationResult" element="tns:SendNotificationResult" />
</wsdl:message>
<wsdl:portType name="NotificationServicePortType">
<wsdl:operation name="SendNotification">
<wsdl:input message="tns:SendNotificationSoapIn" />
<wsdl:output message="tns:SendNotificationSoapOut" />
</wsdl:operation>
</wsdl:portType>
<wsdl:binding name="NotificationServiceBinding" type="tns:NotificationServicePortType">
<wsdl:documentation>
<wsi:Claim conformsTo="http://ws-i.org/profiles/basic/1.0" xmlns:wsi="http://ws-i.org/schemas/conformanceClaim/" />
</wsdl:documentation>
<soap:binding transport="http://schemas.xmlsoap.org/soap/http" style="document" />
<wsdl:operation name="SendNotification">
<soap:operation soapAction="http://schemas.microsoft.com/exchange/services/2006/messages/SendNotification" />
<wsdl:input>
<soap:body use="literal" />
</wsdl:input>
<wsdl:output>
<soap:body use="literal" />
</wsdl:output>
</wsdl:operation>
</wsdl:binding>
<wsdl:binding name="NotificationServiceBinding12" type="tns:NotificationServicePortType">
<soap12:binding transport="http://schemas.xmlsoap.org/soap/http" style="document" />
<wsdl:operation name="SendNotification">
<soap12:operation soapAction="http://schemas.microsoft.com/exchange/services/2006/messages/SendNotification" />
<wsdl:input>
<soap12:body use="literal" />
</wsdl:input>
<wsdl:output>
<soap12:body use="literal" />
</wsdl:output>
</wsdl:operation>
</wsdl:binding>
<wsdl:service name="NotificationServices">
<wsdl:port name="NotificationServicePort" binding="tns:NotificationServiceBinding">
<soap:address location="" />
</wsdl:port>
</wsdl:service>
</wsdl:definitions>
我也添加了这个,因为没有它我得到一个“绑定错误”
<wsdl:service name="NotificationServices">
<wsdl:port name="NotificationServicePort" binding="tns:NotificationServiceBinding">
<soap:address location="" />
</wsdl:port>
</wsdl:service>
我不是 SOAP 方面的专家……这里出了什么问题?谢谢奥利