【文件上传 后端】文件上传 后端 Part2 —— base64文件流方式
<?php function response($arr){ switch($arr['code']){ case 200: $code_str = "OK"; break; case 201: $code_str = "Created"; break; case 400: $code_str = "Bad Request"; break; case 401: $code_str = "Invalid Token"; break; case 403: $code_str = "Forbidden"; break; case 404: $code_str = "Not Found"; break; case 409: $code_str = "Conflict"; break; case 500: $code_str = "Internal Server Error"; break; } header("HTTP/1.1 ".$arr['code']." ".$code_str); header("Content-type: application/json"); echo json_encode($arr['data']); exit; } $method = $_SERVER['REQUEST_METHOD']; if($method != 'POST'){ $arr = Array( 'code' => 400, 'data' => Array( 'code' => 400, 'data' => 'wrong method' ) ); response($arr); } if(!isset($_POST["file_content"]) || !$_POST["file_content"]){ $arr = Array( 'code' => 400, 'data' => Array( 'code' => 400, 'data' => 'invalid file_content' ) ); response($arr); } if(!isset($_POST["file_name"]) || !$_POST["file_name"]){ $arr = Array( 'code' => 400, 'data' => Array( 'code' => 400, 'data' => 'invalid file_name' ) ); response($arr); } if(!isset($_POST["file_type"]) || !$_POST["file_type"]){ $arr = Array( 'code' => 400, 'data' => Array( 'code' => 400, 'data' => 'invalid file_type' ) ); response($arr); } $file_content = base64_decode($_POST["file_content"]); $file_size = strlen($file_content); $file_digest = md5($file_content); $arr = Array( 'code' => 200, 'data' => Array( 'name' => $_POST["file_name"], 'type' => $_POST["file_type"], 'md5' => $file_digest, 'size' => $file_size ) ); response($arr); ?>
以上可以配合文件上传-前端 part3种介绍的方法,作为上传到的后端upload_file2.php来看待
1、首先检查上传的方法是否为POST
2、由于是用的是模拟表单上传文件流,所以通过$_POST的方式接收文件流和其它参数(文件名、文件类型等)
3、因为接收的是base64的文件流,所以在获取之后要进行base64的解码
4、从前端传的参数中获取到文件名、文件类型、文件流,并根据文件流计算出实际的文件大小和md5(包含了上传文件常需要使用到的一些文件参数),由于这种方法是直接上传的文件流,所以其它部分内容不同于文件指针无法通过后端获取