php文件上传之单文件上传,
为了简单一些,php文件跟form表单写在了一个文件里.
php单文件上传---->
<span> 1</span> <!DOCTYPE html> <span> 2</span> <html> <span> 3</span> <head> <span> 4</span> <meta charset="UTF-8" /> <span> 5</span> </head> <span> 6</span> <body> <span> 7</span> <form action="upload.php" method="post" enctype="multipart/form-data"> <span> 8</span> 请选择要上传的文件:<input type="file" name="myfile"/><br /><br /> <span> 9</span> <input type="submit" value="submit" /> <span>10</span> <input type="hidden" name="MAX_FILE_SIZE" value="5982"/> <span>11</span> </form> <span>12</span> </body> <span>13</span> </html> <span>14</span> <span>15</span> <span>16</span> <span>17</span> <?<span>php </span><span>18</span> <span>if</span>(!<span>empty</span>(<span>$_FILES</span><span>)){ </span><span>19</span> <span>header</span>('content-type:text/html;charset=utf-8'<span>); </span><span>20</span> <span>$fileInfo</span>=<span>$_FILES</span>['myfile'<span>]; </span><span>21</span> <span>print_r</span>(<span>$_FILES</span><span>); </span><span>22</span> <span>//</span><span>如果上传出错则退出并打印错误信息</span> <span>23</span> <span>if</span>(<span>$fileInfo</span>['error']>0<span>){ </span><span>24</span> <span>switch</span>(<span>$fileInfo</span>['error'<span>]){ </span><span>25</span> <span>case</span> 1: <span>26</span> <span>$msg_error</span>='上传文件超过了php配置文件中UPLOAD_MAX_FILESIZE选项的值'<span>; </span><span>27</span> <span>break</span><span>; </span><span>28</span> <span>case</span> 2: <span>29</span> <span>$msg_error</span>='超过了表单MAX_FILE_SIZE限制的大小'<span>; </span><span>30</span> <span>break</span><span>; </span><span>31</span> <span>case</span> 3: <span>32</span> <span>$msg_error</span>='文件部分上传'<span>; </span><span>33</span> <span>break</span><span>; </span><span>34</span> <span>case</span> 4: <span>35</span> <span>$msg_error</span>='没有文件上传'<span>; </span><span>36</span> <span>break</span><span>; </span><span>37</span> <span>case</span> 6: <span>38</span> <span>$msg_error</span>='没有找到临时目录'<span>; </span><span>39</span> <span>break</span><span>; </span><span>40</span> <span>case</span> 7: <span>41</span> <span>case</span> 8: <span>42</span> <span>$msg_error</span>='系统错误'<span>; </span><span>43</span> <span>break</span><span>; </span><span>44</span> <span> } </span><span>45</span> <span>exit</span>(<span>$msg_error</span><span>); </span><span>46</span> <span> } </span><span>47</span> <span>$filename</span>=<span>$fileInfo</span>['name'<span>]; </span><span>48</span> <span>//</span><span>获取文件的扩展名</span> <span>49</span> <span>$ext</span>=<span>strtolower</span>(<span>substr</span>(<span>$filename</span>,<span>strrpos</span>(<span>$filename</span>,'.')+1<span>)); </span><span>50</span> <span>//</span><span>定义可允许上传的扩展名</span> <span>51</span> <span>$allowExt</span>=<span>array</span>('txt','html','png','gif','jpeg'<span>); </span><span>52</span> <span>//</span><span>检测上传文件的类型</span> <span>53</span> <span>if</span>(!<span>in_array</span>(<span>$ext</span>,<span>$allowExt</span><span>)){ </span><span>54</span> <span>exit</span>('上传文件类型错误'<span>); </span><span>55</span> <span> } </span><span>56</span> <span>57</span> <span>58</span> <span>//</span><span>检测文件的大小</span> <span>59</span> <span>$maxSize</span>=2097152<span>; </span><span>60</span> <span>if</span>(<span>$fileInfo</span>['size']><span>$maxSize</span><span>){ </span><span>61</span> <span>exit</span>('上传文件过大'<span>); </span><span>62</span> <span> } </span><span>63</span> <span>64</span> <span>//</span><span>检测是否为HTTP POST方式上传上来的</span> <span>65</span> <span>if</span>(!<span>is_uploaded_file</span>(<span>$fileInfo</span>['tmp_name'<span>])){ </span><span>66</span> <span>exit</span>('文件不是通过HTTP POST方式提交上来的'<span>); </span><span>67</span> <span> } </span><span>68</span> <span>69</span> <span>//</span><span>确保文件名字唯一,防止同名文件被覆盖</span> <span>70</span> <span>$uniqName</span>=<span>md5</span>(<span>uniqid</span>(<span>microtime</span>(<span>true</span>),<span>true</span>)).'.'.<span>$ext</span><span>; </span><span>71</span> <span>72</span> <span>//</span><span>定义保存在哪个文件夹下,如果没有该文件夹则创建</span> <span>73</span> <span>$path</span>='uploads'<span>; </span><span>74</span> <span>if</span>(!<span>file_exists</span>(<span>$path</span><span>)){ </span><span>75</span> <span>mkdir</span>(<span>$path</span>,0777,<span>true</span><span>); </span><span>76</span> <span>chmod</span>(<span>$path</span>,0777<span>); </span><span>77</span> <span> } </span><span>78</span> <span>$destination</span>=<span>$path</span>.'/'.<span>$uniqName</span><span>; </span><span>79</span> <span>80</span> <span>//</span><span>移动文件至要保存的目录</span> <span>81</span> <span>if</span>(! @<span>move_uploaded_file</span>(<span>$fileInfo</span>['tmp_name'],<span>$destination</span><span>)){ </span><span>82</span> <span>exit</span>('文件上传失败'<span>); </span><span>83</span> <span> } </span><span>84</span> <span>85</span> <span>echo</span> '上传成功'<span>; </span><span>86</span> <span>87</span> <span> } </span><span>88</span> ?>

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는
