我是微软Dynamcis 365 & Power Platform方面的工程师罗勇,也是2015年7月到2018年6月连续三年Dynamics CRM/Business Solutions方面的微软最有价值专家(Microsoft MVP),欢迎关注我的微信公众号 MSFTDynamics365erLuoYong ,回复341或者20190603可方便获取本文,同时可以在第一间得到我发布的最新博文信息,follow me!

Dynamics 365支持OAuth认证,我前面已经写过几篇文章了,这次我将 利用Fiddler模拟通过Dynamics 365的OAuth 2 Client Credentials认证后调用Web API 文章的方法用Microsoft Flow来实现。

登录 https://flow.microsoft.com 后,点击左边的 【My flows】 导航项,再点击右边的 【New】 > 【Scheduled - from blank】。

在出来的窗口中为Flow设置好名称,我这里设置为Repeat every 50 Minute,也就是每隔50分钟运行一次,因为获取到的Access Token默认有效期是1个小时。然后点击【Create】按钮。

在界面点击【+ New step】按钮。

我这里输入 HTTP来筛选,在筛选结果中选择第一个HTTP。

我这里设置该请求的属性如下,请求的URI和内容的说明,返回内容说明请参考我的博文:利用Fiddler模拟通过Dynamics 365的OAuth 2 Client Credentials认证后调用Web API

一般应该为步骤起个合适的名字,方法是点击步骤旁边的更多命令图标,点击 【Rename】,我这里更新为【Get Dynamics 365 Access Token】,这个名字后面的步骤中我会用到。

我这里将获取到的access token存入实体 Access Token的Name为 LuoYong_Demo_App 的记录中。首先我需要查出这条记录,然后更新它。

我继续添加一个步骤,使用Common Data Service进行筛选,选择 【List records】这种步骤。

我设置 Environment为 (Current) ,这个方便进行不同环境之前迁移,记得自己在新建Microsoft Flow的时候选择好合适的Environment。Enity Name选择合适的,然后点击【Show advanced options】

查询记录当然需要设置查询条件,也就是OData语法,设置到【Filter Query】这个字段旁,我这里设置的是 new_name eq 'LuoYong_Demo_App' ,Top Count我这里设置为1,因为我只需要找到符合记录的第一条即可,然后我将这个步骤重命名为【Get Access Token Records】。

然后再新增一个Common Data Service类别下面的【Update a record】步骤。

Environment还是设置为 (Current),Entity Name设置为要更新的实体,Record identifier就是要更新记录的主键(Guid),这个值应该是前面步骤【Get Access Token Records】 查询到的记录集中的第一条记录的new_accesstokenid字段的值,这里利用表达式来设置,点击字段值后,在右边的弹出框中切换到 Expression,输入 body('Get_Access_Token_Records')['value'][0]['new_accesstokenid'] 然后点击OK按钮。

再点击【Show advanced options】按钮设置要更新字段的值,以类似的方法设置设置Access Token字段的值为表达式: body('Get_Dynamics_365_Access_Token')['access_token'] ,

继续以类似方法为【Valid To Datetime】字段值设置为表达式 addHours(utcNow(),1) 。

设置好了以后这个步骤的设置如下:

然后点击【Save】按钮保存该Microsoft Flow,最后这个Flow如下:

然后我们来测试下,点击【Test】。

选择【I'll perform the trigger action】,然后点击【Save & Test】。

在弹出窗口中点击【Run flow】按钮。

在提示成功框中点击【See flow run activity】查看运行记录。

运行报错:

是获取access token步骤报错,报错信息如下:

{"error":"invalid_request","error_description":"AADSTS900144: The request body must contain the following parameter: 'grant_type'.\r\nTrace ID: ccb315ef-4fbb-4c3b-ad40-825dfd7c4a00\r\nCorrelation ID: 8cce0977-0d45-43cb-a0ba-9b911bd949e1\r\nTimestamp: 2019-06-03 11:07:29Z","error_codes":[900144],"timestamp":"2019-06-03 11:07:29Z","trace_id":"ccb315ef-4fbb-4c3b-ad40-825dfd7c4a00","correlation_id":"8cce0977-0d45-43cb-a0ba-9b911bd949e1"}

怎么办?可以看到请求的内容和返回,我发现是请求时候,默认请求的Content-Type是application/json,但实际上我这个请求并不是,所以需要自己赋值来覆盖默认值。

修改下这个步骤添加一个名称为Content-Type的Header,其值为 application/x-www-form-urlencoded 。

然后运行,成功。

然后我去Dynamics 365中看下:

当然我也验证了这个access token是否有效,是有效的。

你可能还会问,如果我不通过这种方式,可以直接发起HTTP请求,自带验证方式来直接调用Dynamics 365 Customer Engagement的Web API吗?答案是可以的,我这么设置,注意【Authentication】选择【Active Directory OAuth】,然后设置相应字段的值类似如下。

