2015-01-05 4 views
1

현재 Microsoft Office 365 Rest API가 올바르게 작동하는 방법을 이해하는 데 어려움을 겪고 있습니다.REST API를 통해 연락처를 지원하는 프로세스

{ ["token_type"]=> string(6) "Bearer" ["expires_in"]=> string(4) "3600" ["expires_on"]=> string(10) "1420476937" ["not_before"]=> string(10) "1420473037" ["resource"]=> string(30) "https://outlook.office365.com/" ["access_token"]=> string(1276) "eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsIng1dCI6ImtyaU1QZG1Cdng2OHNrVDgtbVBBQjNCc2VlQSJ9.eyJhdWQiOiJodHRwczovL291dGxvb2sub2ZmaWNlMzY1LmNvbS8iLCJpc3MiOiJodHRwczovL3N0cy53aW5kb3dzLm5ldC81YjVkNjRjOC03YTgxLTQ1NzctOWEyYy04OTJjNDc1Y2UxN2EvIiwiaWF0IjoxNDIwNDczMDM3LCJuYmYiOjE0MjA0NzMwMzcsImV4cCI6MTQyMDQ3NjkzNywidmVyIjoiMS4wIiwidGlkIjoiNWI1ZDY0YzgtN2E4MS00NTc3LTlhMmMtODkyYzQ3NWNlMTdhIiwiYW1yIjpbInB3ZCJdLCJlbWFpbCI6IndhcnJlbi5kb3lsZUBzeW5ldHkuY29tIiwiaWRwIjoiaHR0cHM6Ly9zdHMud2luZG93cy5uZXQvZDJjMmY2N2EtOTdjYy00N2Q5LWIxOWItNzAyMjRhNGVjYmUyLyIsImFsdHNlY2lkIjoiNTo6MTAwM0JGRkQ4ODg0OEI3RiIsInN1YiI6Imo3QzhzODJ0aDVlQTl4UjFGS0YxeDhya0FjNjlrd0lFeFFTcm5pSzJJS2MiLCJnaXZlbl9uYW1lIjoiV2FycmVuIiwiZmFtaWx5X25hbWUiOiJEb3lsZSIsIm5hbWUiOiJXYXJyZW4gRG95bGUiLCJ1bmlxdWVfbmFtZSI6IndhcnJlbi5kb3lsZUBzeW5ldHkuY29tIiwiYXBwaWQiOiJhYzNkMWVkMS00MDdkLTQzM2YtOTk4Zi1jMzMxOGI5NmUxOTQiLCJhcHBpZGFjciI6IjEiLCJzY3AiOiJDb250YWN0cy5SZWFkIENvbnRhY3RzLldyaXRlIiwiYWNyIjoiMSJ9.g4bNE7iSjPgazeeHdgQZy-ml_YqhPKAvvM0rHGxifu6k6POeHdcpgZurgJOW3AjmoM4SYLg6R1mhqLYwBolb3CxgqQJGIZ8uyzPMhlCtlowcD6JFWYB7McIQruFwxDthSWma_4YGb6pRW4LrTvfh1pxLMnSXhiI2nPltrJUbAJX_XdcnSGm7OqDNM68G8Eb1bz0xW9vAB0yuE7O9ewEcjwlUw4pzS5lNA0Y4-q-Ps9fn0goqzBh-ktZhAQPNhf91zv3v9Py3NPdsA-OtzdcIiPPAL_unmqcDisjChXVgBmHirTsb0Tt_UC2_YFRfMo3xEnE1Md4X17Jqa95N3E1a7Q" ["refresh_token"]=> string(694) "AAABAAAAvPM1KaPlrEqdFSBzjqfTGFrnaPrXWPrZOlHimbEubuR7_30VHdDxmZ_Dk5en6iiFagl-ySjHykZl5M-33l4qAIzjK1AecNfRWt6ISotbWXE9KoYxx5TO5lCPgkF7yJppUSlNoZ2nduQnWffLNGUZql8cO_YqCcAxXKFTg2fhwNt0GfpjZnME96_4C4JptBTuFFSyIl4UmByghVD83k4H32CD4ga0WOLdZx5v0fVztYWA3QxXX1pxzf7UCrh7Xq7nviWv46KDtr2SMozW1AyPVm9OPDdtL0Qbm3DMhyvUNYyJW7N8qiscmTaBLiVOmIbHVnEY_U5_s1MMdw1NfhUY6qtsbrjeyMKG5JqTx9MDnZ1_edsfIjCj29t-aGLJtmNDLJGsCAR6PSbq2bc2GqGpQatv7RtMLk7qvw2tRcz3JQ2RSrJ2tCtYcih8R8zkgUXsNvyoTSe-PdnI9eihJ-oT3gQwc_xm-6eVV_xcVdZyp3Fvp10weh5OG0LU4Lstfhe0J8MFGS5A28I_moSnF6eYSW5EVWDKjQXe5wOkifXUcW2o7A6EyAtVnombDYYiG3zd2BsovEyMm798GWNTBFZZ5szh2hpMDMtzHJy-vVYyGjVk_g7w9FzflWxfGGshIfT6lKZw8G1C9YKoE37z7z-ywj7-RC4siZr-1sqRAdii37ogAA" ["scope"]=> string(28) "Contacts.Read Contacts.Write" ["id_token"]=> string(820) "eyJ0eXAiOiJKV1QiLCJhbGciOiJub25lIn0.eyJhdWQiOiJhYzNkMWVkMS00MDdkLTQzM2YtOTk4Zi1jMzMxOGI5NmUxOTQiLCJpc3MiOiJodHRwczovL3N0cy53aW5kb3dzLm5ldC81YjVkNjRjOC03YTgxLTQ1NzctOWEyYy04OTJjNDc1Y2UxN2EvIiwiaWF0IjoxNDIwNDczMDM3LCJuYmYiOjE0MjA0NzMwMzcsImV4cCI6MTQyMDQ3NjkzNywidmVyIjoiMS4wIiwidGlkIjoiNWI1ZDY0YzgtN2E4MS00NTc3LTlhMmMtODkyYzQ3NWNlMTdhIiwiYW1yIjpbInB3ZCJdLCJlbWFpbCI6IndhcnJlbi5kb3lsZUBzeW5ldHkuY29tIiwiaWRwIjoiaHR0cHM6Ly9zdHMud2luZG93cy5uZXQvZDJjMmY2N2EtOTdjYy00N2Q5LWIxOWItNzAyMjRhNGVjYmUyLyIsInN1YiI6InZMOGlWOUxGX0U0cVg2Ty1wQUo3ZTkyODd1R1FZbUxhWWZ2cFRiX0FUZlkiLCJnaXZlbl9uYW1lIjoiV2FycmVuIiwiZmFtaWx5X25hbWUiOiJEb3lsZSIsIm5hbWUiOiJXYXJyZW4gRG95bGUiLCJ1bmlxdWVfbmFtZSI6IndhcnJlbi5kb3lsZUBzeW5ldHkuY29tIiwicHdkX2V4cCI6IjcxODQ3MDUiLCJwd2RfdXJsIjoiaHR0cHM6Ly9wb3J0YWwubWljcm9zb2Z0b25saW5lLmNvbS9DaGFuZ2VQYXNzd29yZC5hc3B4In0." ["pwd_exp"]=> string(7) "7184705" ["pwd_url"]=> string(54) "https://portal.microsoftonline.com/ChangePassword.aspx" } 
: - -> 다음> https://login.windows.net/common/oauth2/token 완벽하게 잘 작동

