2023-04-07 起网站暂时关闭,停止调用
这两天出现大量E5账户被“强制”过期,到期时间被重置为 0/0,避免影响其他账户的到期时间,所以暂时将调用关闭。
可能是滥用的太多了,对使用了本程序的E5进行了“强制”过期,还好的是留了1个月时间可以转移OD里的资源,所以大家尽快备份资源吧。
初步判断是根据以下几个原因锁定的E5。
- 根据调用服务器的IP
- 根据在AZ面板里应用设置的回调地址,也就是 https://e5.qyi.io/xxxxxxxxxxxx
所以还没有被 “过期”的童鞋,在 az面板 里将应用删除了吧,或者将回调地址删了也行。
历史
2023-01-15 : 官方将回调地址 https://e5.qyi.io/outlook/auth2/receive 设置为黑名单,填写了该地址的应用都将判断为“钓鱼”应用。关于续订程序出现授权出错问题
2023-02-17 : github将用于登录的github Apps 暂停,导致无法登录。无任何通知,就回调的时候提示被暂停,当时有发过工单询问原因,到目前(04-07)未收到回复。
2023-04-04 : 对使用了本程序的E5进行了“强制”过期。
看了下今年官方对用 续订程序 的操作来看,其实在 1-15 就开始“不满”了,进行了限制,我现在才反应过来,当时因该停止服务端的调用,减少损失。
程序于2023年01月15日更新部署教程有些许不同,请注意查看。
AZ面板中已经被禁用的应用,无法删除,需要新建一个应用。
查看应用是否被禁用:关于续订程序出现授权出错问题
由于我前端是废的,界面将就看看就行了,不影响程序~
申请office E5 开发者试用的教程
新版可续签的Office 365开发者试用订阅!E5(附自动续订的方法)
Onedrive容量 1T 修改 为5T,老帐号不删除重建
说明
- 此程序部署在我的服务器上,每隔2小时会自动调用outlook api 获取邮件列表
- 对于信息: 只会保存必要的 client_id、client_secret,其他任何内容都不会保存,
- 会读取授权的outlook账号邮箱邮件,但不会保存任何信息,仅仅是调用api。
- 请单独创建一个同域 E5 子账号进行授权,不要使用此账号进行发送、接收个人邮件,以免发生误会。
新手作代码辣鸡,估计会出现各种问题,所以还是不建议自己搭建。
项目地址:
https://github.com/luoye663/e5
使用教程
1、注册自己的api key
登录进入 azure ,登录账号使用你的e5账户 ,就是以xxx.onmicrosoft.com开头的的账户。
搜索“应用注册”
2021-03-15:
现在不能直接搜索到了,目前两种方法可以找到 应用注册
1)请搜索 “Azure Active Directory”,然后在 管理-应用注册 ,
2)或者直接点击直达链接:
https://portal.azure.com/#blade/Microsoft_AAD_IAM/ActiveDirectoryMenuBlade/RegisteredApps
点击 新注册
2023-01-15更新
和之前不同的是
1、受支持的帐户类型 ,请选择第一个,仅此组织目录(仅 xxx - 单一租户)中的帐户
2、重定向 URI (可选) 暂时不要填写。
3)点击注册后记录以下信息:
1、应用程序(客户端)ID
2、客户端密码
3、目录(租户) ID
创建客户端密码:
2021-03-07 :
最近很多同学反应授权报错 Invalid client secret is provided. 这里请注意了,客户端密码请复制 “值”,不要复制 ID。
2021-08-19:
客户端密码这里已经没有了“从不”,只能选2年。(别在意这些,谁也不知道2年后微软的策略会不会变,2年换一次密钥也不麻烦)
保存好以上2个key,一会需要用到。
配置api权限
勾选一下四个选项后,同时点击 代表XX授予管理员同意
PS: 这一步如果用的是子账号创建的api,那么这一项是灰色的,不能点击。需要登录 管理员 账号,再点击 代表XX授予管理员同意
这个时候api的配置就算完成了
2、添加key到自动订阅程序
进入 https://e5.qyi.io/
这里需要github账户登录,同样的,我只能获取你在 github中的 用户id、用户名等基础信息(邮箱获取不了),其他的任何信息也获取不到(可自行尝试注册一个github Apps测试)。
登录后进入主页面
2023-01-01 :
进入主页面后,请先获取回调地址,每个人的地址都不同,请不要泄露以及复制别人的。
这一步骤是为了减少被判定为钓鱼应用的风险。
将这个地址复制,粘贴到 azure 面板,步骤如下
新建应用
名称随意输入,只是个标识而已,描述可空。
点击 配置
填入上一步记录的
应用程序(客户端)ID、客户端密码 、租户ID
点击下一步进行配置调用时间,
- 说明:单位 秒(最低调用频率为 60 秒,最高为6小时),例如: 30-60,代表在30秒-60秒之间随机调用一次
再点击下一步,到了 授权 ,
此时会跳转到 microsoftonline Auth2.0授权页面,在这里请注意使用同一个域下的空账号(子账号)进行授权。
(因为在这一步我能获取到授权的outlook账户 邮件,但是程序不会保存,仅仅是调用api。)以免在以后发生误会。
点击 接受 后,将会跳转回自动订阅程序。
到此时,授权就完成了。
3、下一步
已经没啦~
到这里你就可以不用管了,程序会每两个小时调用一次outlook的api。
界面写得辣鸡,因为我不会前端呀~大家将就看看就行了。
过几天我会把删除功能加上,可以删除在程序里注册的账户。
交流群:959720211(已被封)
二群: 546596275
还是要说一下隐私安全问题
因为有几个读者也说到了,统一回答下
- api权限仅拥有 openid offline_access Mail.Read Mail.ReadWrite Mail.ReadBasic Mail.ReadBasic.ALL 这6个权限
- 也就是说我仅仅能读取授权账户的邮件,其他任何事都做不了,且我写的这个程序没有保存任何除key之外的信息
- 所以一开始我就说了,用子账户进行授权(空账户)及创建api,这样不涉及到 隐私及安全问题。
- 如果实在担心不想用了,azure 直接删掉api就可以了。
4、FQA
Q: 日志是空的
A: 如果是新加入的账户,请等待系统自动调用。
Q: 参数错误
A: 如果 应用id 与 密钥 都没有错误的情况下,那么创建的时候看一下 “任何组织目录(任何Azure AD目录-多租户)中的帐户和个人Microsoft 帐户(例如,Skype、Xbox)” 有没有选这个
Q: 什么时候续期
A: 最后一个月中的任意一天会进行续期,目前是微软程序检测活跃情况,人工点击“一键续期”???
Q: REST API is not yet supported for this mailbox.
A:创建子账号的时候需要给outlook许可。
Q: 显示 此订阅处于非活动状态,将很快过期
A:这个提示是少于30天就会显示,并非根据活跃情况显示的。
Q: 过期了怎么办
A: 在过期后的2个月内订阅还是可以用的,所以可以在2个月内取回数据。如果在过期1个月都还没有续订的话,那么就可以开始转移数据了。
Q: 续期历史
2020-04-28 续期一次
2020-06-26 续期一次
貌似从 6月26日开始后,基本上每天都会检测订阅,难道现在不用 人工点击“一键续期”了?
5、注意问题
- 如果是在到期一个月调用,那么请用管理员账户登录,因为这个时候除了管理员能登录outlook以外,其他的子账户都不行!
6、关闭双重验证
群友发的
6、更新日志
2020-03-04:
- 加入调用时间显示,每日 0 点清空。
2020-04-17 11:12:
- 更新完成,加入随机调用时间
- 会读取邮箱前5封邮件
2020-04-21 01:04
- 由于消息队列没有配置好,导致无法正常随机调用api问题。(已修复)
2020-04-22 23:04
- 修复新注册的童鞋没有显示日志问题。
- 在调用时间范围内重复问题。
2020-08-19
维护中......
2020-08-23
已恢复
2020-12-20
增加同一账户多应用调用
大佬 麻烦问一下怎么才能知道是否续订成功了?我在开发人员页面显示的时间每天都在减少,是到期之后才刷新时间还是每天都刷新?
续订成功都有邮件提示,只有到期时间小于30天才会开始续期。
大佬牛逼,按照大佬的教程一次性搞定!
大佬 搞个key过期提醒吗?这样失败了也会知道。
token一般不会过期,我这里是用refresh_token刷新,除非是修改了api的配置~
这个管理员账号都是小号,所以也无所谓了,就用管理员账号授权的,看到日志了,也是才用了几天,还有很久才会激活,希望大佬可以一直维持下去。
看到调用时间心理踏实了 虽然还有60多天才到期,提前登陆保持活跃 谢谢博主提供的软件 😉
已上车 感谢楼主!!
我能看到调用时间了,感谢大佬
CompactToken validation failed with reason code: 80049228.求助 这是什么原因
重新点击授权一下
大哥 你的github页面打不开了 请修复
好像又报502了 😥
正在升级~稍后~
能不能写个云函数的,自己配置调用
不好意思,暂时没时间弄呢,后面有时间我弄一个。
已经搞好了,就是看不到调用时间。
大佬 调用时间不更新的吗
能不能写个使用云函数的,自己配置调用
不报错就是正常运行吧?我看界面没变过一直就两次那个调用时间
大佬牛逼,已经用上了
保存成功后点授权就跳这个,大佬,这个要怎么解决?{"code":500,"msg":"value == null","data":null}
看一下这条评论,类型有木有选对~
https://blog.curlc.com/archives/687.html#comment-390
重新注册调整了组织类型后就成功了,大佬牛逼
无法刷新令牌怎么办呀
原始错误提示是什么呢?
大佬什么时候把日志修好。
这个要调用多久才能续期,目前还没有收到邮件。
另外我的申请时间比较早,还是 E3 开发者版试用,能使用这个续期吗?
e3好像不行吧,只有3个月有效期,我也不太确定。我上次调用3天才续期,前提是有效期低于30天。
日志我尽快弄。
授权到不是自己的网站总感觉不安全
不放心可以自己按照教程用postman手动调用。https://docs.microsoft.com/zh-cn/outlook/rest/
怎么自己搞个github Apps?
https://github.com/settings/developers
可以的 成功授权 感谢大佬
感谢大佬,辛苦了,成功授权了
虽然我已经自己调用 api 续订了,但是还是得说博主nb!
请问你调用了outlook吗
我按照官方文档拼接 Uri 调用了 OutLook 的 API ,比如获取邮件和发送邮件啥的。https://docs.microsoft.com/zh-cn/previous-versions/office/office-365-api/api/version-2.0/use-outlook-rest-api
一次就成了,感谢
为什么跟其他人一样这个报错...
看了一下评论,已经解决
报错啦 {"code":500,"msg":"value == null","data":null}
看一下这条评论,类型有木有选对~
https://blog.curlc.com/archives/687.html#comment-390
好了,谢谢 ♪(・ω・)ノ
授权失败!
错误: 未知错误,请联系管理员~
这个一般是 client_id、client_secret 填写错误导致的
博主最后一步显示这个{"code":500,"msg":"value == null","data":null}是因为什么啊
看一下这条评论,类型有木有选对~
https://blog.curlc.com/archives/687.html#comment-390
emm保存不上点击授权也没有反应_(:з」∠)_是我网的问题吗
是不是禁用js了~~~
是万恶的移动宽带 我换了电信就保存上了但是 报错{"code":500,"msg":"\n### Error updating database.
已修复,再试一次~
Thanks♪(・ω・)ノ已经好使了
感谢大佬!
谢谢博主大佬!我在想过后大佬要不要用rand时间,不然以后都是两小时的过后被微软看到会不会被提高一些新的门槛了
ojbk,后面我加上随机时间~
大佬,怎样调用多个账户的api
emm......暂时木有多key的功能,后期添加上,目前只能多注册几个github账户登录了......
楼主辛苦了,我自己也找了个demo调用。
卧槽,大佬牛逼
楼主楼主,请问保活需要调用API的时间是多久鸭,我现在每2小时调用一次API已经三天了,还是没有续期,是因为我刚刚开通,还剩八十多天的缘故嘛,是要等到少于一个月才会续期嘛 😥
那你还早呀,确实要少于一个月才会续期。
那我现在还要疯狂调用嘛,还是等到少于一个月再调用
你就挂在我的这个程序上就可以了,2小时调用一次,这个频率已经超级低了。真正用这个api的公司/个人,并发量都很大的。
请问下大佬,这个网页以后会开源吗,想把它部署到自己的服务器(同一ip疯狂部署不会被banIp吗),这样稳一点。
暂时没看见文档说访问频率多少,auth一般都是限制key访问频率,目前我这个是2小时一次,完全没问题。至于开源嘛,如果没问题以后会开的~
顺便无痕窗口添加报错
{"code":500,"msg":"nested exception is org.apache.ibatis.exceptions.TooManyResultsException: Expected one result (or null) to be returned by selectOne(), but found: 2","data":null}
make,是因为未知bug导致添加了两次key,回去一起修复~
博主,进入Azure那里是用管理员账号还是我新建的账号?
尽量用自己子账号,然后用管理员账户授权就可以啦~
博主,为什么我点“授权”之后微软的网站就一直在刷新,我点了账号也没用,过了一会儿又显示“无法登录”呀?
可能是网络问题,国内访问微软都不咋样,不行就科学上网吧。
博主,我试了一下,如果用管理员账号就可以正常授权,但是如果用子账号就会要你填更多信息,点击跳过之后它就开始一直刷新了。
能不能录一个视频我看一下是啥问题。
博主,视频上传到了
https://www.lanzous.com/xxxxx
因为网盘原因,所以压缩了一下。我还想问一下就是可以直接用管理员账号授权吗?反正我也不用那个账号收发邮件~
可以直接使用管理员账号,视频我看了(链接帮你删了),这个是你设置了安全策略导致的~
好的,感谢博主大大!那这个安全策略要怎么关闭呀?
微软的分类太多了,我也没找到。你看看这里面有没有你的账户 https://aad.portal.azure.com/#blade/Microsoft_AAD_IAM/RiskyUsersBlade ,用管理员账户看。
https://aad.portal.azure.com/#allservices 这个链接是管理安全的。
非常感谢博主大大,我添加手机号就可以了,谢谢!
最后一步,点击授权出现 {"code":500,"msg":"value == null","data":null}
看了下日志,奇怪的错误,主要是因为api返回的状态码不对,先记录下,等一起修复......你再试一下,两个参数一定要填对啊~
我用子号也出现这个问题,直接用管理员账号可以了
我好像也出现了这个问题,不过用管理员账号好像也没有成功
找到错误原因:登录Azure - 应用注册,新注册的时候,名称随意取一个之后,在下面能看到【受支持的账户类型】 应当把账户类型选择最后一个任何组织目录。我之前是因为忽略了这个,现在已经成功授权了
我也是同样的错误,用你说的办法,改了权限就能用了。多谢!
最后一步,添加填入上一步记录的 应用程序(客户端)ID、客户端密码
client_id ->应用程序(客户端)ID
client_secret->客户端密码
这里错误。
我都错 😥 ,已修复~
感谢教程!但是好像网页报错了 😕 ,没法添加id和key
我都错 😥 ,已修复~
博主,我登录https://e5.qyi.io/user/home这个网址的时候,有FreeMarker template error。没办法登录授权
我都错 😥 ,已修复~
https://e5.qyi.io/user/home登陆上去已经出现FreeMarker template error
我都错 😥 ,已修复~
打开来报错,Edge和Firefox都试过了。FreeMarker template error (DEBUG mode; use RETHROW in production!):The following has evaluated to null or missing:==> client_id [in template
我都错 😥 ,已修复~
报错了。。不能添加了
大佬牛逼
貌似挂了?
辛苦了,谢谢! 😉 😀
代表管理员同意那里是灰的 是需要给这个账号管理员权限吗
不用给这个账户管理员权限,但是可能需要你登录管理员的账户,然后进入 应用注册 里面给授权一下,明天我试试用子账号创建api。
试了试需要登录管理员在同样界面给予同意就行了 博主的这个https://e5.qyi.io/user/home现在是还在维护不能用是吧 辛苦博主了~
可以访问的呀,因为套了cf,可能个别地方访问特别慢。
网站报错来着
FreeMarker template error (DEBUG mode; use RETHROW in production!):The following has evaluated to null or missing:==> client_id [in template
我都错 😥 ,已修复~
这个现在只能用主账号创建API,还没法用子账号吧?
可以用子账号创建,但是需要登录管理员账户点击 授权(也是在 应用注册 这里)。
搞定子账号了。像博主说的,先用子账号创建,之后主账号授权就行了。万分感谢!
站长辛苦!
2020-03-04 13:05:29,失败,更新数据库时发现有重复的key。请问这是哪里操作不当造成?
{"code":500,"msg":"nested exception is org.apache.ibatis.exceptions.TooManyResultsException: Expected one result (or null) to be returned by selectOne(), but found: 3","data":null}
你的日志时间是多少,我看一下
2020-03-04 13:05:29,谢谢
刚刚看了日志,部分成功,部分失败。
2020-03-05 11:03:05 失败 更新数据库时发现有重复的key
2020-03-05 11:02:44 失败 更新数据库时发现有重复的key
2020-03-05 09:03:02 失败 更新数据库时发现有重复的key
2020-03-05 09:02:40 失败 更新数据库时发现有重复的key
2020-03-05 09:02:40 失败 更新数据库时发现有重复的key
中午的时候我也发现了,等一会你再看看会不会出现这个错误。
2020-03-05 19:02:38 失败 无法刷新令牌!code:2
2020-03-05 18:01:10 成功 ok
2020-03-05 17:02:36 成功 ok
2020-03-05 16:01:22 成功 ok
2020-03-05 15:04:18 成功 ok
2020-03-05 14:01:19 成功 ok
2020-03-05 13:02:45 成功 ok
2020-03-05 12:01:13 成功 ok
本以为成功了,结果19:02又一次新报错。谢谢大佬
我研究下,晚点修复~
首评?
看来是第二
熬夜党的胜利哎,感谢站长,给力哦,辛苦了