html+php上传图片文件到服务器


html+php上传图片文件到服务器

一.html代码

1 <body>
2 <form action="" method="post" enctype="multipart/form-data" name="upload_form">
3  <label>选择图片文件</label>
4  <input name="imgfile" type="file" accept="image/gif, image/jpeg"/>
5   <input name="upload" type="submit" value="上传" />
6 </form>
7 </body>

二.php代码

 1 if (isset($_FILES[‘imgfile‘])
 2 && is_uploaded_file($_FILES[‘imgfile‘][‘tmp_name‘]))
 3 {
 4  $imgFile = $_FILES[‘imgfile‘];
 5 $upErr = $imgFile[‘error‘];
 6 if ($upErr == 0)
 7 {
 8 $imgType = $imgFile[‘type‘]; //文件类型。
 9 /* 判断文件类型,这个例子里仅支持jpg和gif类型的图片文件。*/
10 if ($imgType == ‘image/jpeg‘
11 || $imgType == ‘image/gif‘)
12 {
13 $imgFileName = $imgFile[‘name‘];
14 $imgSize = $imgFile[‘size‘];
15 $imgTmpFile = $imgFile[‘tmp_name‘];
16 /*
17  将文件从临时文件夹移到上传文件夹中。
18 注意:upfile这个文件夹必须先创建好,不然会报错。
19 */
20 move_uploaded_file($imgTmpFile, ‘upfile/‘.$imgFileName);
21 /*显示上传后的文件的信息。*/
22 $strPrompt = sprintf("文件%s上传成功<br>"
23 . "文件大小: %s字节<br>"
24 . "<img src=‘upfile/%s‘>"
25 , $imgFileName, $imgSize, $imgFileName
26 );
27 echo $strPrompt;
28 }
29 else
30 {
31 echo "请选择jpg或gif文件,不支持其它类型的文件。";
32 }
33 }
34 else
35 {
36 echo "文件上传失败。<br>";
37 switch ($upErr)
38 {
39 case 1:
40  echo "超过了php.ini中设置的上传文件大小。";
41 break;
42 case 2:
43  echo "超过了MAX_FILE_SIZE选项指定的文件大小。";
44 break;
45 case 3:
46  echo "文件只有部分被上传。";
47 break;
48 case 4:
49  echo "文件未被上传。";
50 break;
51 case 5:
52  echo "上传文件大小为0";
53 break;
54 }
55 }
56 }
57 else
58 {
59 }

三.php代码分析:

$_FILES是一个数组变量,用于保存上传后的文件信息。

$_FILES[‘imgfile‘]表示文件域名称为‘imgfile‘的控件提交服务器后,上传的文件的信息。

一个上传的文件,有以下属性信息:

‘name‘: 上传的文件在客户端的名称。

‘type‘: 文件的 MIME 类型,例如"image/jpeg"。

‘size‘: 已上传文件的大小,单位为字节。

‘tmp_name‘:上传时,在服务器端,会把上传的文件保存到一个临时文件夹中,可以通过此属性得到临时文件名。

‘error‘:文件在上传过程中的错误代码。如果上传成功,此值为0,其它值的意义如下:

1:超过了php.ini中设置的上传文件大小。

2:超过了MAX_FILE_SIZE选项指定的文件大小。

3:文件只有部分被上传。

4:文件未被上传。

5:上传文件大小为0。

代码中首先判断$_FILES[‘imgfile‘]变量是否存在,如果存在,并且$_FILES[‘imgfile‘][‘tmp_name‘]变量所指文件被上传了,判断error属性,如果属性为0,把上传后的图像从临时文件夹移到upfile文件夹中,显示上传文件的信息,并显示上传后的图像。

如果error值不为0,表示上传失败,显示失败信息。

四.完整代码

 1 <!DOCTYPE html >
 2 <html lang="en">
 3 <head>
 4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 5 <title>上传图片文件</title>
 6 </head>
 7 <?php
 8 if (isset($_FILES[‘imgfile‘])
 9 && is_uploaded_file($_FILES[‘imgfile‘][‘tmp_name‘]))
10 {
11  $imgFile = $_FILES[‘imgfile‘];
12 $upErr = $imgFile[‘error‘];
13 if ($upErr == 0)
14 {
15 $imgType = $imgFile[‘type‘]; //文件类型。
16 /* 判断文件类型,这个例子里仅支持jpg和gif类型的图片文件。*/
17 if ($imgType == ‘image/jpeg‘
18 || $imgType == ‘image/gif‘)
19 {
20 $imgFileName = $imgFile[‘name‘];
21 $imgSize = $imgFile[‘size‘];
22 $imgTmpFile = $imgFile[‘tmp_name‘];
23 /* 将文件从临时文件夹移到上传文件夹中。*/
24 move_uploaded_file($imgTmpFile, ‘upfile/‘.$imgFileName);
25 /*显示上传后的文件的信息。*/
26 $strPrompt = sprintf("文件%s上传成功<br>"
27 . "文件大小: %s字节<br>"
28 . "<img src=‘upfile/%s‘>"
29 , $imgFileName, $imgSize, $imgFileName
30 );
31 echo $strPrompt;
32 }
33 else
34 {
35 echo "请选择jpg或gif文件,不支持其它类型的文件。";
36 }
37 }
38 else
39 {
40 echo "文件上传失败。<br>";
41 switch ($upErr)
42 {
43 case 1:
44  echo "超过了php.ini中设置的上传文件大小。";
45 break;
46 case 2:
47  echo "超过了MAX_FILE_SIZE选项指定的文件大小。";
48 break;
49 case 3:
50  echo "文件只有部分被上传。";
51 break;
52 case 4:
53  echo "文件未被上传。";
54 break;
55 case 5:
56  echo "上传文件大小为0";
57 break;
58 }
59 }
60 }
61 else
62 {
63 /*显示表单。*/
64 ?>
65 <body>
66 <form action="" method="post" enctype="multipart/form-data" name="upload_form">
67  <label>选择图片文件</label>
68  <input name="imgfile" type="file" accept="image/gif, image/jpeg"/>
69   <input name="upload" type="submit" value="上传" />
70 </form>
71 </body>
72 <?php
73 }
74 ?>
75 </html>

