欢迎来到课桌文档! | 帮助中心 课桌文档-建筑工程资料库
课桌文档
全部分类
  • 党建之窗>
  • 感悟体会>
  • 百家争鸣>
  • 教育整顿>
  • 文笔提升>
  • 热门分类>
  • 计划总结>
  • 致辞演讲>
  • 在线阅读>
  • ImageVerifierCode 换一换
    首页 课桌文档 > 资源分类 > PPT文档下载  

    图片管理系统.ppt

    • 资源ID:248000       资源大小:2.95MB        全文页数:89页
    • 资源格式: PPT        下载积分:10金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要10金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    图片管理系统.ppt

    图片管理系统,需求分析,1.创建专辑/修改专辑封皮图片及简介/删除专辑/按名称查询专辑;2.为专辑添加图片/浏览专辑图片/删除选中图片/修改图片简介及所属专辑名;3.分页查询,用力图,功能结构图,数据表设计,数据表设计,系统模块划分,开发步骤,1、文件新建网站,在站点下新 建App_Code和 App_Data 文件夹;2、将数据库文件及数据库日志文 件,存放在App_Data中;3、右击App_Code,添加新 项,添加类文件SqlHelper.cs 和DB.cs;4、右击站点添加配置文件 web.config5、添加两个文件夹image和 logo分别存放图片,利用SqlDataSource生成数据库连接字符串,将SqlDataSource生成的数据库连接字符串复制到web.config中,然后就可以删除该SqlDataSource,如下所示:,为了代码重用,为了体现分层思想,我们将数据库连接代码写在SqlHelper.cs公共类中,将数据库操作代码写在DB.cs公共类中。SqlHelper.cs中:1、右击站点添加引用.NETSystem.Configuration2、代码中添加using System.Data;using System.Data.SqlClient;,SqlHelper.cs代码如下:public class SqlHelper private static readonly string ConnectionString=ConfigurationManager.ConnectionStringsConnectionString.ConnectionString;SqlConnection conn=new SqlConnection(ConnectionString);public SqlCommand GetCommand(string sqlStr,params SqlParameter cmdparms)SqlCommand cmd=new SqlCommand();cmd.Connection=conn;cmd.CommandText=sqlStr;cmd.CommandType=CommandType.Text;if(cmdparms!=null)foreach(SqlParameter p in cmdparms)cmd.Parameters.Add(p);return cmd;public SqlHelper()conn.Open();,DB.cs代码(首先引用using System.Data.SqlClient;)public class DBpublic DB()/TODO:在此处添加构造函数逻辑/在首页上显示所有专辑信息 public DataTable GetAll()SqlHelper helper=new SqlHelper();string strsql=select*from album;SqlCommand cmd=new SqlCommand();cmd=helper.GetCommand(strsql,null);DataTable dt=new DataTable();using(SqlDataReader rdr=cmd.ExecuteReader()dt.Load(rdr);return dt;,/在首页上按名称查询专辑信息 public DataTable GetByID(int id)SqlHelper helper=new SqlHelper();string strsql=select*from album where albumID=albumID;SqlParameter parm=new SqlParameter new SqlParameter(albumID,id);SqlCommand cmd=new SqlCommand();cmd=helper.GetCommand(strsql,parm);DataTable dt=new DataTable();using(SqlDataReader rdr=cmd.ExecuteReader()dt.Load(rdr);return dt;,/为首页的专辑名称下拉菜单绑定名称 public DataTable GetAlbumName()SqlHelper helper=new SqlHelper();string strsql=select albumID,albumName from album;SqlCommand cmd=new SqlCommand();cmd=helper.GetCommand(strsql,null);DataTable dt=new DataTable();using(SqlDataReader rdr=cmd.ExecuteReader()dt.Load(rdr);return dt;,当SqlHelper.cs和DB.cs两个公共类写好后,右击站点,生成网站,检查是否生成成功。如果生成成功,做如下操作:,利用GridView显示专辑信息,用上述方法新建数据源对象,与上述方法中不同的是,选择的DB方法不同。注意:GridView的属性设置:AllowPaging=True,AutoGenerateColumns=False,DataKeyNames=albumID,PageSize=2.,利用GridView显示专辑信息,用上述方法新建数据源对象,与上述方法中不同的是,选择的DB方法不同。,给GridView编辑列,如下所示:BoundField:专辑编号、专辑名称、专辑创建时间TemplateField:专辑封面HyperLinkField:为专辑添加图片、浏览专辑图片、修改专辑CommandField:删除,注意检查GridView的属性设置:AllowPaging=“True”AutoGenerateColumns=“False”DataKeyNames=“albumID”PageSize=“2”,增加查询按钮Button,新建ObjectDataSource,配置数据源,选择DB中的GetByID,双击查询按钮buttton1,进入Default.aspx.cs代码中编辑:protected void Button1_Click(object sender,EventArgs e)GridView1.DataSourceID=ObjectDataSource3.ID;GridView1.DataBind();,对于”创建专辑”按钮按下后,应该打开新的窗体AddAlbum.aspx,实现专辑名称,专辑封面图片和专辑简介信息的添加.如下图:,在DB.cs中继续添加功能块,实现添加专辑信息的功能public void AddAlbum(string albumName,DateTime albumTime,string logoUrl,string albumDesc)SqlHelper helper=new SqlHelper();string strsql=insert into album(albumName,albumTime,logoUrl,albumDesc)values(name,time,logourl,desc);SqlParameter parm=new SqlParameter new SqlParameter(name,albumName),new SqlParameter(time,albumTime),new SqlParameter(logourl,logoUrl),new SqlParameter(desc,albumDesc);SqlCommand cmd=helper.GetCommand(strsql,parm);cmd.ExecuteNonQuery();,双击”提交”按钮,将专辑信息添加到album数据表中.,protected void Button1_Click(object sender,EventArgs e)DB db=new DB();string albumName=TextBox1.Text;DateTime albumTime=DateTime.Now;string logourl=image/+FileUpload1.FileName;string exname=FileUpload1.FileName.Split(.)1;string albumDesc=TextBox2.Text;if(exname.ToLower()=jpg|exname.ToLower()=gif|exname.ToLower()=png)FileUpload1.SaveAs(Server.MapPath(logourl);db.AddAlbum(albumName,albumTime,logourl,albumDesc);Response.Write(alert(创建专辑成功);location.href=default.aspx;);,为专辑添加图片功能的实现:右击站点添加新页面addimage.aspx,给image数据表添加信息,再次给GridView编辑列,如下所示:查看HyperLinkField列:为专辑添加图片,DataNavigateUrlFields:albumID绑定到超链接的NavigateUrl属性字段;DataNavigateUrlFormatString:addimage.aspx?id=0对绑定到超链接的NavigateUrl属性的值应用的格式设置.给image数据表添加信息:,/打开DB.cs,添加方法,实现给专辑添加照片功能:public void addimage(int albumID,string imageName,string imageUrl,DateTime imageTime,string imageDesc)SqlHelper helper=new SqlHelper();string addimage=insert into image(albumID,imageName,imageUrl,imageTime,imageDesc)Values(albumID,imageName,imageUrl,imageTime,imageDesc);SqlParameter parm=new SqlParameter new SqlParameter(albumID,albumID),new SqlParameter(imageName,imageName),new SqlParameter(imageUrl,imageUrl),new SqlParameter(imageTime,imageTime),new SqlParameter(imageDesc,imageDesc);SqlCommand cmd=helper.GetCommand(addimage,parm);cmd.ExecuteNonQuery();,/点击addimage.aspx的“提交按钮”时:protected void Button1_Click(object sender,EventArgs e)DB db=new DB();int albumID=Convert.ToInt32(DropDownList1.SelectedValue);DateTime imageTime=DateTime.Now;string imageUrl=image/+FileUpload1.FileName;string imageType=FileUpload1.FileName.Split(.)1;string imageName=FileUpload1.FileName.Split(.)0;string imageDesc=TextBox1.Text.ToString();if(imageType.ToLower()=jpg|imageType.ToLower()=gif|imageType.ToLower()=png)FileUpload1.SaveAs(Server.MapPath(imageUrl);db.addimage(albumID,imageName,imageUrl,imageTime,imageDesc);Response.Write(alert(添加成功!);location.href=default.aspx;);,浏览专辑图片功能的实现:右击站点添加新页面ViewImage.aspx,首先对default.aspx的GridView进行编辑列操作,使得“浏览专辑图片按钮”具有超链接功能,可链到ViewImage.aspx如下所示:,/在DB.cs中编写方法,实现浏览某个专辑中的所有照片首先引用命名空间:using System.Text;和using System.Collections;public DataTable showImage(int albumID)SqlHelper helper=new SqlHelper();StringBuilder strsql_show=new StringBuilder();strsql_show.Append(select imageID,alb.albumID,alb.albumName,imageName,imageUrl,imageTime,imageDesc);strsql_show.Append(from image as img,album as alb where img.albumID=alb.albumID and img.albumID=id);SqlParameter parm=new SqlParameter new SqlParameter(id,albumID);SqlCommand cmd=helper.GetCommand(strsql_show.ToString(),parm);DataTable dt=new DataTable();using(SqlDataReader rdr=cmd.ExecuteReader()dt.Load(rdr);return dt;,设计ViewImage.asp页面,对GridView进行编辑列操作:CommandField:选择 showselectButton:true;BoundField:HeaderText:图片编号DataField:imageIDHeaderText:图片地址DataField:imageUrl HeaderText:图片名称DataField:imageNameHeaderText:所属专辑名DataField:albumNameHeaderText:图片上传时间DataField:imageTime,HeaderText:图片简介DataField:imageDescHyperLinkField:Text:修改图片所属专辑TemplateField,编辑模板:TemplateField,其中HeaderTemplate和ItemTemplate设计如下:,注意将GridView的属性设置如下:AllowPaging:True,AutoGenergateColumns:False,PageSize:2,DataKeyNames:imageID,设计ViewImage.aspx增加Button和DetailsView控件,给DetailsView控件编辑字段-添加模板,给DetailsView控件编辑模板,如下所示:Label1Text:Eval(“imageName”)Label2Text:Eval(“albumName”)Image1imageUrl:Eval(“imageUrl”)Label3Text:Eval(“imageTime”)Label4Text:Eval(“imageDesc”)并将DetailsView的AutoGenerateRows属性设为False,修改专辑功能的实现,为站点添加新页面updateAlbum.aspx,然后在Default.aspx中单击“修改专辑”导航到updateAlbum.aspx页面,在DB.cs中编写updateAlbum方法实现修改专辑信息的功能 public void updateAlbum(int id,string albumDesc,string albumName,DateTime albumTime,string logourl)SqlHelper helper=new SqlHelper();string strsql=update album set albumName=albumName,albumTime=albumTime,albumDesc=albumDesc,logoUrl=logourl where albumID=albumID;SqlParameter parm=new SqlParameter new SqlParameter(albumID,id),new SqlParameter(albumDesc,albumDesc),new SqlParameter(albumName,albumName),new SqlParameter(logourl,logourl),new SqlParameter(albumTime,albumTime);SqlCommand cmd=helper.GetCommand(strsql,parm);cmd.ExecuteNonQuery();,Textbox:TextMode:SingleLineImageFileuploadTextbox:TextMode:MultiLinebutton,因为进行修改时,要先把旧的数据显示在控件中,在此基础上修改再提交,所以要先按照从Default.aspx传过来的albumID查找出该专辑的所有信息,然后再修改提交。我们在DB.cs中写入新的方法select_albumMore,代码如下:public DataTable select_albumMore(int id)SqlHelper helper=new SqlHelper();string strsql=select albumName,logoUrl,albumDesc from album where albumID=albumID;SqlParameter parm=new SqlParameter new SqlParameter(albumID,id);SqlCommand cmd=helper.GetCommand(strsql,parm);DataTable dt=new DataTable();using(SqlDataReader rdr=cmd.ExecuteReader()dt.Load(rdr);return dt;,当点击default.aspx的修改专辑时,会打开updateAlbum.aspx页面,并触发该页面的Page_Load事件,代码如下所示:protected void Page_Load(object sender,EventArgs e)if(!IsPostBack)DB db=new DB();int albumID=Convert.ToInt32(Request.QueryStringid);TextBox1.Text=db.select_albumMore(albumID).Rows00.ToString();TextBox2.Text=db.select_albumMore(albumID).Rows02.ToString();Image1.ImageUrl=db.select_albumMore(albumID).Rows01.ToString();,在updateAlbum.aspx中点击”提交修改“按钮时,触发以下方法:protected void Button1_Click(object sender,EventArgs e)DB db=new DB();int albumID=Convert.ToInt32(Request.QueryStringid);string albumDesc=TextBox2.Text.ToString();string albumName=TextBox1.Text.ToString();DateTime albumTime=DateTime.Now;string logourl=image/+FileUpload1.FileName;string exname=FileUpload1.FileName.Split(.)1;if(exname.ToLower()=jpg|exname.ToLower()=png|exname.ToLower()=gif)FileUpload1.SaveAs(Server.MapPath(logourl);db.updateAlbum(albumID,albumDesc,albumName,albumTime,logourl);Response.Write(alert(修改成功);location.href=default.aspx?;);,在default.aspx中点击“删除”按钮时,删除专辑的方法在DB中:public void deleteAlbum(int albumID)SqlHelper helper=new SqlHelper();string strsql=delete from image where image.albumID=albumID;delete from album where albumID=albumID;SqlParameter parm=new SqlParameter new SqlParameter(id,albumID);SqlCommand cmd=helper.GetCommand(strsql,parm);cmd.ExecuteNonQuery();,在objectdatasource2中的DELETE方法中选择DB中的deleteAlbum方法。,删除专辑功能的实现,在default.aspx中编辑列时,将删除按钮启动,注意:如果通过查询按钮查出某个专辑后,再点删除按钮,不能实现删除,因为查询功能是通过ObjectDataSource3实现的,而它不支持CommandField的删除钮,除非再编写相应的删除方法。,修改图片所属专辑和简介,给站点添加新页面update.aspx,用于修改图片所属的专辑名和修改图片简介。,在DB.cs中编写需要的方法,因为修改先要显示旧的专辑名和专辑简介信息,所以要有一个按imageID查找所属albumID和imageDesc的方法select_Desc(),代码如下所示:public DataTable select_Desc(int imageID)SqlHelper helper=new SqlHelper();string strsql=select imageDesc from image where imageID=imageID;SqlParameter parm=new SqlParameter new SqlParameter(imageID,imageID);SqlCommand cmd=helper.GetCommand(strsql,parm);DataTable dt=new DataTable();using(SqlDataReader rdr=cmd.ExecuteReader()dt.Load(rdr);return dt;,在DB.cs中编写需要的方法,因为点击提交修改按钮后,实现修改,所以要有一个修改图片所属专辑和图片简介的方法,代码如下所示:public void update(int albumID,string imageDesc,int imageID)SqlHelper helper=new SqlHelper();string strsql=update image set albumID=albumID,imageDesc=imageDesc where imageID=imageID;SqlParameter parm=new SqlParameter new SqlParameter(albumID,albumID),new SqlParameter(imageDesc,imageDesc),new SqlParameter(imageID,imageID),;SqlCommand cmd=helper.GetCommand(strsql,parm);cmd.ExecuteNonQuery();,点击 按钮,导航到update.aspx页面时触发该页的page_load事件,代码如下:protected void Page_Load(object sender,EventArgs e)if(!IsPostBack)DB db=new DB();int imageID=Convert.ToInt32(Request.QueryStringimageID);TextBox1.Text=db.select_Desc(imageID).Rows00.ToString();,当点击update.aspx的 时,触发下面的事件:protected void Button1_Click(object sender,EventArgs e)DB db=new DB();int albumID=Convert.ToInt32(DropDownList1.SelectedValue);string imageDesc=TextBox1.Text.ToString();int imageID=Convert.ToInt32(Request.QueryStringimageID);db.update(albumID,imageDesc,imageID);Response.Write(alert(修改成功);location.href=default.aspx?;);,通过ViewImage.aspx页面的“全选”框,实现全部选择功能,并且可以任意多选或单选,翻页可以保存选择状态。,当显示图片信息的GridView1翻页时,触发以下事件,代码如下:protected void GridView1_PageIndexChanging(object sender,GridViewPageEventArgs e)RememberOldValues();/调用RememberOldValues()方法,保存选中状 态到session中 GridView1.PageIndex=e.NewPageIndex;GridView1.DataBind();RePopulateValue();/调用RePopulateValue()方法,将session中保存的 状态表现在CheckBox中 e.Cancel=true;/退出事件,如果没有此动作,GridView将会再次 DataBind(),将覆盖CheckBox的选中状态,/保存选中状态到session中 private void RememberOldValues()ArrayList al=null;/声名集合/创建一个Session并检查是否为空,这个Session用来保存集合/这里是判断是否是第一次进行分页 if(Sessionchecked_items!=null)/将Session对象保存到集合中 al=(ArrayList)Sessionchecked_items;else al=new ArrayList();/声明一个变量用来保存相应数据从而判断操作的是哪个check控件 int index=-1;续下页,foreach(GridViewRow row in GridView1.Rows)/遍历GridViewRow index=(int)GridView1.DataKeysrow.RowIndex.Value;/从gridview中取得行的绑定值bool result=(CheckBox)row.FindControl(CheckBox2).Checked;/从每行的check中取得选中状态 if(result)/判断选中状态/当check为选中,并且集合中不包含这个值时,将此绑定值添加进集合中 if(!al.Contains(index)al.Add(index);else/当状态为不选中,并且集合中包含这个值时,将帮定值从集合中移除 if(al.Contains(index)al.Remove(index);,/最后判断集合是否为空或者没有值,如果有则将集合添加到Session中,以便保存数据 if(al!=null,/将session中保存的状态表现在CheckBox中 private void RePopulateValue()/将Session中的值赋给集合 ArrayList al=(ArrayList)Sessionchecked_items;if(al!=null,/点击“全选”后,触发CheckedChanged事件的代码:protected void allchecked(object sender,EventArgs e)/注意修改checkbox1的AutoPostBack属性为true CheckBox cbx=(CheckBox)sender;/遍历GridViewRow将其中的check控件的状态设置 foreach(GridViewRow gvr in GridView1.Rows)CheckBox ch=(CheckBox)gvr.FindControl(CheckBox2);ch.Checked=cbx.Checked;,为了实现删除选中的图片记录,在DB.cs中编写如下方法:public void deletemore(ArrayList al)SqlHelper helper=new SqlHelper();StringBuilder str=new StringBuilder();str.Append(delete from image where imageID in();for(int i=0;i al.Count;i+)str.Append(ali+,);string s=str.ToString().Substring(0,str.ToString().Length-1);s+=);SqlCommand cmd=helper.GetCommand(s,null);cmd.ExecuteNonQuery();,/删除所选记录 protected void Button1_Click(object sender,EventArgs e)DB db=new DB();/首先判断gridview是否有值,如果有才可以进行删除 if(GridView1.Rows.Count 0)/通过调用保存状态方法盘判断那个记录被选中 RememberOldValues();/从Session对象中取得集合的内容 ArrayList al=(ArrayList)Sessionchecked_items;if(al!=null)/调用删除多条的方法进行删除操作 db.deletemore(al);GridView1.DataBind();,

    注意事项

    本文(图片管理系统.ppt)为本站会员(夺命阿水)主动上传,课桌文档仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知课桌文档(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-1

    经营许可证:宁B2-20210002

    宁公网安备 64010402000986号

    课桌文档
    收起
    展开