ImageVerifierCode 换一换
格式:DOCX , 页数:18 ,大小:642.75KB ,
资源ID:26387382      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/26387382.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(五十三在Data Web控件显示二进制数据.docx)为本站会员(b****9)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

五十三在Data Web控件显示二进制数据.docx

1、五十三在Data Web控件显示二进制数据在ASP.NET 2.0中操作数据之五十三:在Data Web控件显示二进制数据作者:heker2007 字体:增加减小 类型:转载 时间:2016-05-17我要评论本文主要介绍在ASP.NET 2.0中直接显示PDF超链接的方法,以及如何把已二进制数据形式保存的图片显示在GridView中的方法,虽然这种方法在实际开发中很少用,但还是值得学习一下。导言:在前面的教程我们阐述了应用程序处理二进制数据的2种模式,以及使用FileUpload 控件从浏览器向服务器文件系统上传文件。当文件上传并存储在文件系统里时,应在相应的数据库记录里存储该文件的存储路径

2、。我们先来看如何为最终用户提供二进制数据。怎样展示二进制数据呢?这取决于其类型。比如图片,我们将其显示为image;如果是PDFs,Microsoft Word文档、ZIP文件或其它类型的数据,或许提供一个“Download”链接比较妥当。在本节,我们看如何在GridView和DetailsView一类的数据Web控件里呈现二进制数据,在后面的教程我们将注意力转向将上传文件和数据库联系起来。第一步:提供BrochurePath值表Categories的Picture列存储相关类的图片信息。具体的讲,为16色的低质量位图,大小为172乘120像素,约11 KB。另外还包括一个约78字节的OLE报

3、头,在显示图片的时候需要将其剥离。为什么会有报头信息呢?因为数据库Northwind源于微软的Access数据库。在Access里二进制数据OLE类型来存储的,该类型会添加报头。现在,我们看如何从图片剥离报头,以便显示。在后面的教程我们将创建一个界面,将带报头的这些位图替换为不带报头的等价的JPG图片。前面我们考察了如何使用FileUpload控件,让我们继续为服务器文件系统添加文件。不过暂时不用更新Categories表的BrochurePath列,那是下一章的内容。我们现在需要手工为BrochurePath赋值。在本教程,当你下载东西时,可以看到在/Brochures7文件夹有7个PDF小

4、册子,每个小册子对应一个种类,Seafood除外。我故意没为Seafood提供PDF小册子,以便探讨如何处理某些记录没有附带二进制数据的情况。在服务器资源管理器里右键点击Categories,选“查看表数据”,输入文件路径,如图1所示。由于Seafood类没有图片,将其BrochurePath的值设为“NULL”。图1:手工为表Categories的BrochurePath列键入值第2步:在GridView里添加一个下载链接当为表Categories的BrochurePath列赋值后,我们准备创建一个GridView用于展示每个种类,并附带一个链接下载每个类的小册子。在第4步我们将扩展Grid

5、View以显示每个类的图片。打开BinaryData文件夹的DisplayOrDownloadData.aspx页面并进入设计模式,从工具箱里拖一个GridView控件到页面,设其ID为Categories,从其智能标签选择绑定到一个名为CategoriesDataSource的ObjectDataSource控件。该控件调用类CategoriesBLL的GetCategories()方法。图2:创建一个名为CategoriesDataSource的ObjectDataSource控件图3:设置ObjectDataSource使用CategoriesBLL类图4:调用GetCategories

6、()方法完成设置后,Visual Studio自动的为CategoryID, CategoryName, Description, NumberOfProducts和BrochurePath生成BoundField。移除NumberOfProducts,因为GetCategories()方法用不上,同样将CategoryID移除了。分别把CategoryName和 BrochurePath的HeaderText属性改为“Category”和“Brochure”。做上述修改后,你的GridView and ObjectDataSource的声明代码看起来应该像下面的这样:?12345678910

7、11121314151617在浏览器查看该页(如图5)。列出了所有的8个类,除了Seafood,其它7个类的BoundField列里显示各自的BrochurePath值。由于Seafood的BrochurePath为NULL值,看起来为空格。图5:显示了每个类别的Name, Description和BrochurePath值与其显示BrochurePath的text值,不如创建一个指向小册子的链接。移除BrochurePath,代之以HyperLinkField。设它的HeaderText属性为“Brochure”,Text属性为“View Brochure”, DataNavigateUrl

