av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

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

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

瀏覽:137日期: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:

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

標簽: 百度
主站蜘蛛池模板: 国产小视频精品 | 男女羞羞的网站 | 手机看片1 | 亚洲不卡在线观看 | 成人av在线播放 | 国产成人精品久久二区二区91 | 日韩精品不卡 | 久久久蜜臀国产一区二区 | 欧美一区二区在线观看 | 欧美一区二 | 91九色在线观看 | 综合久| 亚洲精品乱码久久久久久按摩观 | 国产乱码精品一区二区三区中文 | 精品欧美一区免费观看α√ | 密乳av| 久国久产久精永久网页 | av久久 | 欧美一区二区三区在线观看 | 成人在线视频免费播放 | 一级毛片免费 | 午夜国产在线 | 欧美男人天堂 | 国产福利91精品 | 精品国产欧美一区二区三区成人 | 国产精品久久久久久久久久了 | 日韩精品一区二区在线观看 | 亚洲国产高清在线观看 | 国产精品免费观看视频 | 久久亚洲综合 | com.国产| 日韩精品一区二 | 亚洲狠狠丁香婷婷综合久久久 | 91精品国产一区二区 | 亚洲精品九九 | 在线免费av观看 | 久久福利电影 | 99精品观看 | 一区二区三区四区在线视频 | 日韩在线播放av | 国产精品国产三级国产aⅴ入口 |