最近e5订阅很火,但是玄学的续订方式也让人摸不着头脑,有的人说挂个oneindex就续订了,有的人说所有第三方程序都挂了一遍也没续订,所以有人按照微软的官方文档写了一个刷api的脚本,原理很简单,就是重复调用microsoft graph的api,一次调用10个api,5个onedrive的api还有4个outlook的api,剩下一个是组的api,调用一次后延时等待五分钟再重复调用。
但是原作者的代码需要在服务器上运行,成本较高。后来又有一位大佬找到了不用服务器也可以运行的的办法。而后者的方法是建立在前者的基础上的,因此我将他们的教程融合了起来,并对其中的个别词语进行了微调。

最后有视频教程

E5自动续期程序,但是不保证续期

  • 设置了周六日(UTC时间)不启动自动调用,周1-5每6小时自动启动一次 (修改看教程)
  • 调用api保活:
  • 查询系api:onedrive,outkook,notebook,site等
  • 创建系api: 自动发送邮件,上传文件,修改excel等

步骤

准备工具:

  • E5开发者账号(非个人/私人账号)

  • 管理员号 ———— 必选

  • 子号 ———— 可选 (不清楚微软是否会统计子号的活跃度,想弄可选择性补充运行)

  • rclone软件,下载地址 前往下载

    步骤大纲:

  • 微软方面的准备工作 (获取应用id、密码、密钥)

  • GIHTHUB方面的准备工作 (获取Github密钥、设置secret)

  • 试运行

微软方面的准备工作

第一步,注册应用,获取应用id、secret

首先去 E5应用注册 注册一个应用

先用e5管理员账号登录网站,然后在主页找到Azure Active Directory点进去

OFFICE365 E5调用api使E5开发者续订 修复版AutoApi (不使用服务器)

再在左侧目录找到点击应用注册

OFFICE365 E5调用api使E5开发者续订 修复版AutoApi (不使用服务器)

再点上方的新注册就会跳出一个新建应用的界面,应用名字随意填写,然后选择任何组织目录(任何 Azure AD 目录 – 多租户)中的帐户,重定向url选web,填入http://localhost:53682/,最后点注册即可

OFFICE365 E5调用api使E5开发者续订 修复版AutoApi (不使用服务器)

复制应用程序(客户端)ID到记事本备用(获得了应用程序ID!) 记录ID 下面会用到

OFFICE365 E5调用api使E5开发者续订 修复版AutoApi (不使用服务器)

点击左边管理的证书和密码,点击+新客户端密码,点击添加,复制新客户端密码的值 记录这个值 下面会用到

OFFICE365 E5调用api使E5开发者续订 修复版AutoApi (不使用服务器)

OFFICE365 E5调用api使E5开发者续订 修复版AutoApi (不使用服务器)

点击左边管理的API权限,点击+添加权限,点击常用Microsoft API里的Microsoft Graph(就是那个蓝色水晶), 点击委托的权限,然后在下面的条例搜索以下12个 最后点击底部添加权限

1
2
3
4
5
6
7
Calendars.ReadWrite	、	Contacts.ReadWrite	、	Directory.ReadWrite.All

Files.ReadWrite.All 、 MailboxSettings.ReadWrite 、 Mail.ReadWrite

Mail.Send 、 Notes.ReadWrite.All 、 People.Read.All

Sites.ReadWrite.All 、 Tasks.ReadWrite 、 User.ReadWrite.All

OFFICE365 E5调用api使E5开发者续订 修复版AutoApi (不使用服务器)

OFFICE365 E5调用api使E5开发者续订 修复版AutoApi (不使用服务器)

添加完自动跳回到权限首页,点击代表授予管理员同意

OFFICE365 E5调用api使E5开发者续订 修复版AutoApi (不使用服务器)

现在 把前期准备的rclone软件掏出来
打开 rclone.exe 所在文件夹,shift+右键,在此处打开powershell,输入下面修改后的内容,回车后跳出浏览器,登入e5账号,点击接受,回到powershell窗口,看到一串东西。(MAC打开终端,一个道理)

