以 文件重命名 为例:
当完成重命名操作提交会到这个地址 https://pan.baidu.com/api/filemanager
返回如下结果
{
"errno": 0,
"info": [],
"request_id": 88137407060055336,
"taskid": 307843054247316
}
可以联想到在server端建立了一个task, 并返回了taskid让客户端后续取状态来更新ui
客户端轮训服务器的接口 https://pan.baidu.com/share/taskquery
来获取状态, 1秒一次请求, 服务器端返回结果如下: 分几种情况我总结了一下
#进行中的返回值
{
"errno": 0,
"request_id": 88137707954758994,
"task_errno": 0,
"status": "pending"
}
#进行中
{
"errno": 0,
"request_id": 88137707954758994,
"task_errno": 0,
"status": "running"
}
#操作成功的返回值
{
"errno": 0,
"request_id": 88138584419582326,
"task_errno": 0,
"status": "success",
"list": [
{
"from": "/test1/我的照片",
"to": "/test1/我的照片2"
}
],
"total": 1
}
当 status 为success时候, 则轮询结束, 更新UI元素
问题: 直接访问重命名接口不行吗? 为什么要这么设计, 好处是什么?
Vous avez été très clair. Y a-t-il autre chose que vous ne comprenez pas ?
La première fois consiste à lancer une demande de changement de nom sur le serveur.
Le serveur lancera la tâche.
L'interrogation suivante consiste à vérifier si la tâche est terminée, et le front-end effectuera les opérations correspondantes une fois terminée. En cas d'échec, le front-end effectuera également les opérations de restauration.
Devinez la raison : dans des cas extrêmes, l'opération peut prendre beaucoup de temps et ne peut pas être renvoyée immédiatement. Une fois l'opération terminée, le lien socket peut avoir été déconnecté et le résultat final ne peut pas être obtenu. , cela peut garantir que le client obtient le résultat final.
En plus des considérations ci-dessus, il peut y avoir une autre raison très importante, à savoir la pression de la concurrence. Rendu asynchrone, il peut résoudre la concurrence