ASP.NET中圖片顯示方法實(shí)例
本文實(shí)例講述了ASP.NET中圖片的顯示方法。分享給大家供大家參考。具體如下:
genimage.ashx:
genimage.ashx.cs:
// Copyright (C) 2003 by Greg Ennis // (mailto:greg@ennis.net) // // The contents of this file are subject to the Artistic License (the "License"). // You may not use this file except in compliance with the License. // You may obtain a copy of the License at: // http://www.opensource.org/licenses/artistic-license.html using System; using System.Collections; using System.ComponentModel; using System.Data; using System.Data.SqlClient; using System.Drawing; using System.Web; using System.IO; using System.Configuration; using System.Web.SessionState; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.HtmlControls; namespace netpix { public class ImageGenerator : IHttpHandler { public bool IsReusable { get { return true; } } public void ProcessRequest(HttpContext Context) { // Get the image filename and album root path from the database //圖片瀏覽次數(shù) int numviews; //圖片數(shù)據(jù)庫(kù)中的ID int picid = Convert.ToInt32(Context.Request["id"]); //圖片路徑 string imgpath = npdata.GetPathToPicture(picid, out numviews); // Writing an image to output stream Context.Response.ContentType = "image/jpg"; // 'thumbnail' means we are requesting a thumbnail //顯示縮略圖 if (Context.Request["thumbnail"] != null) { // Need to load the image, resize it, and stream to the client. // Calculate the scale so as not to stretch or distort the image. Bitmap bmp = new Bitmap(imgpath); float scale = 150.0f / System.Math.Max(bmp.Height, bmp.Width); System.Drawing.Image thumb = bmp.GetThumbnailImage((int)(bmp.Width * scale), (int)(bmp.Height * scale), null, System.IntPtr.Zero); thumb.Save(Context.Response.OutputStream, System.Drawing.Imaging.ImageFormat.Jpeg); bmp.Dispose(); thumb.Dispose(); } else { // Stream directly from the file // Get the stream and send it out the response System.IO.FileStream fs = File.Open(imgpath, FileMode.Open, FileAccess.Read, FileShare.Read); const int byteLength = 8192; byte[] bytes = new byte[byteLength]; while( fs.Read(bytes, 0, byteLength ) != 0 ) { Context.Response.BinaryWrite(bytes); } fs.Close(); //更新數(shù)據(jù)庫(kù)瀏覽次數(shù) npdata.SetNumViews(picid, numviews+1); } } } }
使用方法:
希望本文所述對(duì)大家的ASP.NET程序設(shè)計(jì)有所幫助。
- Asp.net FileUpload+Image制作頭像效果示例代碼
- asp.net顯示圖片到指定的Image控件中 具體實(shí)現(xiàn)
- asp.net驗(yàn)證碼圖片生成示例
- ASP.NET實(shí)現(xiàn)圖片以二進(jìn)制的形式存入數(shù)據(jù)庫(kù)
- 使用asp.net改變網(wǎng)頁(yè)上圖片顏色比如灰色變彩色
- 使用asp.net改變圖片顏色如灰色的變成彩色
- Asp.net簡(jiǎn)單實(shí)現(xiàn)給圖片增加文字水印
- ASP.NET簡(jiǎn)單好用功能齊全圖片上傳工具類(水印、縮略圖、裁剪等)
- Asp.Net上傳圖片同時(shí)生成高清晰縮略圖
- asp.net文件上傳解決方案(圖片上傳、單文件上傳、多文件上傳、檢查文件類型)
- ASP.NET圖片處理三類經(jīng)典問(wèn)題
- asp.net fileupload控件上傳圖片并預(yù)覽圖片
- ASP.NET圖片上傳實(shí)例(附源碼)
- ASP.NET實(shí)現(xiàn)上傳圖片并生成縮略圖的方法
- asp.net實(shí)現(xiàn)圖片以二進(jìn)制流輸出的兩種方法
- ASP.NET中Image控件使用詳解
相關(guān)文章
ASP.net中網(wǎng)站訪問(wèn)量統(tǒng)計(jì)方法代碼
這篇文章介紹了ASP.net中網(wǎng)站訪問(wèn)量統(tǒng)計(jì)方法代碼,有需要的朋友可以參考一下2013-11-11ASP.NET Session會(huì)導(dǎo)致的性能問(wèn)題
你的站點(diǎn)有被客戶投訴很慢嗎?是不是查了很多遍還是沒有完全解決?是不是數(shù)據(jù)庫(kù)沒有發(fā)現(xiàn)異常,CPU也沒有異常,內(nèi)存占用量沒有異常,GC計(jì)數(shù)沒有異常,硬盤IO也沒有異常,帶寬沒有異常,線路沒有異常,沒有丟包,但就是被投訴?2009-07-07ASP.NET實(shí)現(xiàn)TreeView的XML數(shù)據(jù)源綁定實(shí)例代碼
這篇文章介紹了ASP.NET實(shí)現(xiàn)TreeView的XML數(shù)據(jù)源綁定實(shí)例代碼,有需要的朋友可以參考一下2013-11-11.net簡(jiǎn)單使用Log4net的方法(多個(gè)日志配置文件)
log4net是.net中常用的一個(gè)日志記錄工具,下面這篇文章主要給大家介紹了關(guān)于.net簡(jiǎn)單使用Log4net的方法(多個(gè)日志配置文件),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧2018-11-11ASP.Net Post方式獲取數(shù)據(jù)流的一種簡(jiǎn)單寫法
這篇文章主要介紹了ASP.Net Post方式獲取數(shù)據(jù)流的一種簡(jiǎn)單寫法,本文直接給出代碼實(shí)例,需要的朋友可以參考下2015-05-05asp.net下生成英文字符數(shù)字驗(yàn)證碼的代碼
用了asp.net隨機(jī)數(shù),獲取指定位數(shù)的字母或數(shù)字以后,進(jìn)行圖片輸出的驗(yàn)證碼函數(shù)。2009-12-12簡(jiǎn)單使用BackgroundWorker創(chuàng)建多個(gè)線程的教程
簡(jiǎn)單使用BackgroundWorker創(chuàng)建多個(gè)線程的教程,需要的朋友可以參考一下2013-03-03詳解ASP.NET Core Web Api之JWT刷新Token
這篇文章主要介紹了詳解ASP.NET Core Web Api之JWT刷新Token,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11