php實現手機拍照上傳頭像功能


     現在手機拍照很火,那么如何使用手機拍照並上傳頭像呢?原因很簡單,就是數據傳遞,首先手機傳遞照片信息,這個就不是post傳遞 也不是get函數傳遞,
這個另外一種數據格式傳遞,使用的是$GLOBALS ['HTTP_RAW_POST_DATA'],這個系統函數跟post很相似,但是$GLOBALS ['HTTP_RAW_POST_DATA']支持的數據格式更豐富些,詳細的區別請自己百度谷歌。
設計流程就是:
$GLOBALS ['HTTP_RAW_POST_DATA']傳遞照片數據流(二進制)-->打開一張空白圖--->把數據流寫進空白圖片里面--判斷是否是有效圖片---完成。
注意傳遞照片的二進制流已經包含照片的尺寸大小,格式等等屬性,時間上就是把手機圖片信息傳遞到web端頁面。

手機端一般使用flash切割照片大小,大家都知道圖片和視頻是由二進制流組成的,既然圖片可以上傳,那么視頻能不能上傳呢?原理是不是和手機拍照上傳頭像一樣呢?自己可以去研究一下


直接上代碼

/*
 * 上傳圖片類
 * @parameter; 用戶ID
 * @date:2011-8-15
 * @author:cy
 * */
function UpImg($subdir){
// 設置存儲路徑
if(!empty($subdir)){
	$dirnow=getcwd();
	$folder =$dirnow."/cover/".$subdir;// folder where to save images
	  if( !is_dir($folder) )	mkdir($folder);
	  
// 圖片命名
	$datenow=date('Ymd');
	$timenow=time();
	$image = $datenow.$timenow.'.jpg';

// 圖片是否已存在
	$check = $folder . '/' . $image;
		if (file_exists($check)) {
			unlink($check);
		} else {
			$png = file_get_contents ( 'php://input' ) ? file_get_contents ( 'php://input' ) : gzuncompress ( $GLOBALS ['HTTP_RAW_POST_DATA'] );//得到post過來的二進制原始數據 
			if(!empty($png)){
				$file = @fopen($folder."/".$image, "w"); 
	  	    	fwrite($file,$png);//寫入 
				fclose($file);//關閉 
				// orignal image location
				 $write_image = $folder . '/' . $image;
			
			}else{
				$msg = "沒有數據流";
			}	
			if(getimageInfo($write_image)){
					$msg = "上傳成功";
				}else{$msg = "圖片格式不正確";}
	}  
}else{
	$msg = "參數錯誤";
}
		return $msg;
	 }

/*
 * 檢測圖片是否合法
 * @parameter; 文件名
 * @date:2011-8-15
 * @author:cy
 * */
	function getimageInfo($imageName = '') {  
        $imageInfo = getimagesize ( $imageName );  
        if ($imageInfo !== false) {  
            $imageType = strtolower ( substr ( image_type_to_extension ( $imageInfo [2] ), 1 ) );  
//            $imageSize = filesize ( $imageInfo );  
            return $info = array ('width' => $imageInfo [0], 'height' => $imageInfo [1], 'type' => $imageType, 'mine' => $imageInfo ['mine'] );  
        } else {  
            //不是合法的圖片  
            return false;  
        }  
      
    }  

在使用xml-rpc的時候,server端獲取client數據,主要是通過php輸入流input,而不是$_POST數組


所根據,上面幾個探測,我們可以作出以下總結:
1,Content-Type取值為application/x-www-form-urlencoded時,php會將http請求body相應數據會填入到數組$_POST,填入到$_POST數組中的數據是進行urldecode()解析的結果。(其實,除了該Content-Type,還有multipart/form-data表示數據是表單數據,稍后我們介紹)
2,php://input數據,只要Content-Type不為multipart/form-data(該條件限制稍后會介紹)。那么php://input數據與http entity body部分數據是一致的。該部分相一致的數據的長度由Content-Length指定。
3,僅當Content-Type為application/x-www-form-urlencoded且提交方法是POST方法時,$_POST數據與php://input數據才是”一致”(打上引號,表示它們格式不一致,內容一致)的。其它情況,它們都不一致。
4,php://input讀取不到$_GET數據。是因為$_GET數據作為query_path寫在http請求頭部(header)的PATH字段,而不是寫在http請求的body部分。

這也幫助我們理解了,為什么xml_rpc服務端讀取數據都是通過file_get_contents(‘php://input’, ‘r’)。而不是從$_POST中讀取,正是因為xml_rpc數據規格是xml,它的Content-Type是text/xml。



免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM