Home >Backend Development >PHP Tutorial >PHP+Ajax no refresh with progress bar image upload example

PHP+Ajax no refresh with progress bar image upload example

高洛峰
高洛峰Original
2017-02-10 16:36:111736browse

This article mainly introduces the example of PHP+Ajax image upload without refresh with progress bar, and organizes the code of PHP image upload without refresh with progress bar in detail. If you need it, you can learn about it.

Project requirements: 1. PHP+Ajax image upload with progress bar without refresh, 2. With progress bar. Required plugins: jquery.js, jquery.form.js.

Recently I am working on a mobile web project, which requires the use of the Ajax upload function. The project requires PHP to upload images without refreshing and with a progress bar. Let me talk about my implementation method and see the effect first. Figure

PHP+Ajax no refresh with progress bar image upload example

This example requires the use of jquery.js, jquery.form.js, which are included in the demo. You can download them at the bottom of the article.

The first step is to create the front-end page index.html

This paragraph is the front-end display content. What needs to be explained here is that the input:file tag is not very beautiful, so I hide it. . And use an a tag .uploadbtn to call the click event of the file tag to open and select the file.

Note: When uploading files, the form attribute enctype must be set to: multipart/form-data


##

nbsp;HTML>


<meta>
<title>php-ajax无刷新上传(带进度条)demo</title>
<meta>
<meta>
<script></script>
<script></script>
<link>


<p>
 </p>
   
 

 

 

 

 

50%

   点击上传文件


Second step, Ajax submission part

This part is the submission part of Ajax. The process is as follows:

  • At the beginning of submission, set the progress bar to be displayed through the beforeSend callback function. The width of the progress bar is 0% and the progress value is 0%;

  • During the upload process, the width and progress value of the progress bar are changed through the data returned in real time by the uploadProgress callback function.

  • After the upload is successful, the uploaded data information (image name, size, address, etc.) is output through the success callback function and the image is output to the page for preview.

  • Of course, if it fails, there is an error callback function to help you adjust the height.


<script>
$(document).ready(function(e) {
 var progress = $(".progress"); 
 var progress_bar = $(".progress-bar");
 var percent = $(&#39;.percent&#39;);
 $("#uploadphoto").change(function(){
 $("#myupload").ajaxSubmit({ 
 dataType: &#39;json&#39;, //数据格式为json 
 beforeSend: function() { //开始上传 
 progress.show();
 var percentVal = &#39;0%&#39;;
 progress_bar.width(percentVal);
 percent.html(percentVal);
 }, 
 uploadProgress: function(event, position, total, percentComplete) { 
 var percentVal = percentComplete + &#39;%&#39;; //获得进度 
 progress_bar.width(percentVal); //上传进度条宽度变宽 
 percent.html(percentVal); //显示上传进度百分比 
 }, 
 success: function(data) {
 
 if(data.status == 1){
 var src = data.url; 
 var attstr= &#39;<img  src="&#39;+src+&#39;" alt="PHP+Ajax no refresh with progress bar image upload example" >&#39;; 
 $(".imglist").append(attstr);
 $(".res").html("上传图片"+data.name+"成功,图片大小:"+data.size+"K,文件地址:"+data.url);
 }else{
 $(".res").html(data.content);
 }
 progress.hide(); 
 }, 
 error:function(xhr){ //上传失败 
 alert("上传失败"); 
 progress.hide(); 
 } 
 }); 
 });
 
});
</script>


The third step, backend PHP code upload.php

Backend The processing code is PHP file upload, but some judgments need to be made when uploading, such as file format, file size, etc.

Note: The ajax return format above is json, so the json code for the image must be correctly standardized, otherwise a message indicating that the upload was unsuccessful will appear.


$picname = $_FILES['uploadfile']['name']; 
 $picsize = $_FILES['uploadfile']['size']; 
 if ($picname != "") { 
 if ($picsize > 2014000) { //限制上传大小 
 echo '{"status":0,"content":"图片大小不能超过2M"}';
 exit; 
 } 
 $type = strstr($picname, '.'); //限制上传格式 
 if ($type != ".gif" && $type != ".jpg" && $type != "png") {
 echo '{"status":2,"content":"图片格式不对!"}';
 exit; 
 }
 $rand = rand(100, 999); 
 $pics = uniqid() . $type; //命名图片名称 
 //上传路径 
 $pic_path = "images/". $pics; 
 move_uploaded_file($_FILES['uploadfile']['tmp_name'], $pic_path); 
 } 
 $size = round($picsize/1024,2); //转换成kb 
 echo '{"status":1,"name":"'.$picname.'","url":"'.$pic_path.'","size":"'.$size.'","content":"上传成功"}';


Demo download: php-ajax-upload_jb51.rar


The above is the entire content of this article , I hope it will be helpful to everyone's learning, and I also hope that everyone will support the PHP Chinese website.

For more PHP+Ajax non-refresh with progress bar image upload examples and related articles, please pay attention to the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn