如何使用python在Microsoft Graph中显示用户图像

问题描述 投票:0回答:1

我尝试使用GET https://graph.microsoft.com/v1.0/me/photo/$value获取用户的图像/照片,但仅返回HTTP 200状态代码。如何获取二进制数据?

我也尝试过按照content.property中的建议使用similar post,但获取.format不是字典的属性。

@app.route("/photo")
def get_photo():
    token = _get_token_from_cache(app_config.SCOPE)
    if not token:
        return redirect(url_for("login"))
    photo = requests.get(app_config.PHOTO_ENDPOINT,  
            headers={'Authorization': 'Bearer ' + token['access_token']})
    print(photo.status_code)
    return photo
python rest api photo azure-ad-graph-api
1个回答
0
投票

获取个人资料照片,并选择保存本地副本。返回原始照片数据,HTTP状态代码,内容类型和保存的文件名的元组。请参考此sample

def profile_photo(session, *, user_id='me', save_as=None):
    """Get profile photo, and optionally save a local copy.
    session = requests.Session() instance with Graph access token
    user_id = Graph id value for the user, or 'me' (default) for current user
    save_as = optional filename to save the photo locally. Should not include an
              extension - the extension is determined by photo's content type.
    Returns a tuple of the photo (raw data), HTTP status code, content type, saved filename.
    """

    endpoint = 'me/photo/$value' if user_id == 'me' else f'users/{user_id}/$value'
    photo_response = session.get(api_endpoint(endpoint),
                                 stream=True)
    photo_status_code = photo_response.status_code
    if photo_response.ok:
        photo = photo_response.raw.read()
        # note we remove /$value from endpoint to get metadata endpoint
        metadata_response = session.get(api_endpoint(endpoint[:-7]))
        content_type = metadata_response.json().get('@odata.mediaContentType', '')
    else:
        photo = ''
        content_type = ''

    if photo and save_as:
        extension = content_type.split('/')[1]
        filename = save_as + '.' + extension
        with open(filename, 'wb') as fhandle:
            fhandle.write(photo)
    else:
        filename = ''

    return (photo, photo_status_code, content_type, filename)
© www.soinside.com 2019 - 2024. All rights reserved.