`
leonardleonard
  • 浏览: 812297 次
社区版块
存档分类
最新评论

写入和读取图片(c# asp.net sqlserver)

阅读更多

作者:木子  http://blog.csdn.net/derny/

首先要创建一个表包含自段image 和 type 类型各自为image 和 vnanchar

WebForm1.aspx

<%@ Page language="c#" Codebehind="WebForm1.aspx.cs" AutoEventWireup="false" Inherits="ReadAndWritePicFromDB.WebForm1" %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" > <HTML> <HEAD> <title>WebForm1</title> <meta name="GENERATOR" Content="Microsoft Visual Studio .NET 7.1"> <meta name="CODE_LANGUAGE" Content="C#"> <meta name="vs_defaultClientScript" content="JavaScript"> <meta name="vs_targetSchema" content="http://schemas.microsoft.com/intellisense/ie5"> </HEAD> <body MS_POSITIONING="GridLayout"> <form id="Form1" method="post" runat="server"> <FONT face="宋体"><INPUT id="File1" style="Z-INDEX: 101; LEFT: 112px; POSITION: absolute; TOP: 88px" type="file" name="File1" runat="server"></FONT> <asp:Button id="Button1" style="Z-INDEX: 102; LEFT: 400px; POSITION: absolute; TOP: 88px" runat="server" Text="Write" Width="104px"></asp:Button> <asp:Button id="Button2" style="Z-INDEX: 103; LEFT: 552px; POSITION: absolute; TOP: 88px" runat="server" Text="Read" Width="105px"></asp:Button> </form> </body> </HTML>

 

WebForm1.aspx.cs

using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.IO;
using System.Data.SqlClient;

namespace ReadAndWritePicFromDB
{
 /// <summary>
 /// WebForm1 的摘要说明。
 /// </summary>
 public class WebForm1 : System.Web.UI.Page
 {
  protected System.Web.UI.HtmlControls.HtmlInputFile File1;
  protected System.Web.UI.WebControls.Button Button1;
  private string fileName = "" ;
  protected System.Web.UI.WebControls.Button Button2;
  private static SqlConnection conn  = null;
  
  private void Page_Load(object sender, System.EventArgs e)
  {
   // 在此处放置用户代码以初始化页面
   ConnectDB();
  }

  //得到文件名
  private string GetFile()
  {
   HttpPostedFile file = File1.PostedFile;
   fileName = file.FileName;

   return fileName;
  }

  //读取文件内容
  private byte[] ReadFile()
  {
   FileStream file = File.OpenRead(GetFile());
   byte[] content = new byte[file.Length];
   file.Read(content,0,content.Length);
   file.Close();
   
   return content;
  }

  //连接数据库
  private void ConnectDB()
  {
   string connStr = "Initial Catalog=;Data Source=;User ID=;Password=;";
   conn = new SqlConnection(connStr);
   conn.Open();
  }

  //写入图片到数据库中
  private void WriteImage()
  {
   SqlCommand comm = conn.CreateCommand();
   comm.CommandText = "insert into images(image,type) values(@image,@type)";
   comm.CommandType = CommandType.Text;
   SqlParameter param = comm.Parameters.Add("@image",SqlDbType.Image);
   param.Value = ReadFile();
   param = comm.Parameters.Add("@type",SqlDbType.NVarChar);
   param.Value = GetContentType(new FileInfo(fileName).Extension.Remove(0,1));

   if(comm.ExecuteNonQuery() == 1)
    Response.Write("Successful");
   else
    Response.Write("Fail");
   
   conn.Close();
  }

  //获取图片的后缀名
  private string GetContentType(string extension)
  {
   string type = "";

   if(extension.Equals("jpg") || extension.Equals("JPG"))
    type = "jpeg";
   else
    type = extension;

   return "image/"+type;
  }

  //从数据库中读取图片
  private void ReadImage()
  {
   SqlCommand comm = conn.CreateCommand();
   comm.CommandText = "select image,type from images";
   comm.CommandType = CommandType.Text;

   SqlDataReader reader = comm.ExecuteReader();
   while(reader.Read())
   {
    Response.ContentType = reader["type"].ToString();//读写类型  一定要设置 否则浏览器会当作文本输出
    Response.BinaryWrite((byte[])reader["image"]);//图片数据
   }

   Response.Write("Successful");
   Response.End();

   conn.Close();
  }
  #region Web 窗体设计器生成的代码
  override protected void OnInit(EventArgs e)
  {
   //
   // CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
   //
   InitializeComponent();
   base.OnInit(e);
  }
  
  /// <summary>
  /// 设计器支持所需的方法 - 不要使用代码编辑器修改
  /// 此方法的内容。
  /// </summary>
  private void InitializeComponent()
  {   
   this.Button1.Click += new System.EventHandler(this.Button1_Click);
   this.Button2.Click += new System.EventHandler(this.Button2_Click);
   this.Load += new System.EventHandler(this.Page_Load);

  }
  #endregion

  private void Button1_Click(object sender, System.EventArgs e)
  {
   WriteImage();
  }

  private void Button2_Click(object sender, System.EventArgs e)
  {
   try
   {
    ReadImage();
   }
   catch(Exception ep)
   {
    conn.Close();
    Response.End();
   }
  }
 }
}

分享到:
评论

相关推荐

    C# asp.net 图片存进数据库二进制和读取

    ### C# ASP.NET 图片存进数据库二进制与读取 #### 一、概述 在Web开发中,经常需要处理图片数据。特别是在ASP.NET框架下,如何将用户上传的图片存储到数据库,并且能够在需要时正确地读取出来显示或进行其他操作,...

    C# 对SqlServer中Image字段的读写(例子)

    在C#编程环境中,我们经常需要处理这类数据,包括从数据库读取`Image`字段并显示为图片,或者将图片数据写入数据库。本篇文章将详细探讨如何在C#中与SQL Server的`Image`字段进行交互。 1. **二进制数据的处理** ...

    《ASP.NET+SQL Server动态网站开发》光盘

    在本书中,读者将学习到如何设计和构建数据库模型,使用ASP.NET创建用户界面,以及如何通过ASP.NET和SQL Server之间的交互处理用户请求和数据操作。此外,可能还会涉及到ASP.NET的安全特性,如角色管理和身份验证,...

    aspnet(C#)实现从sqlserver数据库中下载以二进制存储的图片

    在ASP.NET(C#)开发中,常常需要处理存储在SQL Server数据库中的二进制数据,例如图片、PDF文档等。本教程将详细讲解如何从数据库中下载这些以二进制形式存储的图片。 首先,我们需要了解数据库中二进制数据的存储...

    C# ASP.NET 模块 - 数据库备份与恢复模块

    总的来说,C# ASP.NET 数据库备份与恢复模块是企业级应用程序不可或缺的部分,它涉及到了SQL Server和Access数据库的备份、恢复、分离和附加等多个方面。通过理解和掌握这些知识,开发者能够构建出更健壮、更安全的...

    《ASP.NET + SQL Server动态网站开发案例精选》随书光盘

    通过这些案例,读者不仅可以深入理解ASP.NET和SQL Server的集成,还能学习到实际项目开发中的最佳实践。每个案例都应包含完整代码、详细步骤和预期结果,帮助读者动手实践,从而更好地掌握这些关键技能。

    c# asp.net 与 excel文件转换

    这篇教程主要关注如何使用C# ASP.NET来实现Excel文件的导入和导出功能,这对于初学者来说是非常实用的知识点。 首先,我们要了解ASP.NET C#中的Excel操作涉及的主要库。微软提供了一个名为`Microsoft.Office....

    C# ASP.NET - 音乐在线点播

    C#提供了System.IO命名空间,其中的FileStream和StreamReader等类可用于读取、写入和操作文件。为了在线试听,可能还使用了嵌入式媒体播放器控件或者JavaScript库来实现音频播放。 4. **数据库设计**: 音乐库信息...

    asp.net,ado.net,c#,sqlserver

    在ASP.NET和ADO.NET中,SQL Server通常作为后端数据库,存储应用程序的数据。开发者可以通过ADO.NET的Command对象执行SQL查询,或者使用DataSet和DataTable对象在内存中操作数据。 在ASP.NET小程序中,通常会用到...

    ASP.NET 2.0+SQL Server 2005全程指南-源代码

    ASP.NET 2.0+SQL Server 2005全程指南 目录 基础篇 第1章 ASP.NET概述及环境配置 1.1 认识ASRNET 1.1.1 .NET Framework框架 1.1.2 ASP.NET功能与特性 1.1.3 ASP.NET与ASP的区别 1.2 搭建ASP.NET开发环境 1.2.1...

    C# asp.net 网络硬盘

    3. **文件系统操作**:在"网络硬盘"项目中,C#代码会涉及到大量的文件系统操作,如读取、写入、移动、删除文件,以及创建和管理文件夹。这需要使用到System.IO命名空间中的类和方法,例如File、FileInfo、Directory...

    我的博客系统c#asp.net做的很好的

    【标题】"我的博客系统c#asp.net做的很好的"揭示了这个项目是使用C#编程语言和ASP.NET框架开发的一个博客平台。C#是一种面向对象的编程语言,广泛应用于Windows和Web应用程序开发,而ASP.NET是.NET框架的一部分,...

    C# asp.Net 做的给照片添加水印标志

    综上所述,这个项目展示了C#和ASP.NET结合处理图片加水印的技术,为Web应用中的图片版权保护提供了一个实用的解决方案。通过理解这些知识点,开发者可以进一步扩展此功能,例如添加批量加水印、自定义水印样式等功能...

    办公事务管理系统(ASP.net+SQL server 2000 .C#)

    【描述】:这个项目是一个基于ASP.NET技术和C#编程语言的办公事务管理系统,结合了SQL Server 2000作为数据库存储解决方案。它包含完整的源代码,并且使用了Visual Studio 2005作为开发环境。作为毕业设计,这个系统...

    C#+SQLSERVER网上教学系统

    同时,C#的ADO.NET库是连接和操作SQL Server数据库的关键工具,通过DataSet、DataTable、DataAdapter等对象,实现了数据的读取、写入和更新。 SQL Server作为后端数据库管理系统,具有高性能、可扩展性和安全性。在...

    A015.ASP.NET+SQLSERVER+教务管理系统(选课系统)+论文.zip

    此外,ASP.NET与SQL SERVER之间的数据交互通常通过ADO.NET实现,这是一种数据访问技术,可以方便地进行数据的读取、写入和更新操作。 教务管理系统的核心功能包括:学生管理、教师管理、课程管理、选课管理、成绩...

    十天学会ASP.net--我认为ASP.NET比ASP难很多,希望大家做好准备

    在ASP.NET中,编程语言增加了C#,提供了VB.NET、C#、ACCESS和SQL的四种组合。ASP.NET的编程模型更加面向对象,允许更灵活的实现同一效果的方法,但这也使得初学者可能会感到困惑。 【环境配置】学习ASP.NET需要安装...

    asp.net+sql server 开发的花店网站源码

    通过ADO.NET,ASP.NET可以与SQL Server进行无缝集成,实现数据的读取、写入和更新操作。 在花店网站的源码中,我们可能会看到以下几个关键组成部分: 1. **用户界面(UI)**:使用ASP.NET Web Forms或者Classic ...

Global site tag (gtag.js) - Google Analytics