bufferphp
Ⅰ 關於php配置文件中output_buffering選項的問題
默認情況下,php buffer是開啟的,而且該buffer默認值是4096,即4kb。你可以通過在php.ini配置文件中找到output_buffering配置.當echo,print等輸出用戶數據的時候,輸出數據都會寫入到php output_buffering中,直到output_buffering寫滿,會將這些數據通過tcp傳送給瀏覽器顯示。你也可以通過ob_start()手動激活php output_buffering機制,使得即便輸出超過了4kb數據,也不真的把數據交給tcp傳給瀏覽器,因為ob_start()將php buffer空間設置到了足夠大。只有直到腳本結束,或者調用ob_end_flush函數,才會把數據發送給客戶端瀏覽器。
Ⅱ php 怎麼使用 flatbuffer
在Android應用程序中使用Flatbuffers的最簡單方法:
JSON數據在應用程序之外的某個地方被轉換成FlatBuffer格式的文件(例如,將二進制數據以文件的形式提交,還可以從API直接返回FlatBuffer二進制文件)。
在flatc (FlatBuffer編譯器)的幫助下,手工生成數據模型(java類)。
JSON文件存在一定的局限性(不能使用null欄位,日期格式也被解析為字元串)。
將來,我們或許會提出更復雜的解決方案。
FlatBuffers編譯器
首先,我們需要flatc,即flatbuffers編譯器。該編譯器可以從Google所屬的源代碼構建,源代碼位於Flatbuffers資源庫中。我們下載並克隆它。整個構建過程在FlatBuffers構建文檔中都做了描述。如果你是Mac用戶的話,需要這樣來構建:
在\{extract directory}\build\XcodeFlatBuffers.xcodeproj路徑下,打開已下載的源代碼。
點擊Play按鈕或⌘ + R,運行flatc scheme(默認情況下應該是被選中的)。
flatc可執行文件就會在項目的根目錄下出現。
現在,我們可以使用schema編譯器了,該編譯器能夠把給定的schema(在Java、C#、python、GO和C++語言中的schema)生成為模型類,還可以把JSON轉換成Flatbuffer的二進制文件。
Schema文件
接著,我們必須准備schema文件,該文件定義了要進行序列化和反序列化的數據結構。這個schema將用於flatc創建Java模型,把JSON轉換成FlatBuffers的二進制文件。
Ⅲ php分頁,就是運行一個PHP程序的時候,在一定條件下要跳轉到另一個PHP程序!
通過在php里輸出javascript的跳轉實現最簡單:
<?php
$t=1;
if($t>0){//如果t大於0
echo '<script>';
echo 'location.href="abc.php"';//跳轉到abc.php
echo '</script>';
}else
echo '不跳轉';
?>
你可以網路hi我一下,我基本在線
Ⅳ PHP里的output_buffering 怎麼開啟
在PHP.INI可以設置以下與輸出緩沖有關的:
名稱 默認值 作用范圍 修正記錄
output_buffering "0" PHP_INI_PERDIR
output_handler NULL PHP_INI_PERDIR 自 PHP 4.0.4 起可用
implicit_flush "0" PHP_INI_ALL 在 PHP <= 4.2.3 版本中是 PHP_INI_PERDIR
簡單解釋如下:
output_buffering boolean/integer
該選項設置為 On 時,將在所有的腳本中使用輸出控制。如果要限制輸出緩沖區的最大值,可將該選項設定為指定的最大位元組數(例如 output_buffering=4096)。從PHP 4.3.5 版開始,該選項在 PHP-CLI 下總是為 Off。
output_handler string
該選項可將腳本所有的輸出,重定向到一個函數。例如,將 output_handler 設置為 mb_output_handler() 時,字元的編碼將被修改為指定的編碼。設置的任何處理函數,將自動的處理輸出緩沖。
注意: 不能同時使用 mb_output_handler() 和 ob_iconv_handler(),也不能同時使用 ob_gzhandler() 和 zlib.output_compression。
注意: 只有內置函數可以使用此指令。對於用戶定義的函數,使用 ob_start()。
implicit_flush boolean
默認為 FALSE。如將該選項改為 TRUE,PHP 將使輸出層,在每段信息塊輸出後,自動刷新。這等同於在每次使用 print()、echo() 等函數或每個 HTML 塊之後,調用 PHP 中的 flush() 函數。
不在web環境中使用 PHP 時,打開這個選項對程序執行的性能有嚴重的影響,通常只推薦在調試時使用。在 CLI SAPI 的執行模式下,該標記默認為 TRUE。
參見 ob_implicit_flush()。
設置了肯定會有用的,除非你修改的PHP.INI位置不是系統使用的那個,比如一般是C::\WINDOWS\PHP.INI,當然可以設置到其它地方。另外控制台程序是不緩沖的。
另外,你還可以在程序裡面控制輸出緩沖,請參考手冊裡面的「CXIV. Output Control 輸出控制函數」那一章,主要有如下函數:
flush -- 刷新輸出緩沖
ob_clean -- Clean (erase) the output buffer
ob_end_clean -- Clean (erase) the output buffer and turn off output buffering
ob_end_flush -- Flush (send) the output buffer and turn off output buffering
ob_flush -- Flush (send) the output buffer
ob_get_clean -- Get current buffer contents and delete current output buffer
ob_get_contents -- Return the contents of the output buffer
ob_get_flush -- Flush the output buffer, return it as a string and turn off output buffering
ob_get_length -- Return the length of the output buffer
ob_get_level -- Return the nesting level of the output buffering mechanism
ob_get_status -- Get status of output buffers
ob_gzhandler -- ob_start callback function to gzip output buffer
ob_implicit_flush -- Turn implicit flush on/off
ob_list_handlers -- List all output handlers in use
ob_start -- Turn on output buffering
output_add_rewrite_var -- Add URL rewriter values
output_reset_rewrite_vars -- Reset URL rewriter values
例子程序:
<?php
ob_start();
echo "Hello\n";
setcookie("cookiename", "cookiedata");
ob_end_flush();
?>
Ⅳ protocol buffer php效率好嗎
沒字paramecium字意思草履蟲 草履蟲種身體圓筒形原物細胞構單細胞物雌雄同體見尾草履蟲體180—280微米變形蟲壽命短計算壽命間晝夜左右身體形狀平面角度看像倒放草鞋底叫做草履蟲 草履蟲Paramecium纖毛綱代表種原物代表種草履蟲淡水般池沼河都采世界已知22種見草履蟲(180~300微米)、雙核草履蟲(80~170微米伸縮泡2兩核)、核草履蟲(180~310微米3伸縮泡核泡型3~12)、綠草履蟲(體80~150微米細胞質內綠藻共見光處培養通體呈綠色核1緻密型) 、草履蟲見者 草履蟲般呈圓筒形前端鈍圓端寬略尖形狀似倒置草鞋名草履蟲全身滿縱行排列纖毛纖毛鞭毛結構基本相同蟲體表面表膜由3層膜組起緩沖保護作用面細胞質化內質與外質每根纖毛位於表膜基體發整表膜基體由縱橫連接纖維連接中國起協調纖毛作用 表膜外質排桿狀囊泡結構與表膜垂直排列叫做刺絲泡口於表膜蟲體遇刺激刺絲泡射其內容物遇水形細絲用5%亞甲基藍、稀醋酸或墨水刺激見放刺絲般認刺絲泡具防衛捕食作用 種身體、圓筒形原物見尾草履蟲體80~300微米身體形狀平面角度看像倒放草鞋底叫做草履蟲草履蟲全身由細胞組身體表麵包著層膜膜密密著許纖毛靠纖毛劃水運身體側條凹入溝叫口溝相於草履蟲嘴巴口溝內密纖毛擺能水細菌機碎屑作食物擺進口溝再進入草履蟲體內供其慢慢消化吸收殘渣由叫肛門點孔排草履蟲靠身體外膜吸收水氧氣排二氧化碳見草履蟲具兩細胞核:核主要營養代謝起重要作用核主要與殖作用關 草履蟲營吞噬營養較復雜消化細胞器由蟲體近前端始條口溝斜著伸向身體部口溝末端與表膜相連處形胞口面連著漏斗形胞咽食物(細菌、物腐爛機物等)通口溝處纖毛擺進入胞口胞咽端積聚泡細胞質包裹脹形食物泡固定路徑流與溶酶體融合進行消化能消化殘渣由身體部胞肛排蟲體外 內、外質間2伸縮泡體前部體部每伸縮泡向周圍細胞質伸放射排列收集管些收集管端部與內質中國管相通伸縮泡主泡收集管由束微管組收縮絲內質中國收集水及代謝廢物通收縮絲收縮進入收集管注入伸縮泡表膜孔(排泄孔)排蟲體外前2伸縮泡交替收縮維持其體內水平衡見伸縮泡功能調節滲透壓排泄 草履蟲殖性殖性殖性殖橫二裂核先進行絲裂核再進行絲裂細胞質二蟲體部橫斷2新體性殖接合殖2草履蟲口溝口溝粘合起粘合處細胞膜溶解兩蟲體細胞質相通核離核裂2形4核其3解體剩1核裂等2核核逐漸消失兩蟲體互換其新核並與較核融合程相於受精作用兩蟲體接合核裂38核4變核其餘4核3解體剩1核裂2核再裂4核每蟲體裂2結原接合兩親本蟲體各形4草履蟲新形8草履蟲都核核 母音字母e重讀音節發母音/i/音發音舌端靠近齒舌前部抬高接觸顎發任何摩擦牙床接近合唇形扁平音現字首、字字尾位置: even 偶數 meter 米 fever 發燒 zebra 斑馬 he (主格) we 我(主格) me 我(賓格) be 希望我能幫助解疑釋
Ⅵ PHP 如何將上傳的文件轉化為buffer數據格式
$upfile=readfile($_FILES['fileField']['tmp_name']);
就可以了。如果想用get方式傳輸文件的話,就把它base64一下,變成字元串。
$str=base64_encode($upfile);
就可以把生成的字元串放到url的get參數里來傳輸。
Ⅶ PHP實現文件下載
2種方法
1直接做個超鏈接,地址為文件的地址
<ahref="文件地址">下載</a>
2流輸出
<?php
$file=fopen('文件地址',"r");
header("Content-Type:application/octet-stream");
header("Accept-Ranges:bytes");
header("Accept-Length:".filesize('文件地址'));
header("Content-Disposition:attachment;filename=文件名稱");
echofread($file,filesize('文件地址'));
fclose($file);
?>
推薦第二種
因為第一種方法只能下載瀏覽器不能解析的文件,比如rar啊,腳本文件之類。如果文件是圖片或者txt文檔,就會直接在瀏覽器中打開
而第二種方法是直接輸出的文件流,不存在上述問題
Ⅷ protocol buffer能在php用嗎
要使用之前先到code.google.com上搜索protocol buffer,下載到本地,解壓後依次執行:
./configuremakemake checkmake install
最後一步涉及到許可權,可能會需要sudo。
二、定義一個proto文件
下面依然是給出一個簡單的例子,要使用proto首先需要自己定義一個proto文件,定義一個people.proto文件,內容如下:
message people{
optional string name = 1;
optional int32 height = 2;}三、生成一個python可用的py文件
然後就是生成對應的py文件,命令如下:
protoc -I=./ --python_out=./ people.proto
其中-I是source的路徑,--python_out表示對應python庫的生成路徑,然後是對應的proto文件。當然,pb還支持c++和java,修改--python_out即可。
完成後就有對應的people_pb2.py文件了。導入後即可使用,第一次安裝後直接用應該會提示:ImportError: No mole named google.protobuf,這是因為找不到對應的庫路徑導致,到你下載的pb路徑下,找到python路徑,執行sudo python setup.py install,執行完後可以通過執行sudo python setup.py test檢查是否有安裝成功,如果最後提示
----------------------------------------------------------------------
Ran 193 tests in 0.327sOK那麼就是安裝成功了,此時再導入對應的pb2.py文件即可使用。
四、導入使用的簡單例子
給出一個簡單的調試例子:
import people_pb2
pbFirstPeople = people_pb2.people()
pbFirstPeople.name = joey
pbFirstPeople.height = 160
print pbFirstPeople
輸出結果為:name: joey
Ⅸ php檢測上傳文件大小的問題
在用PHP進行文件上傳的操作中,需要知道怎麼控制上傳文件大小的設置,而文件可傳大小是受到多種因素制約的,現總結如下:
1、php.ini:upload_max_filesize 所上傳的文件的最大大小。默認值2M。
2、php.ini:memory_limit 本指令設定了一個腳本所能夠申請到的最大內存位元組數,默認值8M。如果不需要任何內存上的限制,必須將其設為 -1。如果內存不夠,則可能出現錯誤:Fatal error: Allowed memory size of X bytes exhausted (tried to allocate Y bytes)
3、php.ini:post_max_size 設定POST數據所允許的最大大小。此設定也影響到文件上傳。要上傳大文件,該值必須大於 upload_max_filesize。
4、php.ini:max_execution_time = 30 ; Maximum execution time of each script, in seconds
5、php.ini:max_input_time = 60 ; Maximum amount of time each script may spend parsing request data
6、如果用到mysql的BLOB進行二進制文件存儲,則需要設置my.ini:max_allowed_packet=xxM
7、httpd.conf
在 Apache 裡面有一個選項是 LimitRequestBody,這個選項可以限制用戶送出的 HTTP 請求內容。這個選項可以在 .htaccess 或 httpd.conf 里使用,而如果在 httpd.conf 內使用,分別可以用在 virtualhost 或目錄屬性設定。而 LimitRequestBody 的設定值是介乎 0 (無限制) 至 2147483647 (2GB)。
例如要在目錄 D:/AppServ/www 設定上傳限制為 100K,可以在 .htaccess 或 httpd.conf 加入以下語句:
LimitRequestBody 1024000000
Options Indexes FollowSymLinks MultiViews ExecCGI
AllowOverride All
Order allow,deny
Allow from all
LimitRequestBody 1024000000Options Indexes FollowSymLinks MultiViews ExecCGIAllowOverride AllOrder allow,denyAllow from all
如果透過 .htaccess 設定,儲存檔案後會立即生效;如透過 httpd.conf 設定,須要重新啟動 Apache。
PHP關於文件上傳部分,特別提到表單隱藏域:MAX_FILE_SIZE,意思是接收文件的最大尺寸。文檔中給出的例子如下:
<form enctype="multipart/form-data" action="_URL_" method="POST">
<input type="hidden" name="MAX_FILE_SIZE" value="30000">
Send this file: <input name="userfile" type="file">
<input type="submit" value="Send File">
form>
Send this file:
這里設置MAX_FILE_SIZE = 30000,期待一種可能,使得瀏覽器在傳送文件之前能夠依此作出預先判斷,如果文件尺寸大於30000位元組,則不執行實際的POST動作。也就是不往伺服器發送文件內容,而是直接在客戶端提醒用戶「你試圖上傳的文件超過30000位元組」。
這的確是一個非常棒的主張,但在現實中卻暫時無法實現。不是因為這個限制可以「被簡單地繞過」,而是IE和FireFox這兩個主流瀏覽器都不支持這個特性。PHP的這個建議尚未被採納。
MAX_FILE_SIZE還有一個用場:後台PHP會判斷接收到的文件大小是否大於這個值,如果超出,$_FILES['thisfile']['error']會被設置為UPLOAD_ERR_FORM_SIZE(2),同時放棄保存臨時文件,將$_FILES['thisfile']['size']置0。
這個例子,沒問題,表現正常,當我試圖上傳一個40多K的文件時,PHP程序報告「文件超過MAX_FILE_SIZE」。
但是,如果我們將表單中的MAX_FILE_SIZE從30000減少到1000,情形又如何呢?
上傳800位元組的文件,正常;
上傳40K的文件,PHP報告文件過大,也正常;
上傳3000個位元組的文件,PHP未報告錯誤,它成功保存了文件!出乎意料!
問題就出在main/rfc1867.c中判斷文件是否超長的這部分代碼上。php每次從buffer中讀取FILLUNIT位元組長度的內容後,首先判斷「已經讀到的內容長度(total_bytes)」是否大於MAX_FILE_SIZE,然後再增加「已經讀到的內容長度(total_bytes)」。這樣一來,和預計的結果之間至多會有FILLUNIT位元組的誤差,而FILLUNIT=1024*5=5K。(點擊bug了解詳細內容)
這就是說,當MAX_FILE_SIZE<5K時,上傳一個大於MAX_FILE_SIZE,但是小於5K的文件是沒有問題的。
當然,因為這個設置很容易被繞過,所以伺服器端編程不應當依賴於MAX_FILE_SIZE。而且,5K到底是個很小的數值,對大多數上傳文件的表單來說沒有影響。
PHP中post_max_size,upload_max_filesize, MAX_FILE_SIZE的設置,和客戶端上傳給伺服器端的流量大小無關。
Apache伺服器從客戶端接收長度不超過LimitRequestBody位元組數的請求,然後傳送給php模塊,php模塊再決定是否保存成臨時文件,設置$_FILES全局變數,移交給script進一步處理。
這個Apache的LimitRequestBody選項預設值=0,允許Request body的最大位元組數是2G(Linux + Apache)
最後還要注意的是:
html本身能夠post數據也是有限制的,不能超過2G。
ftp客戶端有文件偏移指針的2GB邊界限制,未使用特殊編譯flag編譯的ftp伺服器端或者客戶端,無論在什麼FS中都不支持大於2GB的文件。不知道PHP會不會也有這種情況。