<?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(包含了上传文件常需要使用到的一些文件参数),由于这种方法是直接上传的文件流,所以其它部分内容不同于文件指针无法通过后端获取