ajax结合php处理图片

1、处理保存 base64编码 的图片,并返回保存的图片URL(可用来处理保存CANVAS转成的图片的)
2、处理图片,并返回 base64编码 的图片(一般解决JS跨域的问题)

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

<!DOCTYPE>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>test</title>
</head>

<body>




<div>1、处理保存 base64编码 的图片,并返回保存的图片URL</div>
<img id="get_imgUrl" src="" />
<div>2、处理图片,并返回 base64编码 的图片</div>
<img id="get_base64" src="" />

<script type="text/javascript" src="https://cdn.bootcss.com/jquery/1.11.2/jquery.min.js"></script>
<script type="text/javascript">
//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);
			}
	});
}
</script>




</body>
</html>

filesave.php代码:

<?php
function rndStr(){
    $string = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
    $len = rand(0,3)+5;
    $rst = '';
    $strl = strlen($string);
    for($i=0;$i<$len;$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;
}
?>

猜你喜欢

转载自blog.csdn.net/qq_16494241/article/details/81317306