首頁  >  文章  >  後端開發  >  淺析php如何實作App常用的秒發功能_php實例

淺析php如何實作App常用的秒發功能_php實例

WBOY
WBOY原創
2016-08-17 13:02:321120瀏覽

前言

想像一下,我們平常發朋友圈的時候,N張圖片配上文字,嗖的一下就發出去了,不帶任何拖泥帶水的那種,體驗感覺好爽~。

但是我們停下來用技術手段思考一下,這可能嗎?有些2G網路最多也就幾十K網速,我們的圖片隨便一張都幾M,即使壓縮過也有幾百K,怎麼可能瞬間發出訊息呢?

現在想想,是不是有些詭異呢~

其實吧,眾多社群軟體(微博,微信)都是用了一種秒發機制。他並不是真的先去發送然後發送完畢再告訴你發送成功,而是直接告訴你發送成功,然後後台再偷偷去上傳你發的東西,所以在網速不好的時候我們會經常發現一個現象,剛開始發出的朋友圈剛開始很正常,但是過了幾分鐘後,提示我們發送失敗!這很尷尬啊,明明剛開始你什麼也沒說啊,到了最關鍵的時候你告訴我不行了..

不要被高大上的技術嚇到了,無非就是做了一些小技巧而已,真的很基礎,但是也真的很實用。

在討論技術前先聲明一些初始條件。

    1.對資料庫表結構進行了一些特殊改造: 朋友圈內容表有一個特殊的字段status, status值有兩種情況,值可以為1或2,
值為1是朋友圈未發布。 值為2是朋友圈已發布。 (暫時看不懂為什麼這樣做的同學,可以先繼續閱讀,後面會講解)

    2.此篇文章的秒發功能指的有圖片的情況下使用,因為有圖片的話,圖片上傳太慢,所以需要採用秒發機制,但是沒有圖片純文字的話,就沒太大的必要了,因為文字傳輸量很低,按照正常流程發送即可。

    3.這篇文章的程式碼是基於PhalApi框架,文法都比較簡單,有過ORM操作經驗的同學應該都看得懂

    4.這篇文章主要講解APP的秒發功能,WEB端不是特別需要這個功能,因為現代網絡足以我們的PC一次性發送很多很多張圖片(10M/s,20M/s)

大方向討論一下整個執行流程:

客戶端呼叫發佈API,服務端進行發佈內容(publish.php),如果是有圖片,那麼客戶端還要額外呼叫一個上傳API(upload.php),在這個上傳API(upload .php)還沒完成工作的時候,客戶端會直接告訴你發布成功(其實目前是沒有上傳完成,後面有一個進程在拼命幫你上傳來),然後客戶端會把你發的文字和圖片暫時拼接好顯示給你看(目前只有你能看到,你朋友圈其他人是看不到的),然後等待上傳API(upload.php)的結果/當然也可能上傳超時(通常一分鐘內會出結果),如果成功的話則順利上傳,失敗的話則報發送失敗,但是在等待結果的一分鐘之內,他會先讓你覺得你已經發送了,除非上傳失敗,才會在後來提醒你。

那麼讓我們在技術層面來分析一下這套機制吧:

當我們點上右上角的發送鍵後,有兩個進程在同時啟動,其中一個進程是幫你上傳文本並且告訴你已經發送成功啦(publish.php),另外一個進程是偷偷去上傳你發的圖片(upload.php),具體程式碼如下:

Publish.php

<&#63;php
 
//正常获取数据(文本,图片,位置信息等)
 
…
 
Code …
 
Code …
 
//进行判断,如果有图片则为未发布(status为1),无图片则为立即发布(status为2)
 
//如果有图片则通过返回标识符告诉客户端,让他赶紧去调用真实的上传逻辑upload.php,我们这只把最基本的文本上传好,再设置多一个status而已~
 
$status = ($pic_num > 0) &#63; 1 : 2;
 
//拼接入库数据
 
$where_data = array( "status"=> $status)
 
//数据入库
 
DI()->notorm-> friends ->insert($where_data);
 
&#63;>

看出玄妙了嗎?我們對入庫的status字段進行了一次判斷,分別會有1(未發布)和2(已發布)兩種情況,那麼在讀取數據的時候我們應該怎麼做呢(list.php )?

那麼展示頁面就是這樣:

Lists.php

<&#63;php
 
//code ..
 
//获取文字信息
 
Code..
 
//获取图片信息
//(它在获取当前用户pic表内的f_id(即获取朋友圈图片),最关键的地方是where条件
$data= DI()->notorm->pic->select('f_id')->where("status > 1 OR (status = 1 && u_id = {$u_id})")->->fetchAll();
 
 
//code ..
 
&#63;>

此处的where条件是秒发机制的最关键的地方:

status大于1(已发表)或者等于1(未发布),(tipsstatus在有图片的情况下默认值为1)但是属于当前用户发布的内容,都可以读出来,这就有一个很奇妙的现象,就是无论如何,我们自己发的朋友圈,自己永远是可以读出来的,但是其他人就不一定了(因为如果有图片的话,还需要去调用另外一个进程上传图片,然后在那个进程将status改为2)

那么还有最后一个关键点,就是负责上传图片的那个进程(upload.php),这个是真实上传图片的逻辑,

有几张图片,这么upload.php就会被调用几次

每次上传成功后将图片行的字段status改成2

upload.php

<&#63;php
 
//Code..
 
//把图片上传到服务器目录
 
//获取长传结果标识,更改状态
 
If(上传成功){
 
//将status改回2
 
$status_data = array("status" => 2);
 
DI()->notorm->pic->select('u_id')->where('u_id, $u_id)-->update($status_data);
 
}else{
 
Code…
 
}

经过以上的几个操作(首先是publish.php,如果有图片上传的话则调用upload.php,展示的时候是list.php)。

不知道大家看出门道没有,和我们平常写的发布功能不同的是,上传upload.php功能被独立出来了,改装后的发布publish.php会用最快的速度将你的文本内容存进数据库,并且如果有图片内容的话,他会单独调用上传API upload.php

最关键的是在显示的时候做了一些小技巧,让自己保证可以看到自己发的东西。

好了,以上就是本文的全部内容了,希望对大家学习PHP有所帮助,也请大家继续关注脚本之家。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn