php ajax写一起,php与ajax结合在一起如何处理图片(代码)

这篇文章给大家介绍的内容是关于PHP中Trait的特性以及用法介绍(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

1、处理保存 base64编码 的图片,并返回保存的图片URL(可用来处理保存CANVAS转成的图片的)

2、处理图片,并返回 base64编码 的图片(一般解决JS跨域的问题)

demo代码(测试请用服务器环境:localhost):

test
1、处理保存 base64编码 的图片,并返回保存的图片URL

2、处理图片,并返回 base64编码 的图片

//1、处理保存 base64编码 的图片,并返回保存的图片URL

function getNewImgUrl(){

// var new_img_src = mycanvas.toDataURL("image/jpg");

var new_img_src = '';

dataImg = new_img_src.substring(22);

$.ajax({

type:'post',

url:'filesave.php',

data:{dataimg:dataImg,datatype:'get_imgUrl'},

beforeSend:function(){

},success:function(str){

$('#get_imgUrl').attr('src', str);

}

});

}

getNewImgUrl();

//

//2、处理图片,并返回 base64编码 的图片

getBase64Img('http://qr.topscan.com/api.php?&w=100&m=10&fg=E60012&bg=E3CFB3&text=' + encodeURIComponent('https://blog.csdn.net/') , function(data){

// base64img = new Image();

// base64img.src = data;

$('#get_base64').attr('src', data);

});

function getBase64Img (sourceImgUrl , callback){

// var sourceImgUrl = 'http://qr.topscan.com/api.php?&w=200&m=0&fg=E60012&bg=E3CFB3&text=' + encodeURIComponent('https://blog.csdn.net/');

$.ajax({

type:'post',

url:'filesave.php',

data:{dataimg:sourceImgUrl,datatype:'get_base64'},

beforeSend:function(){

},success:function(str){

callback(str);

}

});

}

filesave.php代码:<?php

function rndStr(){

$string = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';

$len = rand(0,3)+5;

$rst = '';

$strl = strlen($string);

for($i=0;$i

$ind = rand(0, $strl);

$s = $string[$ind];

$rst .= $s;

}

return $rst;

}

//要处理的类型

$type = $_POST['datatype'];

//要处理的图片(正常url图片 / base64编码图片)

$getImg = $_POST['dataimg'];

//1、处理保存 base64编码 的图片,并返回保存的图片URL(可用来处理保存CANVAS转成的图片的)

if($type == 'get_imgUrl'){

//以当前时间+随机字符串设置的不会重复的文件名

$name = time() . rndStr();

$img = str_replace(' ', '+', $getImg);

$img = base64_decode($img);

//存储图片,注意文件夹是否有写入权限

$dir = iconv("UTF-8", "GBK", "upfile");

if (!file_exists($dir)){

mkdir ($dir,0777,true);

}

$f = fopen('upfile/' . $name . '.jpg', 'w+');

fwrite($f, $img);

fclose($f);

//输出保存的图片URL

echo 'upfile/' . $name . '.jpg';

//2、处理图片,并返回 base64编码 的图片(一般解决JS跨域的问题)

}else if($type == 'get_base64'){

$pic = $getImg;

//$arr = getimagesize($pic);

//$pic = "data:{$arr['mime']};base64," . base64_encode(file_get_contents($pic));

$pic = "data:image/jpg;base64," . base64_encode(file_get_contents($pic));

echo $pic;

}

?>

相关文章推荐:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值