ホームページ >バックエンド開発 >PHPチュートリアル >phpとajaxを併用して画像を処理する方法(コード)
この記事ではPHPにおけるTraitの特徴と使い方(コード付き)を紹介していますので、参考になると思いますので、困っている方は参考にしていただければ幸いです。
1. Base64 でエンコードされた画像を処理して保存し、保存された画像の URL を返します (CANVAS によって変換された画像を処理して保存するために使用できます)
2. 画像を処理して、base64 でエンコードされた画像を返します画像 (一般的に解決された JS クロスドメインの問題)
デモ コード (テストにはサーバー環境を使用してください: 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; } ?>
おすすめ関連記事:
PHP 変数の命名規則と PHP 変数の使い方 (コード付き)
以上がphpとajaxを併用して画像を処理する方法(コード)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。