8、Fields属性为“ BrochurePath”。图6:添加一个指向BrochurePath的HyperLinkField这样将在GridView里添加一列链接,如图7所示。点“View Brochure”时要么直接在浏览器显示PDF,要么提示用户下载该文件。这取决于浏览器的设置以及是否安装了PDF阅读器。图7:点击“View Brochure”访问某类的Brochure图8:显示某类的PDF文件隐藏无小册子图片的类的“View Brochure” 文本如图7所示,不管某个类的BrochurePath是否为NULL值,名为BrochurePath的HyperLinkField都呈现为其Text

9、属性(“View Brochure”) 。当然,如果BrochurePath为NULL值,链接只显示为文本(而不带下划线),就像Seafood类一样(见图7)。与显示文本“View Brochure”相比,更为可取的是将那些BrochurePath值为空的类显示为“No Brochure Available”。为达此目的,我们需要用到TemplateField,使其产生一个基于BrochurePath值的合适的结果。我们先来看看如何实现,就像在教程之12在GridView控件中使用TemplateField一样。在“编辑列”对话框里选中名为BrochurePath的HyperLinkField

10、,再点“Convert this field into a TemplateField”链接,将其转换为TemplateField。图9:将HyperLinkField转换为TemplateField这样将创建一个TemplateField,其ItemTemplate模板包含一个HyperLink Web控件,该控件的NavigateUrl属性为BrochurePath值。用下面的代码将其替换掉:?12345然后,在ASP.NET页面的“后台代码”里添加一个protected类型的GenerateBrochureLink方法,它接受一个输入参数并返回一个字符串。?12345678protect