记录时间:2018年8月8日19:55:27

原文地址:https://www.cnblogs.com/lygz/p/9445314.html

时间: 2024-10-08 13:45:11

html+php上传图片文件到服务器的相关文章

上传图片/文件到服务器

package yao.camera.util; import java.io.ByteArrayOutputStream; import java.io.DataOutputStream; import java.io.File; import java.io.FileInputStream; import java.io.InputStream; import java.net.HttpURLConnection; import java.net.URL; import android.gr

Ajax上传图片文件到服务器

1 <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="FileUploadByJs.aspx.cs" Inherits="WebApplication1.UI.FileUploadByJs" %> 2 3 <!DOCTYPE html> 4 5 <html xmlns="http://www.w3.org/1999/xht

C# WinForm 上传图片,文件到服务器的方法Uploader.ashx

网上有很多方案,起初用时,因为对asp.net不太了解,觉得FTP实现不错,可是后来发现,如果机器在域控下,就会有问题. 一年过去了,asp.net也熟悉了,知道ajax没事应该用ashx,验证码也用ashx,当然这里要说的WinForm上传也应该是ashx了吧,哈哈,先提供简单思路: 接收文件的asp.net是:Uploader.ashx,相关代码: view plaincopy to clipboardprint? <%@ WebHandler Language="C#" C

[Ajax] 使用Ajax异步上传图片文件(非Form表单提交)

通过表单Form提交来上传文件的方式这里就不说了: 下面介绍,通过js中使用ajax异步上传图片文件: 新建一个html页面和一个一般处理程序即可: 涉及思路: //发送2次Ajax请求完成js异步上传文件的操作:          //第1次,post 只上传文件,返回文件名name          //第2次,get 根据文件名name定位服务器上的文件,同时根据浏览器传过来的realname重命名服务器上的文件          //(如果有其他参数,也可以通过第2次一并上传) 图片文件

Android上传文件至服务器(转)

本实例实现每隔5秒上传一次,通过服务器端获取手机上传过来的文件信息并做相应处理:采用Android+Struts2技术. 一.Android端实现文件上传 1).新建一个Android项目命名为androidUpload,目录结构如下: 2).新建FormFile类,用来封装文件信息 package com.ljq.utils; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundExce

kindeditor扩展粘贴图片功能&amp;修改图片上传路径并通过webapi上传图片到图片服务器

前言 kindeditor是一个非常好用的富文本编辑器,它的简单使用我就不再介绍了. 而kindeditor却对图片的处理不够理想. 本篇博文需要解决的问题有两个: kindeditor扩展粘贴图片功能 kindeditor修改图片上传路径并通过webapi上传图片到图片服务器(支持分布式图片) 结果演示 1.扩展粘贴图片功能演示 2.修改图片上传路径演示: 我们的网站演示地址是:http://localhost:9393/ 我们的图片服务器地址是:http://localhost:9394/

Android上传图片(PHP服务器)

原理 Android客户端模拟一个HTTP的Post请求到服务器端,服务器端接收相应的Post请求后,返回响应信息给给客户端. PHP服务器 <?php move_uploaded_file($_FILES['file']['tmp_name'], "./upload/".$_FILES["file"]["name"]); ?> Android客户端 package com.example.uploadfile.app; import

【经验记录】Android上传文件到服务器

Android中实现上传文件,其实是很简单的,和在java里面是一样的,基本上都是熟悉操作输出流和输入流!还有一个特别重要的就是需要配置content-type的一些参数!如果这些都弄好了,上传就很简单了,下面是我写的一个上传的工具类: package com.spring.sky.image.upload.network; import java.io.DataOutputStream; import java.io.File; import java.io.FileInputStream;

上传图片到cdn服务器

1 /** 2 * 发送POST请求 3 */ 4 function doPost2($url, $postdata) { 5 //初始化 6 $curl = curl_init(); 7 // 设置post方式提交 8 curl_setopt($curl, CURLOPT_POST, 1); 9 // 设置抓取的url 10 curl_setopt($curl, CURLOPT_URL, $url); 11 // 设置提交的数据 12 curl_setopt($curl, CURLOPT_PO