PHP base64 编码转化图片并进行指定路径的保存和上传处理

背景

  • 前两天在做图片上传的功能优化,发现了一个效果比较好的 JQuery 插件(H5移动前端图片批量压缩上传),看其中的介绍是使用了 base64 编码的方式进行上传

  • 个人在使用过程中,做了简单处理,只需向后台传输 base64 编码数据即可,然后后台进行处理,下面主要介绍我的操作流程,可做参考.

一. 前端处理

①. js 代码修改

  • 本着不做过多更改的原则,在处理好页面布局后,我只是修改了源代码中的 upload() 方法.

处理目的

  1. 将获取的 base64 编码传到后台,如果后台顺利处理完毕,会返回它的存储路径,然后我进行了多图片存储路径在页面上(隐藏域)的拼接,方面后面提交后的数据库数据存储

  2. 如果没有成功,则会返回错误提示信息

//    图片上传,将base64的图片转成二进制对象,塞进formdata上传
    function upload(basestr, type, $li) {
        var text = window.atob(basestr.split(",")[1]);
        var buffer = new Uint8Array(text.length);
        
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
ThinkPHP 是一款流行的 PHP 框架,它提供了丰富的功能和便利的API来处理文件上传。将Base64编码图片上传到服务器,你可以按照以下步骤操作: 1. **解码Base64字符串:** 首先,你需要将Base64编码图片数据转换回原始二进制格式。这可以通过PHP内置的`base64_decode()`函数完成。 ```php $data = base64_decode($base64ImageString); ``` 2. **获取文件名或随机生成:** 为上传的文件创建一个唯一的文件名,可以使用当前时间戳或者随机字符串。 ```php $filename = time() . '_' . md5(rand(0, 999999)) . '.jpg'; ``` 3. **设置临时保存路径:** 在服务器上设置一个临时目录来存储上传的文件,直到正式保存到目标位置。 ```php $tmpPath = '/path/to/your/upload/temporary/directory/'; $tmpFile = $tmpPath . $filename; ``` 4. **保存文件:** 使用PHP的`file_put_contents()`函数将解码后的二进制数据写入临时文件。 ```php file_put_contents($tmpFile, $data); ``` 5. **调用ThinkPHP上传方法:** ThinkPHP提供了`upload()`方法,用于处理文件上传,包括验证、移动文件等。在这个方法中,指定临时目录和目标目录(通常是public/upload目录)。 ```php $upload = new \Think\File\Upload(); $upload->save(array( 'rootPath' => 'public/upload/', 'tempName' => $tmpFile, 'saveName' => $filename, 'maxSize' => 1048576 // 设置最大上传文件大小 )); ``` 6. **检查上传结果:** `upload()`方法会返回一个包含上传信息的数组,检查`status`字段是否为0(成功)。 ```php if ($upload['status'] == 0) { // 上传成功,将文件移动到目标位置 $targetFile = $upload['savePath'] . $upload['saveName']; rename($tmpFile, $targetFile); } else { // 处理上传失败的情况 } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值