首页 > 原创文章 > 软件开发 > 查看文章

php调用美图秀秀插件上传头像

所属分类:软件开发 来源: 丁老师原创 更新时间:2018-02-08 10:05 浏览: 5171 IP属地: 深圳

1.登录美图秀秀WEB开放平台(http://open.web.meitu.com/wiki/)

2.设置crossdomain.xml

下载crossdomain.xml文件,把解压出来的crossdomain.xml文件放在您保存图片或图片来源的服务器根目录下。 如: http://example.com.cn,那么crossdomain.xml的路径为:http://example.com.cn/crossdomain.xml。
需要注意的是crossdomain.xml必须部署于站点根目录下才有效, crossdomain.xml的目的是授权来自美图域下的flash向您的站点上传图片或者从您的站点加载图片。

3.修改代码调用方法

在你的网页代码head标签里或者body标签里加入代码。

然后加载meitu.js和JQ.Js的代码,再创建一个div,id设置为csdiv,例:

接下来你需要编辑你的meitu.js文件,设置美图秀秀API的相关参数啦,例:

接着,我们就上面的上传接口进行编写相应的php代码:

0){
    //文件上传错误提示
    switch($_FILES['Filedata']['error']){
        case 1:
            //1---文件上传大小超过服务器允许上传的最大值
            $error_log='The file is bigger than this PHP installation allows';
            break;
        case 2:
            //2---文件上传大小超过html表单中隐藏域MAX_FILE_SIZE选项的值
            $error_log='The file is bigger than this form allows';
            break;
        case 3:
            //3---文件只有部分被上传
            $error_log='Only part of the file was uploaded';
            break;
        case 4:
            //4---没有文件被上传
            $error_log='No file was uploaded';
            break;
        default:break;
    }
    
    die('upload error:'.$error_log);
}
else {
    //上传成功
    
    //获得临时文件名
    $img_data = $_FILES['Filedata']['tmp_name'];
    
    //获得上传文件的大小
    $size = getimagesize($img_data);
    
    //获得上传文件类型
    $file_type = $size['mime'];
    if (!in_array($file_type, array('image/jpg', 'image/jpeg', 'image/pjpeg', 'image/png', 'image/gif'))) {
        $error_log='only allow jpg,png,gif';
        
        //文件类型出错,输出错误信息
        die('upload error:'.$error_log );
    }
    
    //获得文件扩展名
    switch($file_type){
        case 'image/jpg':
        case 'image/jpeg':
        case 'image/pjpeg':
            $extension = 'jpg';
        break;
        
        case 'image/png':
            $extension='png';
        break;
        case 'image/gif':
            $extension='gif';
        break;
    }
}

if(!is_file($img_data)){
    die('Image upload error!');
}

上边这段代码重要的作用是:判断是否上传文件,上传文件是否满足要求(大小,格式),获得文件的扩展名。
下边这段代码可以理解为:新创建一个$filename,带有文件路径、文件名和文件扩展名,调用move_uploaded_file函数,将上传的图片移到到当前$filename文件,然后加载Db.class.php类和连接数据库操作的config.php,接着把当前上传文件更新在数据库相应的avatar上:

连接数据库的config.php文件为:


标签:

相关文章

百度编辑器ueditor自动添加p标签换行的...

在实际工作中发现,有个编辑器每次保存或者修改后,都会自动在内容顶部和底部增加几行,烦人的很,一直找不到解决办法。后来发现原来是自己代码的问题。解决办法:内容在textarea中,不要换行不要写成:<textarea{content...

Nginx环境下php页面总是缓存刷新也不行...

nginx环境下php页面总是缓存刷新也不行的解决办法

Nginx环境下php下缓存问题的解决

nginx环境下php缓存问题的解决

小程序想升级,是二次开发好还是重做划算?

有同学咨询丁老师,他们公司之前开发的微信小程序,已经运行了四年多,不管是从UI界面上来说,还是功能使用上,都不太理想,想对小程序进行升级改造,那么是对小程序进行二次开发好呢,还是重新做好呢?今天丁老师针对这个问题,从小程序升级所涉及的开...

推荐文章

微信小程序提示“手机号快速验证组件”资源包用...

微信小程序自2023年8月起,开始对《手机号快速验证组件》进行收费,每个小程序有1000次的免费额度,超过额度就要收费。说白了就是以后在使用微信小程序获取用户手机(用户主动授权)的时候,需要按次数收费了。那么,在当前的经济状况下,如何做到轻...

微信小程序和APP有什么区别?到底该做哪个?

经常有新客户咨询丁老师,微信小程序和APP有什么区别呢?一般情况下来说应该做哪个?今天丁老师就这个问题做一下介绍。微信小程序和APP的区别微信小程序微信小程序微信平台运行,无需下载安装,用户通过微信搜索、扫码或者朋友分享就能直接使用,用完即...

VideoJs宽度高度自适应100%的方法

videojs是一款非常不错的html video播放器插件,很多同学经常在群里问我,说丁老师这个videojs怎么设置为宽度或者高度自适应呢,不想把video的width和height写死,有没有什么办法呢。丁老师经过研究发现啊,vide...

CI框架页面添加全局变量的方法

CI框架是一款很小却又非常强大的PHP程序框架,非常适合用来搭建中小型网站以及扩展程序。有同学问到,在使用CI框架时,比如要对全站的标题、公司信息、电话等设置一个全局变量,不用每个页面都写死,该怎么办呢?丁老师来教你:1.打开页面的控制器文...

当前在线
免费咨询