博客地址:http://blog.csdn.net/FoxDave

目前这个东西还在预览阶段,所以不推荐在正式生产环境中使用。

我们可以使用Microsoft Graph接口来构建强大的解决方案来访问Office 365和其他微软服务的数据。为了使SPFx的解决方案能够连接到Microsoft Graph,你需要注册一个Azure AD应用程序并完成授权流。为了简化这个过程,GraphHttpClient出现了,通过使用它,你可以直接调用Microsoft Graph接口而不需要其他额外的设置。

GraphHttpClient类是什么?

GraphHttpClient类作为SharePoint Framework的一部分包含在其中。它的工作方式跟HttpClient类似,你可以使用它来跟第三方应用程序接口通信。该类会自动确保你对Microsoft Graph的请求拥有有效的访问令牌和必须的请求头。当你发出一个GET或POST请求时,GraphHttpClient会验证它是否拥有一个有效的访问令牌,如果没有它将会从内部API获取一个并保存下来用于接下来的请求。

下面的代码演示了使用GraphHttpClient类访问Microsoft Graph接口。

// ...
import { GraphHttpClient, GraphClientResponse } from '@microsoft/sp-http'; export default class MyApplicationCustomizer
extends BaseApplicationCustomizer<IMyApplicationCustomizerProperties> { // ... @override
public onRender(): void {
this.context.graphHttpClient.get("v1.0/groups?$select=displayName", GraphHttpClient.configurations.v1)
.then((response: GraphClientResponse): Promise<any> => {
return response.json();
})
.then((data: any): void => {
// ...
});
}
}

向Microsoft发送请求,需要以下几个步骤:

1. 从@microsoft/sp-http包引入GraphHttpClient和GraphClientResponse模块。

2. 使用this.context.graphHttpClient属性作为该类的实例来发送请求道Microsoft Graph。

3. 指定想要调用的Microsoft Graph API(从版本开始,不带前面的斜杠/)。

4. 你还可以指定额外的请求头,这些会跟GraphHttpClient设置的默认头进行合并。

使用GraphHttpClient类需要考虑的事情

GraphHttpClient类提取了授权流和访问令牌的管理,使得访问Microsoft Graph更加便捷。由于现在正处于开发预览版,在使用它的过程中你需要注意以下一些事情。

仅用来访问Microsoft Graph接口

使用GraphHttpClient类仅能访问Microsoft Graph。URL必须如前所述指定为以Microsoft Graph API版本开头,加上API操作的URL,任何不符合此条件的URL都会返回一个错误。

权限

GraphHttpClient使用Office 365 SharePoint Online的Azure AD应用程序来获取有效的访问令牌,该令牌代表当前用户。获取来的访问令牌有两个权限:读写所有组(Group.ReadWrite.All)和读取所有使用率报告(Reports.Read.All)。

注意仅有这两个权限,因此如果你需要其他的权限,你就需要使用ADAL JS with implicit OAuth flow来代替它。

访问令牌通过内部API获得

GraphHttpClient通过发起一个web请求到/_api/SP.OAuth.Token/Acquire端点来获得有效的访问令牌。对外是不公开的,也就是说你是无法在你的解决方案中直接与它通信的。

