HTML控件之FileUpload实现上传图片

界面设计:将下面这个可爱的图片上传到服务器上。

在代码文件夹内建立一个up文件夹,将这个可爱的图片从C盘图片文件中传到up文件夹内。

如下图界面设计:

代码实现:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

namespace ASP.net
{
    public partial class InputFile : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            Image1.Visible = false;
        }

        protected void btnUpload_Click(object sender, EventArgs e)
        {
            string fullFileName=this.FileUpload1 .PostedFile .FileName;//要上传文件的全路径;
            string fileName = fullFileName.Substring(fullFileName .LastIndexOf ("\\")+1);  //截取当前全路径的最后文字,文件名
           string type=fullFileName .Substring(fullFileName.LastIndexOf (".")+1); //查取.后面的字符,即文件名的扩展名。判断上传格式是否为图片
           Image1.Visible = true;
           if (type=="jpg" || type=="bmp" || type=="gif")
           {
                this.FileUpload1.PostedFile.SaveAs(Server .MapPath ("up")+"\\"+fileName );  //上传    MapPath返回相对路径
                this.Image1.ImageUrl = "up/" + fileName;
           }
           else
           {
               Response.Write("<script language='javascript'> alert('你选择的图片格式错误') </script>");
           }
        }
    }
}


 

界面效果:

up文件夹内

  • 6
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 15
    评论
你可以按照以下步骤使用 `fileupload` 控件图片上传到数据库: 1. 在 HTML 页面中,添加一个 `form` 元素,并设置 `enctype` 属性为 `"multipart/form-data"`,以支持文件上传: ```html <form action="upload.php" method="post" enctype="multipart/form-data"> <input type="file" name="image" /> <input type="submit" value="Upload" /> </form> ``` 2. 创建一个 PHP 文件(例如 `upload.php`),用于处理上传的图片,并将其保存到数据库中。首先,连接到数据库: ```php $servername = "localhost"; $username = "username"; $password = "password"; $dbname = "database"; $conn = new mysqli($servername, $username, $password, $dbname); if ($conn->connect_error) { die("Connection failed: " . $conn->connect_error); } ``` 3. 处理文件上传。首先,检查文件是否成功上传并且没有错误: ```php if (isset($_FILES["image"]) && $_FILES["image"]["error"] == 0) { // 文件上传成功 // 获取文件信息 $file = $_FILES["image"]; $fileName = $file["name"]; $fileTmpName = $file["tmp_name"]; $fileSize = $file["size"]; $fileType = $file["type"]; ``` 4. 将文件内容读取为二进制数据,并进行必要的验证。例如,检查文件类型是否为图片: ```php // 检查文件类型 $allowedTypes = array("image/jpeg", "image/png", "image/gif"); if (in_array($fileType, $allowedTypes)) { // 读取文件内容 $fp = fopen($fileTmpName, 'r'); $content = fread($fp, filesize($fileTmpName)); $content = addslashes($content); fclose($fp); ``` 5. 将文件内容插入到数据库中: ```php // 将文件内容插入数据库 $sql = "INSERT INTO images (name, type, size, content) VALUES ('$fileName', '$fileType', $fileSize, '$content')"; if ($conn->query($sql) === TRUE) { echo "File uploaded successfully."; } else { echo "Error: " . $sql . "<br>" . $conn->error; } ``` 6. 关闭数据库连接: ```php $conn->close(); } ``` 请注意,上述代码仅为示例,并且没有包含对上传文件的完整验证和安全性处理。在实际应用中,你可能需要添加更多的验证和安全性措施来保护你的应用程序和数据库。
评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值