二进制数据流方式实现 个人头像的读取、上传、修改------善良公社项目

       这几天自己在实现个人资料修改信息这块,首先当用户注册后并不能来的把所有详细信息都填写完整,所有这块需要用户通过修改用户上传自己的头像,首先系统会默认加载一个头像,如图:

现在系统是默认的,我点击修改资料的时候需要查出这个图片,再把我的头像传上去,即修改即可。

 

代码很简单(自己考虑的时候一直受到思维限制,使用js来实现(绕弯了)并没有会想如此简单(建新指导))

 

前台:

 

<div title="修改头像" style="overflow: auto; padding: 20px;">
                            <%--<form id="Form2" method="post" runat="server">--%>
                            <div id="localImag"   style="width: 350px; float: left">
                                <img id="preview" src="SearchPhoto.ashx"  />
通过调用一般处理程序绑定头像
                                
                            </div>
                            <div style="width: 100px; float: left">
                                <asp:FileUpload ID="FileUpload1" runat="server" onchange="javascript:setImagePreview(this,localImag,preview);" />
                                
                            </div>

 


一般处理程序:

 

 ////绑定数据源,将信息添加到Category

                StringBuilder strWhere = new StringBuilder();
                string UserID = context.Session["ID"].ToString();
                userInfo = userinfobll.GetEntity(UserID);
                string HeadImg = userInfo.HeadImg;//获取头像地址(我用的是相对路径)
string img = context.Server.MapPath(HeadImg);//把头像地址转换为绝地地址(受下面的要求)
                
                FileStream aFile = new FileStream(img, FileMode.OpenOrCreate, FileAccess.ReadWrite); // 以二进制方式读文件 
                
                BinaryReader brMyfile = new BinaryReader(aFile); // 创建一个二进制数据流读入器,和打开的文件关联 
               
                brMyfile.BaseStream.Seek(0, SeekOrigin.Begin); // 把文件指针重新定位到文件的开始  
               
                byte[] photo = brMyfile.ReadBytes(Convert.ToInt32(aFile.Length.ToString())); //获取照片的字节数组  
               
                brMyfile.Close(); // 关闭以上new的各个对象  

                context.Response.BinaryWrite(photo);//把图片的路径返回界面


这样轻松的根据数据库中的路径加载相应的图片,修改头像就是很简单了。(部分核心代码--贺刚博客分享)

if (this.FileUpload1.FileContent.Length >= 200000)//限制大小
            {
                Page.ClientScript.RegisterStartupScript(Page.GetType(), "message", "<script language='javascript' defer>alert('照片不能超过200KB!');</script>");
                return;
            }
            String fullfilename = this.FileUpload1.PostedFile.FileName;    //获取图片的绝对路径
            String filename = fullfilename.Substring(fullfilename.LastIndexOf("\\") + 1);//获取图片的名称
            String type = filename.Substring(filename.LastIndexOf(".") + 1).ToLower();            //获取图片的格式(类型)
            String Rename = Session["UserName"] + "_" + DateTime.Now.ToString("yyyyMMddHHmmss");     //用户名+时间命名,避免上传图片命名重复
            string varToDirectory = Request.PhysicalApplicationPath + "touxiang";  //专门存放用户相册的文件
            //判断文件是否存在,不存在则创建该文件
            if (!Directory.Exists(varToDirectory))
            {
                Directory.CreateDirectory(varToDirectory);
            }
            if (type == "jpg" || type == "png" || type == "jpeg" || type == "gif")
            {

                userInfo.UserID = Int32.Parse(Session["UserID"].ToString());
                userInfo.HeadImg = "touxiang/" + Rename + "." + type;  //数据库中中图片的路径
 FileUpload1.SaveAs(Server.MapPath("touxiang") + "/" + Rename + "." + type);//将图片以相对路径保存,并以当前时间命名


 总结

        遗留下的问题:

        1:如果直接使用一般处理程序返回的是字符串(头像的相对地址),不能正常显示图片,在浏览器的调试下把相对地址拷过去可以正常显示图片,为什么返回的是二进制流就可以读取头像,二者的区别是什么呢?请高手指导。

 

         这段时间做系统,遇到的问题越来越多,见识也越多越广,好多知识等着去深刻理解、运用,打破思维的限制,大家共同努力啊。

 

 

 

posted on 2013-12-03 00:14  哼哼唧唧  阅读(330)  评论(0编辑  收藏  举报

导航