1
./rclone authorize "onedrive" "应用程序(客户端)ID 去上面找,让你保存的" "应用程序密码 去上面找,让你保存的"

执行完毕后 找到 “refresh_token”:” ,从双引号开始选中到 “,”expiry”:2021 为止(就是refresh_token后面双引号里那一串,不要双引号),如下图,右键复制保存(获得了微软密钥)

OFFICE365 E5调用api使E5开发者续订 修复版AutoApi (不使用服务器)

GITHUB方面的准备工作

Github项目地址

第一步,fork本项目

登陆/新建github账号,回到本项目页面,点击右上角fork本项目的代码到你自己的账号,然后你账号下会出现一个一模一样的项目,接下来的操作均在你的这个项目下进行。

第二步,新建github密钥

进入你的个人设置页面 (右上角头像 Settings,不是仓库里的 Settings),选择 Developer settings -> Personal access tokens -> Generate new token

设置名字为 GH_TOKEN , 然后勾选repo,点击 Generate token ,最后复制保存生成的github密钥(获得了github密钥,一旦离开页面下次就看不到了!)

第三步,新建secret

依次点击页面上栏右边的 Setting -> 左栏 Secrets -> 右上 New repository secret,新建6个secret: GH_TOKEN、MS_TOKEN、CLIENT_ID、CLIENT_SECRET、CITY、EMAIL

(以下填入内容注意前后不要有空格空行)

GH_TOKEN

1
github密钥 (第三步获得),例如获得的密钥是abc...xyz,则在secret页面直接粘贴进去,不用做任何修改,只需保证前后没有空格空行

MS_TOKEN

1
微软密钥(第二步获得的refresh_token)

CLIENT_ID

1
应用程序ID (第一步获得)

CLIENT_SECRET

1
应用程序密码 (第一步获得)

CITY

1
城市 (例如Beijing,自动发送天气邮件要用到)

EMAIL

1
收件邮箱 (自动发送天气邮件要用到)

试运行

点击上栏中间的Action进入运行日志页面,中间应该有个绿色按钮(I understand my workflow…),点击。

自动刷新后,会看到左边有三个流程,一个Run api.Read,一个Run api.Write,一个Update Token。

1
2
3
4
工作流程说明
Run api.Write:创建系api,一天自动运行一次
Run api.Read: 查询系api,每6小时自动运行一次
Update Token: 微软密钥更新,每2天运行一次

这三个流程名字前面应该是都有黄色感叹号的

分别点进去,然后会看到有个黄条(this schedule was disabled……),点击 enable workflow 按钮,三个流程都要按这个!

(不确定是否都需要进行这一步,我自己做视频教程的时候发现有的。如果你没有,直接忽略并往下进行,能正常运行就可以了 )

点击两次右上角的星星(star,就是fork按钮的隔壁)启动action

再点击上面的Action选择Run api.Read或者api.Write流程 -> build -> run api 就能看到每次的运行日志

(必需点进去build里面的run api.XXX看下,api有没有调用到位,操作有没有成功,有没有出错)

image

再点两次星星,查看是否能再次成功运行

然后点击Action里的 update token 流程 -> build -> update token ,日志里显示“微软密钥上传成功”。

同时,依次点击页面上栏右边的 Setting -> 左栏 Secrets(也就是Github方面准备的第三步的secret页面),应该能看到MS_TOKEN显示刚刚update了

(这一步是为了保证重新上传到secret的token是正确的)

教程最后

程序会自行按计划启动,不必操心。

1
2
 但是github更新了防止薅羊毛的规则,如果仓库60天无任何变动,将会暂停Action,但是会发邮件通知,所以请留意邮箱,收到邮件请上来手动启动一下action。
(我还没有收到过此邮件,但是据说邮件里会有启动链接,或者上来按两次星星按钮就行)

附上教程视频

{bilibili bvid=”BV185411n7Mq”/}

教程完