PHP 图片上传/ 64位上传

<?php
namespace app\index\controller;

use think\Controller;
use think\Db;
use think\Request;
use think\Session;
use app\index\model\Member;

class Uploads extends Controller
{
    public function _initialize()
    {
        header('Access-Control-Allow-Origin: *');
        header("Access-Control-Allow-Headers: AuthToken, Origin, X-Requested-With, Content-Type, Accept, Authorization");
        header('Access-Control-Allow-Methods: POST,GET,PUT,DELETE');
    }
    
    //图片上传
    public function uploads2($dir = '/uploads/index/upload/')
    {
        $file = request()->param('pic');        
        if (!$file) {
           return  json(['status'=>0,'msg'=>'请上传图片']);
        } else {            
            $info = $file->validate(['size' => 2097152,'ext' => 'jpg,png,gif,jpeg'])->move(ROOT_PATH . '/public' . DS . $dir);            
            if (!$info) {
             return  json(['status'=>0,'msg'=>$file->getError()]);
            } else {
                $path = str_replace('\\', '/', Request()->domain() . $dir . $info->getSaveName());
                return json(['status'=>1,'msg'=>'上传成功','url'=> $path ]);
            }
        }
    }
    
    //图片64位上传
    public function uploads()
    {
        //图片的base64文件
        $base64_img = input('post.pic');
        //存放在当前目录的uploads文件夹下
        $up_dir = './uploads/';
        //判断是否存在文件,不存在创建
        if (!file_exists($up_dir)) {
            mkdir($up_dir, 0777);
        }
        if (preg_match('/^(data:\s*image\/(\w+);base64,)/', $base64_img, $result)) {
            $type = $result[2];
            //判断是否是图片格式
            if (in_array($type, array('pjpeg', 'jpeg', 'jpg', 'gif', 'bmp', 'png'))) {
                $new_file = $up_dir . date('YmdHis_') . '.' . $type;
                if (file_put_contents($new_file, base64_decode(str_replace($result[1], '', $base64_img)))) {
                    //图片的uploads/路径
                    $img_path = str_replace('../../..', '', $new_file);
                    $request = Request::instance();
                    $img =  ltrim($img_path,'.');
                    //全部路径
                    $path = $request->domain() . $img_path;
                  //  msg('ok', '图片上传成功', $path);
                  return json(['status'=>1,'msg'=>'上传成功','url'=> $path ]); 
                } else {
                   // msg('no', '图片上传失败');
                    return  json(['status'=>0,'msg'=>'图片上传失败']);
                }
            } else {
            //文件类型错误
              //  msg('no', '图片上传类型错误');
                    return  json(['status'=>0,'msg'=>'图片上传类型错误']);
            }

        } else {
          //文件错误
            //msg('no', '文件错误');
                  return  json(['status'=>0,'msg'=>'文件错误']);
        }
    }
    
}
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值