반환 https://login.windows.net/common/oauth2/authorize : 나는 다음과 같은 사용하여 액세스 토큰을 얻을 수있는 샘플 응용 프로그램을 내장, 푸른 AD, 셰어 개발자 사이트를 구축 나는에서 유효한 GUID와 토큰을 사용하여 연락처 API (https://outlook.office365.com/api/v1.0/me/contacts? $ ORDERBY = 표시 이름 % 20desc)

작업을 시도 할 때마다

그러나 이전에는 401

반환

사용자가 우리의 웹 사이트를 방문하여 소원 :

{ 
aud: "https://outlook.office365.com/", 
iss: "https://sts.windows.net/5b5d64c8-7a81-4577-9a2c-892c475ce17a/", 
iat: 1420469746, 
nbf: 1420469746, 
exp: 1420473646, 
ver: "1.0", 
tid: "5b5d64c8-7a81-4577-9a2c-892c475ce17a", 
amr: [ 
    "pwd" 
], 
email: "[email protected]", 
idp: "https://sts.windows.net/d2c2f67a-97cc-47d9-b19b-70224a4ecbe2/", 
altsecid: "5::1003BFFD88848B7F", 
sub: "j7C8s82th5eA9xR1FKF1x8rkAc69kwIExQSrniK2IKc", 
given_name: "Warren", 
family_name: "Doyle", 
name: "Warren Doyle", 
unique_name: "[email protected]", 
appid: "ac3d1ed1-407d-433f-998f-c3318b96e194", 
appidacr: "1", 
scp: "Contacts.Read", 
acr: "1" 
} 

그냥 우리는 다음과 달성을 목표로하고 있습니다 확인 : 내 JWT