11、ed string GenerateBrochureLink(object BrochurePath)if (Convert.IsDBNull(BrochurePath)return No Brochure Available;elsereturn string.Format(View Brochure,ResolveUrl(BrochurePath.ToString();该方法判断传入的值是否为NULL。如果是,则返回一个消息指出该类没有小册子文件;相反,如果传入值不为空,将显示为一个链接。我们注意到,当BrochurePath值不为空时,将调用ResolveUrl(url)方法。该方法的作

12、用在于将传入的相对路径转换为物理路径。比如应用程序的根目录在/Tutorial55,ResolveUrl(/Brochures/Meats.pdf)返回的路径是/Tutorial55/Brochures/Meat.pdf.图10为经过上述修改后的界面。我们注意到Seafood类的BrochurePath列现在显示为文本“No Brochure Available”.图10:没有小册子的类将显示为文本“No Brochure Available”第3步:新增页面以显示类的图片当用户访问一个ASP.NET页面时,他将接收该页面的HTML代码。HTML代码仅仅包含了text文本,而并不包含任何的二进

13、制数据。任何的二进制数据,比如图片,音乐文件、Flash程序、Windows Media Player视频等,以独立资源的形式存放于服务器。HTML只包含了这些文件的引用,并不包含这些文件本身。比如,在HTML里元素用来引用一张图片,其src属性指向该图片文件,如:当浏览器收到HTML代码时,它向服务器发送获取图片的请求并将其显示在浏览器中,该模式对所有的二进制数据都适用。在第2步中,我们没有在页面的HTML标记里将小册子显示在浏览器,而是在HTML标记里提供一个超链接,当点击它是,导致浏览器直接请求PDF文件。为了显示或允许用户下载储存在数据库中的二进制数据,我们需要另外创建一个页面,用于从

14、数据库返回所需的数据。对我们的应用程序而言,由于直接存储在数据库中的二进制数据只有一项类的图片,所以我们需要一个页面,当需要时从数据库返回某个特定类的图片。在BinaryData文件夹添加一个DisplayCategoryPicture.aspx页面,注意不要使用母版页。该页面接受一个包含CategoryID值的查询字符串,返回Picture列的二进制数据。由于该页只返回二进制数据,所以我们不需要页面的HTML部分有任何代码。进入页面的“源码”模式,删除页面的所有代码,只保留部分。也即:DisplayCategoryPicture.aspx页面的声明代码应该只由如下的单独行构成:?123如果里

15、包含有MasterPageFile属性,将其删除,同时在后台代码类的Page_Load事件处理器里添加如下代码:?1234567891011121314151617181920212223protected void Page_Load(object sender, EventArgs e)int categoryID = Convert.ToInt32(Request.QueryStringCategoryID);/ Get information about the specified categoryCategoriesBLL categoryAPI = new CategoriesBL

16、L();Northwind.CategoriesDataTable categories =categoryAPI.GetCategoryWithBinaryDataByCategoryID(categoryID);Northwind.CategoriesRow category = categories0;/ Output HTTP headers providing information about the binary dataResponse.ContentType = image/bmp;/ Output the binary data/ But first we need to

17、strip out the OLE headerconst int OleHeaderLength = 78;int strippedImageLength = category.Picture.Length - OleHeaderLength;byte strippedImageData = new bytestrippedImageLength;Array.Copy(category.Picture, OleHeaderLength,strippedImageData, 0, strippedImageLength);Response.BinaryWrite(strippedImageDa

18、ta);代码先读取查询字符串的CategoryID值,并对名为categoryID的变量赋值。然后,通过调用CategoriesBLL类的GetCategoryWithBinaryDataByCategoryID(categoryID)方法获取图片数据,再通过Response.BinaryWrite(data)方法向客户端返回数据。不过在此之前先要剥离数据的OLE报头。怎么实现呢?创建一个名为strippedImageData的byte数组,它包含的字节刚好比Picture列的数据少78。而Array.Copy方法将从category.Picture的第78个字节开始复制数据(即刚好剥离OLE

19、报头)。代码中的Response.ContentType属性指定了要返回内容的MIME type,以便浏览器知道如何显示数据。由于Categories表的Picture列存储的是位图图片,故在这里,位图图片的MIME type是(image/bmp). 如果你忽视了MIME type,绝大多数浏览器也可以正确的显示图像,因为,它们能根据图像文件的二进制数据的内容而推断其类型。即便如此,还是尽可能的使用MIME type。创建页面后,可以访问页面DisplayCategoryPicture.aspx?CategoryID=categoryID来查看某个特定类的图片。图11显示的是Beverage

20、s类的图片,页面为DisplayCategoryPicture.aspx?CategoryID=1.图11:显示类Beverages的图片有时候,当你访问DisplayCategoryPicture.aspx?CategoryID=categoryID页面时,有可能显示这样的提示:“Unable to cast object of type System.DBNull to type System.Byte”。原因有可能是如下2方面。第一,表Categories的Picture列允许为NULL值,而DisplayCategoryPicture.aspx page页面总是假定传入的为非NULL值

21、。当Picture为NULL值时,不能直接访问CategoriesDataTable的Picture属性。如果你允许Picture为NULL值,添加如下代码:?1234567891011if (category.IsPictureNull()/ Display some No Image Available pictureResponse.Redirect(/Images/NoPictureAvailable.gif);else/ Send back the binary contents of the Picture column/ . Set ContentType property an

22、d write out ./ . data via Response.BinaryWrite .上述代码假定在Images文件夹里存在名为NoPictureAvailable.gif的图片,当某个类没有图片时,就显示该图片。另一种情况:当你在向导里选用“使用SQL语句”的模式再次运行主查询时,它将影响GetCategoryWithBinaryDataByCategoryID方法的SELECT命令返回的列(换句话说,主查询没有返回Picture列,再次运行主查询时将使GetCategoryWithBinaryDataByCategoryID方法也不会返回Picture列)。所以,应确保GetCa

23、tegoryWithBinaryDataByCategoryID方法的SELECT命令返回Picture列。注意:每次访问DisplayCategoryPicture.aspx页面时,都会访问数据库并返回所需的图片。如果图片自最近一次访问以来没有改变过的话,这样每次访问数据库再返回数据的做法效率是不高的。幸运的是,HTTP允许使用conditional GETs,这样的话,客户端使HTTP请求发送一个If-Modified-Since HTTP header。If-Modified-Since HTTP header包含了客户端最近一次从服务器获取的数据以及时间。如果请求的内容没有发生改变,服

24、务器响应为Not Modified status code (304),并不返回请求的内容。简而言之,如果请求的资源自最近一次访问以来没发送改变的话,服务器将不会回传该资源,以达到减轻服务器负荷的目的。第四步:在GridView控件里显示Category Pictures现在我们有一个web页面来显示某个特定种类的图片的。通过Image Web控件或 HTML 元素来指向DisplayCategoryPicture.aspx?CategoryID=categoryID页面,从而达到显示该图片的目的。我们可以在GridView控件或DetailsView控件的 ImageField里显示图片。I

25、mageField的DataImageUrlField属性、DataImageUrlFormatString属性与HyperLinkField的DataNavigateUrlFields属性、DataNavigateUrlFormatString属性用法相似。让我们对DisplayOrDownloadData.aspx页面里名为Categories的GridView控件进行扩充。添加一个ImageField,设其DataImageUrlField属性为CategoryID;DataImageUrlFormatString属性为DisplayCategoryPicture.aspx?CategoryID=0。这样将为GridView增加一列,呈现为一个元素,其src属性为DisplayCategoryPicture.aspx?CategoryID=0,其中0将由GridView row的CategoryID值填充。图12:为GridView控件添加一个ImageField添加完成后,你的GridView控件的声明代码看起来应像下面这样:?123456789101112131415161718asp:ImageField DataImageUrlFi

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1