Maison >développement back-end >tutoriel php >Le framework Layui implémente le téléchargement de fichiers et l'exemple d'opération de traitement en arrière-plan TP3.2.3 pour les fichiers téléchargés
Cet article présente principalement le framework layui pour implémenter le téléchargement de fichiers et TP3.2.3 pour effectuer des opérations de traitement en arrière-plan sur les fichiers téléchargés. Il analyse les techniques d'implémentation associées du framework layui combinées avec thinkPHP pour les opérations de téléchargement et de traitement de fichiers sous forme d'exemples. .Les amis qui en ont besoin peuvent s'y référer. Suivant
L'exemple de cet article décrit la mise en œuvre du téléchargement de fichiers par le framework layui et l'opération de traitement en arrière-plan des fichiers téléchargés par TP3.2.3. Partagez-le avec tout le monde pour votre référence, les détails sont les suivants :
Le framework layui est la version 1.0.9. .
Tout d'abord, le code de la page html est le suivant :
<p class="layui-form-item" id="upload_file"> <p class="layui-input-block" style="width: 300px;"> <input type="hidden" id="img_url1" name="HeadImageUrl" value=""/> <p class="layui-upload-drag" id="uploadpic1" lay-verify="uploadpic1"> <p class="layui-col-xs12 layui-col-md12"> <img class="layui-upload-img" id="demo1" > </p> <p class="button-hide"> <input type="file" name="banner_file_upload" id="banner_file_upload" class="layui-uplaod-file" lay-type="file"> </p> </p> </p> </p>
le code js est le suivant :
<script type="text/javascript" th:inline="javascript"> layui.use('upload', function (){ var upload = layui.upload; var url="__PUBLIC__"; upload({ elem: '#banner_file_upload', url: "/index.php/Admin/Product/upload", method: 'post', before: function(obj){ console.log('文件上传中'); layer.load(); }, success: function (msg) { console.log(msg); if(msg.msg=="success"){ layer.closeAll('loading'); layer.msg("上传成功"); $("#img_url1").attr("value", msg.src); }else if(msg.msg=="error"){ layer.closeAll('loading'); layer.msg(msg.code); } }, error:function (data) { layer.msg("上传失败"); console.log(data); } }); }); </script>
La méthode suivante pour recevoir des valeursà partir de l'arrière-plan php :
#上传文件方法 public function upload(){ $res=array( 'code'=>1, 'msg'=>'no sorry', 'data'=>array( 'src'=>'', ) ); #图片存放路径 $directory = C('UPLOAD_PATH')."/Public/docment/"; #判断目录是否存在 不存在则创建 if(!(is_dir($directory))){ $this->directory($directory); } #获取数据库最后一条id 当做文件名称 $product_last_id=D('ApiProduct')->getLastId(); $savename="ApiProduct_".time().'_'.($product_last_id['id']+1); $upload = new \Think\Upload(); $upload->maxSize = 0; $upload->exts = array('doc','docx','xls','xlsx','pdf','txt'); $upload->rootPath = $directory; $upload->saveName="$savename"; $upload->savePath = ''; $info = $upload->uploadOne($_FILES['banner_file_upload']); if(!$info){ $res['code']=$upload->getError(); $res['msg']='error'; }else{ $res['code']=0; $res['msg']='success'; $res['src']="/Public/docment/".$savename.".".$info['ext']; } echo json_encode($res);die; } /** * 递归创建文件 * @author erwa<erwa@qingjinju.net> */ public function directory($dir){ return is_dir ( $dir ) or directory(dirname( $dir )) and mkdir ( $dir , 0777); }
Le framework ThinkPHP implémente un exemple d'exportation de données Excel
Native JS implémente Ajax pour interagir avec PHP via un exemple de méthode POST de compétences php
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!