GraphHttpClient概述的更多相关文章

  1. 【AR实验室】ARToolKit之概述篇

    0x00 - 前言 我从去年就开始对AR(Augmented Reality)技术比较关注,但是去年AR行业一直处于偶尔发声的状态,丝毫没有其"异姓同名"的兄弟VR(Virtual ...

  2. Recurrent Neural Network系列1--RNN(循环神经网络)概述

    作者:zhbzz2007 出处:http://www.cnblogs.com/zhbzz2007 欢迎转载,也请保留这段声明.谢谢! 本文翻译自 RECURRENT NEURAL NETWORKS T ...

  3. Swift3.0服务端开发(一) 完整示例概述及Perfect环境搭建与配置(服务端+iOS端)

    本篇博客算是一个开头,接下来会持续更新使用Swift3.0开发服务端相关的博客.当然,我们使用目前使用Swift开发服务端较为成熟的框架Perfect来实现.Perfect框架是加拿大一个创业团队开发 ...

  4. .Net 大型分布式基础服务架构横向演变概述

    一. 业务背景 构建具备高可用,高扩展性,高性能,能承载高并发,大流量的分布式电子商务平台,支持用户,订单,采购,物流,配送,财务等多个项目的协作,便于后续运营报表,分析,便于运维及监控. 二. 基础 ...

  5. [C#] 进阶 - LINQ 标准查询操作概述

    LINQ 标准查询操作概述 序 “标准查询运算符”是组成语言集成查询 (LINQ) 模式的方法.大多数这些方法都在序列上运行,其中的序列是一个对象,其类型实现了IEnumerable<T> ...

  6. 【基于WinForm+Access局域网共享数据库的项目总结】之篇一:WinForm开发总体概述与技术实现

    篇一:WinForm开发总体概述与技术实现 篇二:WinForm开发扇形图统计和Excel数据导出 篇三:Access远程连接数据库和窗体打包部署 [小记]:最近基于WinForm+Access数据库 ...

  7. Java消息队列--JMS概述

    1.什么是JMS JMS即Java消息服务(Java Message Service)应用程序接口,是一个Java平台中关于面向消息中间件(MOM)的API,用于在两个应用程序之间,或分布式系统中发送 ...

  8. [AlwaysOn Availability Groups]健康模型 Part 1——概述

    健康模型概述 在成功部署AG之后,跟踪和维护健康状况是很重要的. 1.AG健康模型概述 AG的健康模型是基于策略管理(Policy Based Management PBM)的.如果不熟悉这个特性,可 ...

  9. μCos-ii学习笔记1_概述

    一.μCos-ii _概述 网上关于μCosii的文章多不胜数,本人学习的过程中也参考了很多人的理解和想法,看的是卢有亮老师的<嵌入式实时操作系统-μC/OS原理与实践>(第2版),同时也 ...

随机推荐

  1. 第四篇——Struts2的引入多个配置文件

    引入多个配置文件 在Struts2配置文件中使用include可引入多个配置文件. 项目实例 1.项目结构 2.pom.xml <project xmlns="http://maven ...

  2. Linux hostname设置,静态ip设置,hostname与静态ip相互映射

    1,hostname设置 永久设置: centos 7 下,切换到root 用户 vi /etc/hostname 输入要修改的hostname centos 6或者其他linux 系统,可能在/et ...

  3. xml 和 json 序列化忽略字段

    xml 和 json 序列化忽略字段: @JsonIgnore @XmlTransient

  4. 使用Java或 JavaScript获取 方括号中的内容

    1.使用Java获取方括号中的内容 String str = "[你]们,[我]们,[他]们,都要[好好学习,天天敲代码]"; Pattern p = Pattern.compil ...

  5. HTTP的简单的解析

    HTTP 中文全称为超文本传输协议是一种为分布式,合作式,多媒体信息系统服务,面向应用层的协议.它是一种通用的,不分状态(stateless)的协议,除了诸如名称服务和分布对象管理系统之类的超文本用途 ...

  6. Odd Gnome【枚举】

    问题 I: Odd Gnome 时间限制: 1 Sec  内存限制: 128 MB 提交: 234  解决: 144 [提交] [状态] [命题人:admin] 题目描述 According to t ...

  7. Lintcode175-Revert Binary Tree-Easy

    175. Invert Binary Tree Invert a binary tree. Example Example 1: Input: {1,3,#} Output: {1,#,3} Expl ...

  8. 安卓外派(Android外派)提供安卓程序员外派业务(北京动点,可签合同)

    北京动点飞扬长年提供安卓工程师外派业务. 平均技术情况如下: 1.2~3年以上Android平台开发经验 2.熟练掌握java技术,熟悉面向对象编程设计 3.熟悉Android应用开发框架及Activ ...

  9. spring-cloud-config-server——Environment Repository

    参考资料: https://cloud.spring.io/spring-cloud-static/spring-cloud-config/1.4.0.RELEASE/single/spring-cl ...

  10. jquery 判断元素是否可见

    if($('#progress_bar').is(":visible")){ $('#progress_bar').hide(); }