当outlook Web插件通过makeEwsRequestAsync api

时间:2017-08-09 14:27:45

标签: exchangewebservices office-js

我们正在使用Exchange Server和Outlook客户端版本的不同组合测试Outlook Web Add-in。

加载项通过makeEwsRequestAsync API发出GetItem请求:

<?xml version="1.0" encoding="utf-8"?>
<soap:Envelope 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xmlns:m="http://schemas.microsoft.com/exchange/services/2006/messages" 
    xmlns:xsd="http://www.w3.org/2001/XMLSchema" 
    xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" 
    xmlns:t="http://schemas.microsoft.com/exchange/services/2006/types">
    <soap:Header>
        <RequestServerVersion Version="Exchange2013" 
            xmlns="http://schemas.microsoft.com/exchange/services/2006/types" soap:mustUnderstand="0" />
    </soap:Header>
    <soap:Body>
        <GetItem 
            xmlns="http://schemas.microsoft.com/exchange/services/2006/messages">
            <ItemShape>
                <t:BaseShape>IdOnly</t:BaseShape>
                <t:IncludeMimeContent>true</t:IncludeMimeContent>
            </ItemShape>
            <ItemIds>
                <t:ItemId Id="AAMkAGMwMDQxMDZhLTc5ODgtNDY5Yi1iYzk1LThlZDMyYjNiOTI3MgBGAAAAAACAJypvrerqS79u4AuHwVA6BwDco3spzUIpR7WutkjxuhkZAAAAAAEMAADco3spzUIpR7WutkjxuhkZAAA3RsNcAAA="/>
            </ItemIds>
        </GetItem>
    </soap:Body>
</soap:Envelope>

当我们使用Exchange Server 2016与Outlook for Windows 2013进行测试时,GetItem操作失败,并显示以下响应:

<s:Envelope 
    xmlns:s="http://schemas.xmlsoap.org/soap/envelope/">
    <s:Header>
        <h:ServerVersionInfo MajorVersion="15" MinorVersion="1" MajorBuildNumber="225" MinorBuildNumber="41" Version="V2_48" 
            xmlns:h="http://schemas.microsoft.com/exchange/services/2006/types" 
            xmlns="http://schemas.microsoft.com/exchange/services/2006/types" 
            xmlns:xsd="http://www.w3.org/2001/XMLSchema" 
            xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"/>
    </s:Header>
    <s:Body 
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
        xmlns:xsd="http://www.w3.org/2001/XMLSchema">
        <m:GetItemResponse 
            xmlns:m="http://schemas.microsoft.com/exchange/services/2006/messages" 
            xmlns:t="http://schemas.microsoft.com/exchange/services/2006/types">
            <m:ResponseMessages>
                <m:GetItemResponseMessage ResponseClass="Error">
                    <m:MessageText>Access is denied. Check credentials and try again.</m:MessageText>
                    <m:ResponseCode>ErrorAccessDenied</m:ResponseCode>
                    <m:DescriptiveLinkKey>0</m:DescriptiveLinkKey>
                    <m:Items/>
                </m:GetItemResponseMessage>
            </m:ResponseMessages>
        </m:GetItemResponse>
    </s:Body>
</s:Envelope> 

对于同一帐户,如果我们尝试使用Outlook 2016 for Windows或Outlook Web App,则加载项工作正常。

我怎样才能进一步调试?有没有已知的限制?能帮忙吗?

框架请求的JS代码:

function addSoapEnvelope(body) {

var request =
    '<?xml version="1.0" encoding="utf-8"?>' +
    '<soap:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"' +
    '               xmlns:m="http://schemas.microsoft.com/exchange/services/2006/messages"' +
    '               xmlns:xsd="http://www.w3.org/2001/XMLSchema"' +
    '               xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"' +
    '               xmlns:t="http://schemas.microsoft.com/exchange/services/2006/types">' +
    '  <soap:Header>' +
    '    <RequestServerVersion Version="Exchange2013" xmlns="http://schemas.microsoft.com/exchange/services/2006/types" soap:mustUnderstand="0" />' +
    '  </soap:Header>' +
    '  <soap:Body>' + body + '</soap:Body>' +
    ' </soap:Envelope>';

return request;

}

function getItemRequest(id) {
var body = 
    '<GetItem xmlns="http://schemas.microsoft.com/exchange/services/2006/messages">' +     
    '      <ItemShape>  <t:BaseShape>IdOnly</t:BaseShape>  <t:IncludeMimeContent>true</t:IncludeMimeContent>  </ItemShape>' +
    '      <ItemIds><t:ItemId Id="' + id + '"/></ItemIds>' +
    '</GetItem>';
return addSoapEnvelope(body);

}

var request = getItemRequest(itemid);

Office.context.mailbox.makeEwsRequestAsync(request,getMessageCallBack,requestContext);

来自Exchange服务器的EWS日志

2017-08-17T13:07:30.548Z,32e3b547-77aa-451C-9981-fbccecec0769,15,0,847,30,承载,TRUE,的 user1_mailbox@qa.sample.com 下, qa.sample.com,Microsoft Office / 15.0(Windows NT 10.0; Microsoft Outlook 15.0.4805;

Office扩展无权访问用户上下文中提供的邮箱以外的任何其他邮箱。在Microsoft.Exchange.Services上的Microsoft.Exchange.Services.Core.Types.StoreSessionCacheBase.ConnectOnce(ExchangePrincipal mailboxToAccess CallContext callContext Boolean unifiedLogon)at Microsoft.Exchange.Services.Core.Types.StoreSessionCacheBase.CreateMailboxSessionBasedOnAccessType(ExchangePrincipal mailboxToAccess CallContext callContext Boolean unifiedLogon) .Core.Types.AppWideStoreSessionCache.GetCachedMailboxSessionByGuid(Guid mailboxGuid CallContext callContext Boolean unifiedLogon)at Microsoft.Exchange.Services.Core.MethodWideStoreSessionCache.GetCachedStoreSessionByMailboxGuid(Guid mailboxGuid Boolean unifiedLogon)at Microsoft.Exchange.Services.Core.Types.MethodWideStoreSessionCache.GetCachedMailboxSession (MailboxId mailboxId Boolean unifiedLogon)at Microsoft.Exchange.Services.Core.Types.IdConverter.ConvertId(CallContext callContext IdHeaderInformation headerInformation ConvertOption convertOption BasicTypes expectedType List 1 attachmentIds String changeKey Int32 hashCode Boolean unifiedLogon Item& cachedItem) at Microsoft.Exchange.Services.Core.Types.IdConverter.ConvertItemIdToIdAndSession(BaseItemId baseItemId ConvertOption convertOption BasicTypes expectedType Item& cachedItem) at Microsoft.Exchange.Services.Core.GetItem.<>c__DisplayClass1.<Execute>b__0() at Microsoft.Exchange.Common.IL.ILUtil.DoTryFilterCatch(TryDelegate tryDelegate FilterDelegate filterDelegate CatchDelegate catchDelegate) at Microsoft.Exchange.Services.Core.GetItem.Execute() at Microsoft.Exchange.Services.Core.ExceptionHandler 1.Execut e(CreateServiceResult createServiceResult Int32 index GenerateMessageXmlForServiceError generateErrorXml);

0 个答案:

没有答案