🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
PHP对Base64的支持非常好,有内置的base64_encode与base64_decode负责图片的Base64编码与解码。 编码上,只要将图片流读取到,而后使用base64_encode进行进行编码即可得到。 而图片编码成base64字符串后,编码内会加入这些字符 data:image/png;base64,本来是用于base64进行识别的。但是如果直接放到php里用base64_decode函数解码会导致最终保存的图片文件格式损坏,而解决方法就是先去掉这一串字符: ``` $base64_string= explode(',', $base64_string); //截取data:image/png;base64, 这个逗号后的字符 $data= base64_decode($base64_string[1]);  //对截取后的字符使用base64_decode进行解码 file_put_contents($url, $data); //写入文件并保存 ``` ### **项目应用实例** ``` /** * 构造函数定义子目录和获取配置文件中定义的上传路径 * */ public function __construct() { $this->base_upload_url = $this->getAmazonImageUploadPath();//获取配置文件中定义的路径 $this->image_path = '/sku_images'; } /** * 批量上传,返回上传路径 * @param $sku_id 子目录 * @param $thumbs base64图像文件 * @param $imageIsFile 是否是图像文件 * @throws * */ public function batchUploadFile($sku_id,$thumbs,$imageIsFile = false) { $pathName = $this->image_path.'/'.$sku_id; $result = []; $images = json_decode($thumbs); if(!empty($images)){ foreach ($images as $img){ $file_name = 'sku'.'-'.time().rand(10000,99999); $path = yield $this->uploadFile($img->data,$pathName,$file_name,$imageIsFile); $result[] ="/publish/amazon/match?path=". $path; } } return $result; } ``` ``` /** * 上传文件 * @param $baseData string * @param $pathName string * @param $fileName string * @return string */ public function uploadFile($baseData, $pathName,$fileName, $isFile = false) { if(!$baseData){ throw new ExceptionFail('未检测到文件'); } $url = $this->base_upload_url . $pathName ; $this->mkdir($url); try { $fileName = strval($fileName).'.jpg'; if(!$isFile){ $start = strpos($baseData, ','); $content = substr($baseData, $start+1); $baseData = base64_decode(str_replace(" ", "+", $content));//base64解码 file_put_contents($url.'/'.$fileName, $baseData); return $pathName.'/'.$fileName; }else{ return $baseData; } } catch (\Exception $e) { throw new ExceptionError($e->getMessage()); } } ``` ### **运行:** 参数说明:图片上传时,需要在前端转成base64格式的图片流。 ![](https://box.kancloud.cn/857775737f3a5b703ec8e2e930f6a319_1063x421.png) 这是本例中测试用的base64图片流: ``` {"data":""} ```