【文件上传 后端】文件上传 后端 Part2 —— base64文件流方式
2016-09-29 12:03
459 查看
<?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(包含了上传文件常需要使用到的一些文件参数),由于这种方法是直接上传的文件流,所以其它部分内容不同于文件指针无法通过后端获取
相关文章推荐
- 【文件上传 后端】文件上传 后端 Part2 —— base64文件流方式
- node中上传文件【base64文件流+插件调用】两种方式
- 原生java http方式上传大文件(含 文件流分段上传问题、base64分段转码问题解决思路)
- 原生java http方式上传大文件(含 文件流分段上传问题、base64分段转码问题解决思路)(转)
- 【文件上传 前端】文件上传 前端 Part2 —— HTML5 文件指针方式
- 【文件上传 后端】文件上传 后端 Part1 —— 文件指针方式
- 【文件上传 前端】文件上传 前端 Part2 —— HTML5 文件指针方式
- 通过文件流的方式上传文件
- 【文件上传 前端】文件上传 前端 Part3 —— HTML5 文件流方式
- Bootstrap File Input MultipartFile 及base64方式实现文件上传
- c# 通过文件流方式上传文件到服务器
- 【文件上传 后端】文件上传 后端 Part1 —— 文件指针方式
- Asp.Net HttpPostedFile和base64两种上传图片(文件)方式
- 【文件上传 前端】文件上传 前端 Part3 —— HTML5 文件流方式
- 图片转成BASE64字符串,然后以JSON的方式传递。当图片大小在1M左右的时候没问题,可以上传。但是当文件大小>1.5M的是否发现图片转BASE64不成功,居然得到的值是NULL
- 使用HttpClient以文件流的方式上传文件(非multipartFormData方式)
- 使用Anthem.NET 1.5中的FileUpload控件实现Ajax方式的文件上传
- 文件上传时,是以什么方式提交的?
- FileUpload控件实现Ajax方式的文件上传
- 非控件方式,在上传文件前获得文件的属性信息,包括文件长度,编辑日期