자격을 갖춘 프로그래머는 데이터베이스에 데이터를 구현할 때 매우 엄격한 필터링 및 데이터 규칙을 적용합니다. 예를 들어 파일 업로드를 수행할 때 사용자가 첫 번째 단계에서 파일을 업로드할지 여부를 결정해야 하며 이를 수행할 수 있습니다. 또한 업로드된 파일이 백그라운드에 있는지 여부도 확인합니다. 이 문서에서는 이 예에 대한 보다 심층적인 분석을 제공합니다.
다음 HTML 코드가 표시됩니다.
<form action="?" method="post" enctype='multipart/form-data'> 文件上传:<input type="file" name="file" id="file"/> <input type="submit" id="send" value="提交"/> </form>
우리가 가장 일반적으로 사용하는 것은 프런트 엔드의 간단한 판단입니다
<script> var send=document.getElementById("send"); send.onclick=function(){ var file=document.getElementById("file").value; if(file.length<1){ alert('请选择图片'); return false; } } </script>
실제 보안을 만들고 싶다면 백그라운드에서 판단 처리를 입력해야 합니다
<?php //判断pic文件框是否已经选择文件 if(!empty($_FILES['file']['tmp_name'])){ echo'已选择文件'; }else{ echo'请选择文件'; } //PS:$_FILES后面的['tmp_name']一定不要忘写,它表示是一个临时的意思 ?>
사례 분석
JS 판단은 상대적으로 일반적입니다. file=document.getElementById("file").value; 이 방법으로 파일을 직접 제출할 수 있습니다. 예를 들어
function CheckWorkFile() { var obj=document.getElementById('fuMain'); if(obj.value=='') { alert('请选择要上传的作业书文件'); return false; } var stuff=obj.value.match(/^(.*)(\.)(.{1,8})$/)[3]; if(stuff!='doc') { alert('文件类型不正确,请选择.doc文件'); return false; } return true; }
와 같은 파일 업로드를 위한 사용자 이름 제한은 if(!empty($_FILES['file']['tmp_name')만 사용합니다. ])){ 비어 있지 않은지 확인하는 것도 사실 무리입니다
이렇게 처리하면
function file_type($filename) { $file = fopen($filename, "rb"); $bin = fread($file, 2); //只读2字节 fclose($file); $strInfo = @unpack("C2chars", $bin); $typeCode = intval($strInfo['chars1'].$strInfo['chars2']); $fileType = ''; switch ($typeCode) { case 7790: $fileType = 'exe'; break; case 7784: $fileType = 'midi'; break; case 8297: $fileType = 'rar'; break; case 8075: $fileType = 'zip'; break; case 255216: $fileType = 'jpg'; break; case 7173: $fileType = 'gif'; break; case 6677: $fileType = 'bmp'; break; case 13780: $fileType = 'png'; break; default: $fileType = 'unknown: '.$typeCode; } //Fix if ($strInfo['chars1']=='-1' AND $strInfo['chars2']=='-40' ) return 'jpg'; if ($strInfo['chars1']=='-119' AND $strInfo['chars2']=='80' ) return 'png'; return $fileType; } echo file_type('start.php'); // 6063 or 6033이렇게 하면 업로드되는 파일 형식을 제한하고 안전한 처리도 제공할 수 있습니다. 프로그램
위 내용은 파일 업로드 여부를 확인하기 위한 PHP의 메서드 예제에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!