ASP.NET数据库图片存储到Sql2000中
创始人
2024-04-23 10:51:45
0

在很多时候,我们有这样的需求:把图片存入到数据库当中。在一些应用程序中,我们可能有一些敏感的资料,由于存储在文件系统(file system)中的东西,将很容易被某些用户盗取,所以这些数据不能存放在文件系统中。

    在这篇文章中,我们将讨论怎样把图片存入到Sql2000当中。

    在这篇文章中我们可以学到以下几个方面的知识:

    1. 插入图片的必要条件

    2. 使用流对象

    3. 查找准备上传的图片的大小和类型

    4.怎么使用InputStream方法?

ASP.NET数据库图片存储:插入图片的必要条件

在我们开始上传之前,有两件重要的事我们需要做:

#Form 标记的 enctype 属性应该设置成 enctype="multipart/form-data"

# 需要一个表单来使用户选择他们要上传的文件,同时我们需要导入 System.IO名称空间来处理流对象

把以上三点应用到aspx页面。同时我们需要对SqlServer做以下的准备。

# 需要至少含有一个图片类型的字段的表

# 如果我们还有另外一个变字符类型的字段来存储图片类型,那样会更好一些。

现在,我们准备了一个Sql表(包含了一个image数据类型的字段),还有标记。当然我们还得准备Submit按钮,以便用户在选择了图片以后提交。在这个按钮的Onclick事件里,我们需要读取选取图片的内容,然后把它存入到表里。那我们先来看看这个Onclick事件。

提交按钮的Onclick事件的代码:

  1. Dim intImageSize As Int64   
  2.      Dim strImageType As String   
  3.      Dim ImageStream As Stream  
  4.  
  5.     ’ Gets the Size of the Image   
  6.     intImageSize = PersonImage.PostedFile.ContentLength  
  7.  
  8.     ’ Gets the Image Type   
  9.     strImageType = PersonImage.PostedFile.ContentType  
  10.  
  11.     ’ Reads the Image   
  12.     ImageStream = PersonImage.PostedFile.InputStream  
  13.  
  14.     Dim ImageContent(intImageSize) As Byte   
  15.     Dim intStatus As Integer   
  16.     intStatus = ImageStream.Read(ImageContent, 0, intImageSize)  
  17.  
  18.     ’ Create Instance of Connection and Command Object   
  19.     Dim myConnection As New SqlConnection(ConfigurationSettings.AppSettings("ConnectionString"))   
  20.     Dim myCommand As New SqlCommand("sp_person_isp", myConnection)  
  21.  
  22.     ’ Mark the Command as a SPROC   
  23.     myCommand.CommandType = CommandType.StoredProcedure  
  24.  
  25.     ’ Add Parameters to SPROC   
  26.     Dim prmPersonImage As New SqlParameter("@PersonImage", SqlDbType.Image)   
  27.     prmPersonImage.Value = ImageContent   
  28.     myCommand.Parameters.Add(prmPersonImage)  
  29.  
  30.     Dim prmPersonImageType As New SqlParameter("@PersonImageType", SqlDbType.VarChar, 255)   
  31.     prmPersonImageType.Value = strImageType   
  32.     myCommand.Parameters.Add(prmPersonImageType)  
  33.  
  34.     Try   
  35.         myConnection.Open()   
  36.         myCommand.ExecuteNonQuery()   
  37.         myConnection.Close()  
  38.        Response.Write("New person successfully added!")   
  39.     Catch SQLexc As SqlException   
  40.         Response.Write("Insert Failed. Error Details are: " & SQLexc.ToString())   
  41.     End Try 

这是怎么实现ASP.NET数据库图片存储的呢?

PersonImage是HTMLInputFile控件的对象。首先需要获得图片的大小,可以使用下面的代码实现:

intImageSize = PersonImage.PostedFile.ContentLength

然后返回图片的类型使用ContenType属性。***,也是最重要的事就是取得Image Stream,这可以用以下代码实现:

ImageStream = PersonImage.PostedFile.InputStream

我们需要一个字节型数组来存储image 内容。读取整个图片可以使用Stream对象的Read方法来实现。Read(in byte[] buffer,int offset,int count)方法有三个参数。他们是:

buffer

字节数组。此方法返回时,该缓冲区包含指定的字符数组,该数组的 offset 和 (offset + count) 之间的值由从当前源中读取的字节替换。

offset

buffer 中的从零开始的字节偏移量,从此处开始存储从当前流中读取的数据。

count

要从当前流中最多读取的字节数。

这个Read方法用以下代码实现:
intStatus = ImageStream.Read(ImageContent, 0, intImageSize)
.

现在,我们已经读取了整个图片的内容,下一步,我们要把这些内容存入到sql 表。我们将使用存储过程来完成插入图片类型和图片内容到sql 表。如果你浏览了上面的代码,你将会发现我们使用了sqldbtype.image的数据类型(datatype)。Ok了,完成了这些,我们也就成功的把图片存入到SqlServer中了。下面是我们编写的aspx页面。

ASP.NET数据库图片存储:图片存入数据库结论

我们已经讨论了如何把图片存入到Sql Server,那么我们如何从SqlServer中读取图片呢?可以参看我的另一篇文章:在Asp.Net中从SqlServer中检索图片。

【编辑推荐】

  1. ASP.NET自定义错误处理页面的添加
  2. ASP.NET中的session存储模式运用
  3. ASP.NET中的文件上传下载方法集合
  4. ASP.NET中的cookie读写方法介绍
  5. ASP.NET中的javascript操作

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...