使用html5 FileReader獲取圖片,並異步上傳到服務器(不使用iframe)javascript
原理:php
1.使用FileReader 讀取圖片的base64編碼css
2.使用ajax,把圖片的base64編碼post到服務器。html
3.根據接收到post的數據分析圖片的類型(jpg,gif,png),並把base64_decode後的數據生成對應類型的圖片文件。html5
html:java
- <!DOCTYPE HTML PUBLIC>
- <html>
- <head>
- <meta charset="utf-8">
- <script src="//code.jquery.com/jquery-1.11.0.min.js"></script>
- <title>使用html5 FileReader獲取圖片,並異步上傳到服務器(not iframe)</title>
-
- <style type="text/css">
- body{margin: 0px; background:#f2f2f0;}
- p{margin:0px;}
- .title{color:#FFFF00; background:#000000; text-align:center; font-size:24px; line-height:50px; font-weight:bold;}
- .file{position:absolute; width:100%; font-size:90px;}
- .filebtn{display:block; position:relative; height:110px; color:#FFFFFF; background:#06980e; font-size:48px; line-height:110px; text-align:center; cursor:pointer; border: 3px solid #cccccc;}
- .filebtn:hover{background:#04bc0d;}
- .showimg{margin:10px auto 10px auto; text-align:center;}
- </style>
-
- <script type="text/javascript">
- window.onload = function(){
-
-
- document.getElementById('img').onchange = function(){
-
- var img = event.target.files[0];
-
-
- if(!img){
- return ;
- }
-
-
- if(!(img.type.indexOf('image')==0 && img.type && /\.(?:jpg|png|gif)$/.test(img.name)) ){
- alert('圖片只能是jpg,gif,png');
- return ;
- }
-
- var reader = new FileReader();
- reader.readAsDataURL(img);
-
- reader.onload = function(e){
-
- $.post("server.php", { img: e.target.result},function(ret){
- if(ret.img!=''){
- alert('upload success');
- $('#showimg').html('<img src="' + ret.img + '">');
- }else{
- alert('upload fail');
- }
- },'json');
- }
- }
-
- }
- </script>
-
- </head>
-
- <body>
- <p class="title">使用html5 FileReader獲取圖片,並異步上傳到服務器(not iframe)</p>
- <p><input type="file" class="file" id="img"><label class="filebtn" for="img" title="JPG,GIF,PNG">請選擇圖片</label></p>
- <p class="showimg" id="showimg"></p>
- </body>
- </html>
server.phpjquery
- <?php
- $img = isset($_POST['img'])? $_POST['img'] : '';
-
- list($type, $data) = explode(',', $img);
-
- if(strstr($type,'image/jpeg')!==''){
- $ext = '.jpg';
- }elseif(strstr($type,'image/gif')!==''){
- $ext = '.gif';
- }elseif(strstr($type,'image/png')!==''){
- $ext = '.png';
- }
-
- $photo = time().$ext;
-
- file_put_contents($photo, base64_decode($data), true);
-
- header('content-type:application/json;charset=utf-8');
- $ret = array('img'=>$photo);
- echo json_encode($ret);
- ?>