android 微信是如何實(shí)現(xiàn)即時(shí)更新好友頭像的
問題描述
微信好友的頭像肯定是做緩存的,那么好友頭像修改后,用戶這邊是如何實(shí)現(xiàn)立即就能看到修改后的頭像的呢?
問題解答
回答1:如果要做到實(shí)時(shí)更新:就需要使用推送,A修改頭像之后,通知服務(wù)端,服務(wù)端再對(duì)A的好友進(jìn)行推送通知更新A的頭像。
回答2:先拉取的肯定是頭像url啊,本地緩存是根據(jù)url做的,本地每次都拉取頭像url然后通過加載模塊去加載的時(shí)候會(huì)判斷當(dāng)前緩存的圖片是否與此url一致,不一致才會(huì)通過新的url去下載。
回答3:數(shù)據(jù)庫(kù)中保存一個(gè)字段:上次頭像修改時(shí)間.
回答4:推測(cè)一下,括號(hào)里的過程是瞎猜的:用戶A上傳新頭像→服務(wù)器處理新頭像→將新頭像URL存儲(chǔ)到用戶表的某個(gè)字段里,記載更改時(shí)間(→同步頭像到CDN→更新用戶表的頭像URL字段,記載更改時(shí)間)→服務(wù)器向在線的客戶端發(fā)推送→客戶端更新頭像。
回答5:猜測(cè)一下,可以設(shè)置一個(gè)標(biāo)識(shí)字段,默認(rèn)為0,用戶更新頭像時(shí)把它置為1,在推送消息或定期同步時(shí),同時(shí)推送這個(gè)標(biāo)識(shí)。手機(jī)在處理消息或定期同步聯(lián)系人信息的同時(shí),判斷這個(gè)標(biāo)識(shí),如果標(biāo)識(shí)為1,說明好友上傳了新頭像,這時(shí)候再GET請(qǐng)求拉取新頭像并緩存在本地,同時(shí)更新服務(wù)器端標(biāo)識(shí)為0,防止下一次同步時(shí)重復(fù)請(qǐng)求頭像。(PS:只是一點(diǎn)個(gè)人的想法。)
相關(guān)文章:
1. mysql - 分庫(kù)分表、分區(qū)、讀寫分離 這些都是用在什么場(chǎng)景下 ,會(huì)帶來哪些效率或者其他方面的好處2. javascript - 能否讓vue-cli的express修改express重啟服務(wù)3. python bottle跑起來以后,定時(shí)執(zhí)行的任務(wù)為什么每次都重復(fù)(多)執(zhí)行一次?4. javascript - 求幫助 , ATOM不顯示界面!!!!5. html5 - HTML代碼中的文字亂碼是怎么回事?6. javascript - vue2如何獲取v-model變量名7. javascript - ios返回不執(zhí)行js怎么解決?8. 前端 - 誰(shuí)來解釋下這兩個(gè) CSS selector 區(qū)別9. javascript - angular使從elastichearch中取出的文本高亮顯示,如圖所示10. python - 爬蟲模擬登錄后,爬取csdn后臺(tái)文章列表遇到的問題