通过重复运行的Microsoft Flow由OAuth认证后获取Access Token并将其更新到实体记录的更多相关文章

  1. Dynamics 365触发Microsoft Flow自动生成PDF并作为附件送邮件

    我是微软Dynamics 365 & Power Platform方面的工程师罗勇,也是2015年7月到2018年6月连续三年Dynamics CRM/Business Solutions方面 ...

  2. 【Azure Developer】使用 Microsoft Authentication Libraries (MSAL) 如何来获取Token呢 (通过用户名和密码方式获取Access Token)

    问题描述 在上一篇博文<[Azure Developer]使用 adal4j(Azure Active Directory authentication library for Java)如何来 ...

  3. Web API与OAuth:既生access token,何生refresh token

    在前一篇博文中,我们基于 ASP.NET Web API 与 OWIN OAuth 以 Resource Owner Password Credentials Grant 的授权方式( grant_t ...

  4. 基于DotNetOpenAuth的OAuth实现示例代码: 获取access token

    1. 场景 根据OAuth 2.0规范,该场景发生于下面的流程图中的(D)(E)节点,根据已经得到的authorization code获取access token. 2. 实现环境 DotNetOp ...

  5. ASP.NET OAuth:access token的加密解密,client secret与refresh token的生成

    在 ASP.NET OWIN OAuth(Microsoft.Owin.Security.OAuth)中,access token 的默认加密方法是: 1) System.Security.Crypt ...

  6. Microsoft Flow 概览

    作者:陈希章 发表于 2017年12月15日 前言 纵观一下我们周围的世界,以及我们每天忙忙碌碌的工作,你会"惊奇地"发现它们都是一个事件接着一个事件发生的.例如,我每天早上起来, ...

  7. Android OAuth认证

    OAuth认证 为了安全地访问在线服务,用户需要在服务上进行身份验证,即要提供他们的身份的证明.对于一个要访问第三方服务的程序来说,安全问题甚至更复杂.不仅仅是用户需要在访问服务前要进行身份验证,而且 ...

  8. OAuth认证协议原理分析及同步消息到Twitter和Facebook使用方法

    OAuth有什么用?为什么要使用OAuth? twitter或豆瓣用户一定会发现,有时候,在别的网站,点登录后转到 twitter登录,之后转回原网站,你会发现你已经登录此网站了,这种网站就是这个效果 ...

  9. oAuth 认证

    这段时间公司开发项目用到oAuth2协议,现在做一下梳理. CORS即Cross Origin Resouce Share,跨域资源共享:是W3C为防止脚本攻击,而制定的安全标准之一,它云溪浏览器向跨 ...

随机推荐

  1. git worktree 使用笔记

    一 worktree 的基本概念和操作 再也不用克隆多个仓库啦!git worktree 一个 git 仓库可以连接多个工作目录 - walterlv的专栏 - CSDN博客 再也不用克隆多个仓库啦! ...

  2. Redis报错:ERR This instance has cluster support disabled

    异常分析从报错误的信息ERR This instance has cluster support disabled很明显看得出来,是没有启动redis集群功能,可是我项目配置的集群的配置方式,要么修改 ...

  3. Spring Boot 2.2.2.RELEASE 版本中文参考文档【3.2 - 3.10】

    Spring Boot 2.2.2.RELEASE版本中文文档持续更新中~如有需要获取参考文档文件,关注公众号JavaSo,回复“参考文档”即可. 3.2 结构化代码 Spring Boot不需要任何 ...

  4. Cobalt Strike系列教程第五章:截图与浏览器代理

    Cobalt Strike系列教程分享如约而至,新关注的小伙伴可以先回顾一下前面的内容: Cobalt Strike系列教程第一章:简介与安装 Cobalt Strike系列教程第二章:Beacon详 ...

  5. Linux 释放cache

    sysc 将所有未写的系统缓冲区写到磁盘中,包含已修改的 i-node.已延迟的块 I/O 和读写映射文件 echo 3 > /proc/sys/vm/drop_caches To free p ...

  6. kali安装vmtool后依旧无法拖拽文件,复制粘贴,解决办法

    本文链接:https://blog.csdn.net/Key_book/article/details/80310235命令行下 执行 apt-get install open-vm-tools-de ...

  7. 如何在Macbook上安装MySQL ?

    MySQL是常用的一款开源数据库,对各个平台都提供了支持,而Macbook又作为程序员的一款主力开发工具经常被使用.因此怎么在Macbook上安装MySQL进行程序开发也成了一项基本技能.下面来跟随本 ...

  8. CSAPP 2-2 整数的表示和运算

    目录 1 整数表示 1 整数表示 编码整数有2种方式: 一种只能表示非负数(大于0的数), 另一种能够表示负数.零和正数. (1) 整型数据类型: C和C++都支持有符号(默认)和无符号数, Java ...

  9. sched_yield()和nanosleep()对进程调度的影响

    关键词:sched_yield().nanosleep()等等. sched_yield()主动放弃CPU执行权,nanosleep()是睡眠一段时间后再唤醒. 1. sched_yield()实现 ...

  10. 【tf.keras】tf.keras使用tensorflow中定义的optimizer

    Update:2019/09/21 使用 tf.keras 时,请使用 tf.keras.optimizers 里面的优化器,不要使用 tf.train 里面的优化器,不然学习率衰减会出现问题. 使用 ...