久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

java - web端百度網盤的一個操作為什么要分兩次請求服務器, 有什么好處嗎

瀏覽:155日期:2022-09-28 14:35:23

問題描述

以 文件重命名 為例:

當完成重命名操作提交會到這個地址 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元素

問題: 直接訪問重命名接口不行嗎? 為什么要這么設計, 好處是什么?

問題解答

回答1:

你已經說的很清楚了啊,還有什么不明白的?

第一次就是向服務器發起改名申請。服務器就開始任務。后面的輪詢都是在查詢任務是否完成,完成了前端做相應操作,萬一失敗了,前端還要做回滾操作。

回答2:

猜一下原因:極端情況下, 操作可能會耗時很久, 無法立即返回. 在操作完成的時候, socket鏈接可能已經斷開, 無法獲取到最終的結果. 設計成任務隊列的方式, 能保證客戶端獲取到最終的結果.

回答3:

除了上面的一些考慮,可能還有一個很重要的原因,那就是并發壓力。做成異步,能很好解決并發

標簽: 百度
主站蜘蛛池模板: 成人欧美在线视频 | 国产精品成人在线观看 | 韩日一区 | 久热免费在线 | 超碰免费在| 美女久久 | 在线观看亚洲大片短视频 | 综合在线视频 | 国产婷婷精品av在线 | 免费毛片网 | 91免费观看视频 | 成人精品网站在线观看 | 91观看在线视频 | 第四色影音先锋 | 日本a在线 | 免费毛片一区二区三区久久久 | 正在播放国产精品 | 精品久久久久久久久久久久 | 欧美成人一区二区三区片免费 | 精品三级在线观看 | 男人天堂网站 | 日韩无| 欧美成人在线免费观看 | 欧美精品一区二区蜜臀亚洲 | 亚洲欧美日韩在线 | 久久精品影视 | 国产日韩欧美一区二区在线观看 | 在线国产视频 | 国产精品国产三级国产aⅴ 精品91 | 99久久久久久久久 | 欧美专区在线观看 | 日韩成人精品 | av免费观看网站 | 亚洲精品在线播放 | 国产一区二区综合 | 日韩三级电影免费观看 | 国产精品成人在线观看 | 日韩精品在线播放 | 国产高清免费视频 | 黄色高清视频 | 在线观看免费黄色片 |