jQuery+ThinkPHP 이미지 업로드

본고는 여러분에게 jQuery+ThinkPHP가 이미지 업로드를 실현하는 구체적인 코드를 공유하여 참고하도록 하였으며, 구체적인 내용은 다음과 같습니다.
하나, js를 이용하여 그림을 업로드할 때 관련 코드를 실시간으로 미리 보기

<!DOCTYPE html> 
<html> 
<head> 
<meta charset="UTF-8"> 
<title> </title>
<script src="http://libs.baidu.com/jquery/2.1.4/jquery.min.js"></script> 
</head> 
<body> 
 <input type="file" onchange="showSelectedImages(this.files)" id="uploadInput"> 
 <br/> 
 <div id="fileList"></div> 
 
</body> 
<script> 
 window.URL = window.URL || window.webkitURL; 
/** 
*   
* @param {[type]} files   
*/ 
function showSelectedImages(files) { 
 var fileList = document.getElementById('fileList'); 
 if (isImageByType(files[0].type)) {
 var img = '<img src="' + window.URL.createObjectURL(files[0]) + '" style="width:200px;">';
 $('#fileList').html(img);
 }else{
 alert(' ');
 }
} 
 
/** 
*   
* @param {[type]} fileType   
* @return {Boolean} 
*/ 
function isImageByType(fileType) { 
 return fileType.indexOf("image") < 0 ? false : true; 
} 
</script> 
</html>
2. jQuery의 Ajax를 이용하여 이미지 폼을 업로드

var formData = new FormData();
formData.append('file', $('#uploadimg')[0].files[0]); // 
formData.append("ewmclass",ewmclass);
formData.append("uname",uname);
formData.append("skaccount",skaccount);

$.ajax({
 url: "/User/ewmup",
 type: "post",
 dataType: "json",
 cache: false,
 data: formData,
 processData: false,//  
 contentType: false, //  
 success: function (mes) {
  if(mes.status == 1){
   msg_alert(mes.message,mes.url);
  }else{
   msg_alert(mes.message);
  }
 }
});
3. ThinkPHP 업로드 파일 관련 코드

// 
$upload = new \Think\Upload();//  
$upload->maxSize =  3145728 ;//  
$upload->exts  =  array('jpg','jpeg','png','gif');//  
$upload->rootPath =  './Uploads/'; //  
$upload->savePath =  'ewm_img/'; //  ( ) 
//  
$info = $upload->upload();
if(!$info) {//  
 echo $upload->getError()
 exit;
}
echo ' :/Uploads/'.$info['file']['savepath'].$info['file']['savename'];
이상은 본문의 전체 내용입니다. 여러분의 학습에 도움이 되고 저희를 많이 응원해 주십시오.

좋은 웹페이지 즐겨찾기