{ 
    "allowActAsForAllClients": null, 
    "appId": "ac3d1ed1-407d-433f-998f-c3318b96e194", 
    "appMetadata": { 
    "version": 0, 
    "data": [] 
    }, 
    "appRoles": [], 
    "availableToOtherTenants": true, 
    "displayName": "CONTACTS MANAGEMENT APP", 
    "errorUrl": null, 
    "groupMembershipClaims": null, 
    "homepage": "https://chrome.uk.cloudcall.com/oAuth/oauth2.php", 
    "identifierUris": [ 
    "https://synetyplc.onmicrosoft.com" 
    ], 
    "keyCredentials": [], 
    "knownClientApplications": [], 
    "logoutUrl": null, 
    "oauth2AllowImplicitFlow": false, 
    "oauth2AllowUrlPathMatching": false, 
    "oauth2Permissions": [ 
    { 
     "adminConsentDescription": "Allow the application to access CONTACTS MANAGEMENT APP on behalf of the signed-in user.", 
     "adminConsentDisplayName": "Access CONTACTS MANAGEMENT APP", 
     "id": "f85ff53b-b153-456d-8a5d-69d9289ab9ff", 
     "isEnabled": true, 
     "origin": "Application", 
     "type": "User", 
     "userConsentDescription": "Allow the application to access CONTACTS MANAGEMENT APP on your behalf.", 
     "userConsentDisplayName": "Access CONTACTS MANAGEMENT APP", 
     "value": "user_impersonation" 
    } 
    ], 
    "oauth2RequirePostResponse": false, 
    "passwordCredentials": [ 
    { 
     "customKeyIdentifier": null, 
     "endDate": "2017-01-05T12:20:03.3224279Z", 
     "keyId": "f6fe401c-8061-47e8-8d21-fdf48841adeb", 
     "startDate": "2015-01-05T12:20:03.3224279Z", 
     "value": null 
    }, 
    { 
     "customKeyIdentifier": null, 
     "endDate": "2016-01-05T11:28:08.8654733Z", 
     "keyId": "e8a37973-bb60-40e3-b9da-3318c8cf524d", 
     "startDate": "2015-01-05T11:28:08.8654733Z", 
     "value": null 
    } 
    ], 
    "publicClient": null, 
    "replyUrls": [ 
    "https://chrome.uk.cloudcall.com/oAuth/oauth2.php" 
    ], 
    "requiredResourceAccess": [ 
    { 
     "resourceAppId": "00000002-0000-0ff1-ce00-000000000000", 
     "resourceAccess": [ 
     { 
      "id": "181aac24-028a-486e-a649-b3742c74ec71", 
      "type": "Scope" 
     } 
     ] 
    }, 
    { 
     "resourceAppId": "00000002-0000-0000-c000-000000000000", 
     "resourceAccess": [ 
     { 
      "id": "311a71cc-e848-46a1-bdf8-97ff7156d8e6", 
      "type": "Scope" 
     } 
     ] 
    } 
    ], 
    "samlMetadataUrl": null, 
    "defaultPolicy": [], 
    "extensionProperties": [], 
    "objectType": "Application", 
    "objectId": "e478cfdb-2590-41f0-8efc-adca13c6f5e4", 
    "deletionTimestamp": null, 
    "createdOnBehalfOf": null, 
    "createdObjects": [], 
    "manager": null, 
    "directReports": [], 
    "members": [], 
    "memberOf": [], 
    "owners": [], 
    "ownedObjects": [] 
} 

그리고 여기에 있습니다 : 3,691,363,210

여기 내 매니페스트 파일입니다 연락처를 동기화합니다 -> 권한 부여를 클릭하면 url을 생성 한 후 login.microsoft로 이동하여 응용 프로그램을 인증하여 해당 연락처에 액세스합니다 -> 사용자가 돌아와서 액세스 토큰을 요청합니다 -> 그런 다음 연락처 요청을 처리하고 h 응답을 andle ...

나는이

감사 워렌

+0

JWT가 약간 이상하게 보입니다 (upn, oid 등 없음). 어떤 유형의 계정을 사용하여 로그인합니까? –

+0

안녕 Jason, Microsoft 업무 계정을 사용 중입니다. –

+0

JWT : \t { typ : "JWT", alg : "없음" }. { AUD "ac3d1ed1-407d-433f-998f-c3318b96e194" ISS : "https://sts.windows.net/5b5d64c8-7a81-4577-9a2c-892c475ce17a/" IAT : 1420561624, NBF : 1420561624, EXP : 1420565524, 버전 "1.0" TID "5b5d64c8-7a81-4577-9a2c-892c475ce17a" AMR : "PWD" ] 이메일 "[email protected] .COM " IDP"https://sts.windows.net/d2c2f67a-97cc-47d9-b19b-70224a4ecbe2/ " 부"vL8iV9LF_E4qX6O-pAJ7e9287uGQYmLaYfvpTb_ATfY " GIVEN_NAME"워렌 " FAMILY_NAME" Doyle ", 이름 :"Warren D oyle ", unique_name :"[email protected] " }. [서명] –

답변

2

확인하는 데 도움이되기를 바랍니다. 그것이 문제이다. Azure의 OAuth는 Azure Active Directory 계정에서만 작동합니다.

+0

대단히 감사합니다! 나는 이제 내 응용 프로그램을 작동시킵니다. 건배 제이슨 - 빠른 질문 중 하나 : 연락처 API가 반환하는 연락처의 한도는 10000 번을 사용하여 무엇입니까?이 모든 것이 반환 되나요, 아니면 일종의 페이징이 있습니까? 감사합니다 Warren –

+0

최대 페이지 크기는 50이지만, 확인을 위해 직접 테스트하지 않았습니다. http://msdn.microsoft.com/office/office365/APi/complex-types-for-mail-contacts-calendar#UseODataqueryparametersPageresults –

관련 문제