ホームページ >バックエンド開発 >PHPチュートリアル >layui フレームワークはファイルのアップロードを実装し、TP3.2.3 (thinkPHP) はアップロードされたファイルに対してバックグラウンド処理操作を実行します。
この記事では、主に、layui フレームワークによるファイルのアップロードの実装と、TP3.2.3 によるアップロードされたファイルのバックグラウンド処理操作を紹介し、ファイルのアップロードと処理操作に関連する、layui フレームワークと thinkPHP の実装スキルを分析します。困っている友達は参考にしてください
この記事の例では、layui フレームワークによるファイルアップロードの実装と、TP3.2.3 によるアップロードされたファイルのバックグラウンド処理操作について説明します。参考のために皆さんと共有してください。詳細は次のとおりです:
layui フレームワークはバージョン 1.0.9 です。 。
まず、HTML ページのコードは次のとおりです:
<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>
js コードは次のとおりです:
<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>
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); }
これがこの記事の全内容です、ありがとう読んでくれたあなた。詳細については、PHP 中国語 Web サイトを参照してください。
関連する推奨事項:
layui は動的および静的データテーブルのページングを実装します
以上がlayui フレームワークはファイルのアップロードを実装し、TP3.2.3 (thinkPHP) はアップロードされたファイルに対してバックグラウンド処理操作を実行します。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。