search了非常多的文章,总算勉强实现了。有许多不完善的地方。

在HCLoad.Web项目下新建目录Pics复制一张图片到根目录下。

图片名:Bubble.jpg 右击->属性->生成操作:Resource

UC_UpDown.xaml


大气象

<UserControl x:Class="HCLoad.UC_UpDown"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 
    Width="500" Height="500">
    <StackPanel Background="White" Height="450">
        <Button Content="down" Click="Button_Click"></Button>
        <HyperlinkButton Content="下载保存" NavigateUri="http://localhost:4528/download.ashx?fileName=aa.txt" TargetName="_self" x:Name="lBtnDown" />
        <TextBlock x:Name="tbMsgString" Text="下载进度" TextAlignment="Center" Foreground="Green"></TextBlock>
        <Button x:Name="btnDownload" Content="DownLoad Pictures" Width="150" Height="35" Margin="15" Click="btnDownload_Click"/>
        <Border Background="Wheat" BorderThickness="5" Width="400" Height="280">
            <Image x:Name="imgDownLoad" Width="400" Height="300" Margin="15" Stretch="Fill"/>
        </Border>
        <Button x:Name="btnUpLoad" Content="UpLoad Pictures" Width="150" Height="35" Margin="15" Click="btnUpLoad_Click"/>
    </StackPanel>
</UserControl>

UC_UpDown.xaml.cs


大气象

using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Animation;
using System.Windows.Shapes; using System.Windows.Media.Imaging; //因为要使用BitmapImage
using System.IO;  //因为要使用Stream namespace HCLoad
{
    public partial class UC_UpDown : UserControl
    {
        //1、WebClient 对象一次只能启动一个请求。如果在一个请求完成(包括出错和取消)前,即IsBusy为true时,进行第二个请求,则第二个请求将会抛出 NotSupportedException 类型的异常
        //2、如果 WebClient 对象的 BaseAddress 属性不为空,则 BaseAddress 与 URI(相对地址) 组合在一起构成绝对 URI
        //3、WebClient 类的 AllowReadStreamBuffering 属性:是否对从 Internet 资源接收的数据做缓冲处理。默认值为true,将数据缓存在客户端内存中,以便随时被应用程序读取         //获取选定图片信息
        System.IO.FileInfo fileinfo;
        public UC_UpDown()
        {
            InitializeComponent();
        }
        #region  下载图片
        private void btnDownload_Click(object sender, RoutedEventArgs e)
        {
            //向指定的Url发送下载流数据请求 
            String imgUrl = "http://localhost:4528/Bubble.jpg";
            Uri endpoint = new Uri(imgUrl);             WebClient client = new WebClient();
            client.OpenReadCompleted += new OpenReadCompletedEventHandler(OnOpenReadCompleted);
            client.DownloadProgressChanged += new DownloadProgressChangedEventHandler(clientDownloadStream_DownloadProgressChanged);
            client.OpenReadAsync(endpoint);
        }
        void OnOpenReadCompleted(object sender, OpenReadCompletedEventArgs e)
        {             //OpenReadCompletedEventArgs.Error - 该异步操作期间是否发生了错误
            //OpenReadCompletedEventArgs.Cancelled - 该异步操作是否已被取消
            //OpenReadCompletedEventArgs.Result - 下载后的 Stream 类型的数据
            //OpenReadCompletedEventArgs.UserState - 用户标识             if (e.Error != null)
            {
                MessageBox.Show(e.Error.ToString());
                return;
            }
            if (e.Cancelled != true)
            {
                //获取下载的流数据(在此处是图片数据)并显示在图片控件中
                //Stream stream = e.Result;
                //BitmapImage bitmap = new BitmapImage();
                //bitmap.SetSource(stream);
                //imgDownLoad.Source = bitmap;
                Stream clientStream = e.UserState as Stream;
                Stream serverStream = (Stream)e.Result;
                byte[] buffer = new byte[serverStream.Length];
                serverStream.Read(buffer, 0, buffer.Length);
                clientStream.Write(buffer, 0, buffer.Length);
                clientStream.Close();
                serverStream.Close();             }         }         void clientDownloadStream_DownloadProgressChanged(object sender, DownloadProgressChangedEventArgs e)
        {
            //DownloadProgressChangedEventArgs.ProgressPercentage - 下载完成的百分比
            //DownloadProgressChangedEventArgs.BytesReceived - 当前收到的字节数
            //DownloadProgressChangedEventArgs.TotalBytesToReceive - 总共需要下载的字节数
            //DownloadProgressChangedEventArgs.UserState - 用户标识             this.tbMsgString.Text = string.Format("完成百分比:{0} 当前收到的字节数:{1} 资料大小:{2} ",
              e.ProgressPercentage.ToString() + "%",
              e.BytesReceived.ToString(),
              e.TotalBytesToReceive.ToString());         }         #endregion         #region  上传图片
        private void btnUpLoad_Click(object sender, RoutedEventArgs e)
        {
            /**/
            /*
         *   OpenWriteCompleted - 在打开用于上传的流完成时(包括取消操作及有错误发生时)所触发的事件
         *   WriteStreamClosed - 在写入数据流的异步操作完成时(包括取消操作及有错误发生时)所触发的事件
         *   UploadProgressChanged - 上传数据过程中所触发的事件。如果调用 OpenWriteAsync() 则不会触发此事件
         *   Headers - 与请求相关的的标头的 key/value 对**
         *   OpenWriteAsync(Uri address, string method, Object userToken) - 打开流以使用指定的方法向指定的 URI 写入数据
         *     Uri address - 接收上传数据的 URI
         *     string method - 所使用的 HTTP 方法(POST 或 GET)
         *     Object userToken - 需要上传的数据流
         */             OpenFileDialog openFileDialog = new OpenFileDialog()
            {  //弹出打开文件对话框要求用户自己选择在本地端打开的图片文件
                Filter = "Jpeg Files (*.jpg)|*.jpg|All Files(*.*)|*.*",
                Multiselect = false  //不允许多选 
            };             if (openFileDialog.ShowDialog() == true)//.DialogResult.OK)
            {
                //fileinfo = openFileDialog.Files; //取得所选择的文件,其中Name为文件名字段,作为绑定字段显示在前端
                fileinfo = openFileDialog.File;                 if (fileinfo != null)
                {
                    WebClient webclient = new WebClient();                     string uploadFileName = fileinfo.Name.ToString(); //获取所选文件的名字                     #region 把图片上传到服务器上                     Uri upTargetUri = new Uri(String.Format("http://localhost:4528/WebClientUpLoadStreamHandler.ashx?fileName={0}", uploadFileName), UriKind.Absolute); //指定上传地址                     webclient.OpenWriteCompleted += new OpenWriteCompletedEventHandler(webclient_OpenWriteCompleted);
                    webclient.Headers["Content-Type"] = "multipart/form-data";                     webclient.OpenWriteAsync(upTargetUri, "POST", fileinfo.OpenRead());
                    webclient.WriteStreamClosed += new WriteStreamClosedEventHandler(webclient_WriteStreamClosed);                     #endregion                 }
                else
                {
                    MessageBox.Show("请选取想要上载的图片!!!");
                }
            }         }         void webclient_OpenWriteCompleted(object sender, OpenWriteCompletedEventArgs e)
        {             //将图片数据流发送到服务器上             // e.UserState - 需要上传的流(客户端流)
            Stream clientStream = e.UserState as Stream;
            // e.Result - 目标地址的流(服务端流)
            Stream serverStream = e.Result;
            byte[] buffer = new byte[4096];
            int readcount = 0;
            // clientStream.Read - 将需要上传的流读取到指定的字节数组中
            while ((readcount = clientStream.Read(buffer, 0, buffer.Length)) > 0)
            {
                // serverStream.Write - 将指定的字节数组写入到目标地址的流
                serverStream.Write(buffer, 0, readcount);
            }
            serverStream.Close();
            clientStream.Close();         }         void webclient_WriteStreamClosed(object sender, WriteStreamClosedEventArgs e)
        {
            //判断写入是否有异常
            if (e.Error != null)
            {
                System.Windows.Browser.HtmlPage.Window.Alert(e.Error.Message.ToString());
            }
            else
            {
                System.Windows.Browser.HtmlPage.Window.Alert("图片上传成功!!!");
            }
        }
        #endregion         private void Button_Click(object sender, RoutedEventArgs e)
        {
            //这种方法搞不定,好像提示跨域操作。
            //提示:错误:Unhandled Error in Silverlight Application 跨线程访问无效。
            //Uri upTargetUri = new Uri(String.Format("http://localhost:4528/download.ashx?filename={0}", "123.jpg"), UriKind.Absolute); //指定上传地址
            //WebRequest request = WebRequest.Create(upTargetUri);
            //request.Method = "GET";
            //request.ContentType = "application/octet-stream";
            //request.BeginGetResponse(new AsyncCallback(RequestReady), request);             //通过调用js代码下载,比较简单。
            System.Windows.Browser.HtmlPage.Window.Eval("window.location.href='http://localhost:4528/download.ashx?filename=123.jpg';");
        }
        void RequestReady(IAsyncResult asyncResult)
        {
            MessageBox.Show("RequestComplete");
        }     }
}

在HCLoad.Web项目下新建WebClientUpLoadStreamHandler.ashx


大气象

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web; using System.IO;  //因为要用到Stream namespace HCLoad.Web
{
    public class WebClientUpLoadStreamHandler : IHttpHandler
    {         public void ProcessRequest(HttpContext context)
        {
            //获取上传的数据流
            string fileNameStr = context.Request.QueryString["fileName"];
            Stream sr = context.Request.InputStream;
            try
            {
                string filename = "";                 filename = fileNameStr;                 byte[] buffer = new byte[4096];
                int bytesRead = 0;
                //将当前数据流写入服务器端文件夹ClientBin下
                string targetPath = context.Server.MapPath("Pics/" + filename + ".jpg");
                using (FileStream fs = File.Create(targetPath, 4096))
                {
                    while ((bytesRead = sr.Read(buffer, 0, buffer.Length)) > 0)
                    {
                        //向文件中写信息
                        fs.Write(buffer, 0, bytesRead);
                    }
                }                 context.Response.ContentType = "text/plain";
                context.Response.Write("上传成功");
            }
            catch (Exception e)
            {
                context.Response.ContentType = "text/plain";
                context.Response.Write("上传失败, 错误信息:" + e.Message);
            }
            finally
            { sr.Dispose(); }         }         public bool IsReusable
        {
            get
            {
                return false;
            }
        }
    } }

新建download.ashx


大气象

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Services;
using System.Net; namespace HCLoad.Web
{
    /// <summary>
    /// $codebehindclassname$ 的摘要说明
    /// </summary>
    public class download : IHttpHandler
    {
        private long ChunkSize = 102400;//100K 每次读取文件,只读取100K,这样可以缓解服务器的压力         public void ProcessRequest(HttpContext context)
        {
            //string fileName = "123.jpg";//客户端保存的文件名
            String fileName = context.Request.QueryString["filename"]; 
            string filePath = context.Server.MapPath("Bubble.jpg");
            System.IO.FileInfo fileInfo = new System.IO.FileInfo(filePath);
            if (fileInfo.Exists == true)
            {
                byte[] buffer = new byte[ChunkSize];
                context.Response.Clear();
                System.IO.FileStream iStream = System.IO.File.OpenRead(filePath);
                long dataLengthToRead = iStream.Length;//获得下载文件的总大小
                context.Response.ContentType = "application/octet-stream";
                //通知浏览器下载文件而不是打开
                context.Response.AddHeader("Content-Disposition", "attachment;  filename=" + HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8));
                while (dataLengthToRead > 0 && context.Response.IsClientConnected)
                {
                    int lengthRead = iStream.Read(buffer, 0, Convert.ToInt32(ChunkSize));//读取的大小
                    context.Response.OutputStream.Write(buffer, 0, lengthRead);
                    context.Response.Flush();
                    dataLengthToRead = dataLengthToRead - lengthRead;
                }
                context.Response.Close();
                context.Response.End();
            }
            //context.Response.ContentType = "text/plain";
            //context.Response.Write("Hello World");
        }         public bool IsReusable
        {
            get
            {
                return false;
            }
        }
    }
}

参考:
http://www.cnblogs.com/wsdj-ittech/archive/2009/08/26/1554056.html
http://www.cnblogs.com/wsdj-ittech/archive/2009/08/25/1553534.html
http://www.cnblogs.com/wmt1708/archive/2009/03/07/1405009.html
http://topic.csdn.net/u/20090918/10/5e41ab52-f514-46b5-ae6a-d69ddb197213.html
http://www.cnblogs.com/wsdj-ittech/archive/2009/08/25/1553534.html
http://www.cnblogs.com/gwazy/archive/2009/04/02/1427781.html
http://www.cnblogs.com/ewyb/archive/2009/12/10/1621020.html
http://blog.csdn.net/emily1900/archive/2010/06/08/5655726.aspx

凡事以大气象去面对,优秀是一种习惯。

 
分类: SilverLight
标签: Silverlight

Silverlight结合Web Service进行文件上传的更多相关文章

  1. JAVA Web 之 struts2文件上传下载演示(二)(转)

    JAVA Web 之 struts2文件上传下载演示(二) 一.文件上传演示 详细查看本人的另一篇博客 http://titanseason.iteye.com/blog/1489397 二.文件下载 ...

  2. JAVA Web 之 struts2文件上传下载演示(一)(转)

    JAVA Web 之 struts2文件上传下载演示(一) 一.文件上传演示 1.需要的jar包 大多数的jar包都是struts里面的,大家把jar包直接复制到WebContent/WEB-INF/ ...

  3. 基于 java 【Web安全】文件上传漏洞及目录遍历攻击

    前言:web安全之文件上传漏洞,顺带讲一下目录遍历攻击.本文基于 java 写了一个示例. 原理 在上网的过程中,我们经常会将一些如图片.压缩包之类的文件上传到远端服务器进行保存.文件上传攻击指的是恶 ...

  4. WEB安全:文件上传漏洞

    文件上传漏洞过程 用户上传了一个可执行的脚本文件,并通过此脚本文件获得了执行服务器端命令的能力. 一般的情况有: 上传文件WEB脚本语言,服务器的WEB容器解释并执行了用户上传的脚本,导致代码执行: ...

  5. 构建web应用之——文件上传

    我们通过使用multipart请求数据接收和处理二进制信息(如文件).DispatcherServlet并没有实现任何解析multipart请求数据的功能,它将该任务委托给了Spring中的multi ...

  6. IIS 之 通过 Web.config 修改文件上传大小限制设置方法

    在IIS 6.0中,不设置默认大小为4M,设置文件上传大小的方法,maxRequestLength(KB),executionTimeout(毫秒),配置如下节点: <system.web> ...

  7. web安全之文件上传漏洞攻击与防范方法

    一. 文件上传漏洞与WebShell的关系 文件上传漏洞是指网络攻击者上传了一个可执行的文件到服务器并执行.这里上传的文件可以是木马,病毒,恶意脚本或者WebShell等.这种攻击方式是最为直接和有效 ...

  8. Web安全-之文件上传漏洞场景

    1   上传漏洞危害介绍 上传是Web中最常见的功能,如果上传功能存在设计.编码缺陷,就容易形成上传漏洞,从而成为致命的安全问题,攻击者可以通过上传脚本木马,实现查看/篡改/删除源码和任意涂鸦网页,可 ...

  9. web实现大文件上传分片上传断点续传

    需求:项目要支持大文件上传功能,经过讨论,初步将文件上传大小控制在500M内,因此自己需要在项目中进行文件上传部分的调整和配置,自己将大小都以501M来进行限制. 第一步: 前端修改 由于项目使用的是 ...

随机推荐

  1. ftrace笔记

    mount -t debugfs nodev /sys/kernel/debug 在mount后,可以在debug目录下看到tracing目录,该目录包含了ftrace的控制与输出文件. (1) en ...

  2. Ajax 实现文件的下载

    JQuery的ajax函数的返回类型只有xml.text.json.html等类型,没有“流”类型,所以我们要实现ajax下载,不能够使用相应的ajax函数进行文件下载.但可以用js生成一个form, ...

  3. ThreadGroup

    http://blog.csdn.net/a352193394/article/details/39323427

  4. HDD磁盘,非4K无以致远

    机械硬盘的未来要靠高容量作为依托,在财报中,希捷表示未来18个月内它们将推出14和16TB机械硬盘,而2020年20TB机械硬盘就将诞生.也有资料显示,3.5英寸100TB硬盘大概在2025年就能面世 ...

  5. Base64的空格 + 问题...

    BASE64  通过url传递到后台 加号变空格的处理方法 解决方法: 前台处理:str.replace("+", "%2B"); (错误) <scrip ...

  6. 电脑技巧 ADSL如何远程盗号

    ADSL如何远程盗号 开头语: 本文中揭露了黑客攻击ADSL用户,窃取用户名密码的常见方法,读者请勿将其用于不法用途,并提醒所有与此漏洞相关的用户尽快采取措施进行防范. ADSL作为一种宽带接入方式已 ...

  7. UP Board USB无线网卡选购指南

    前言 原创文章,转载引用务必注明链接,水平有限,欢迎指正. 本文环境:ubilinux 3.0 kernel 4.4.0 本文使用Markdown写成,为获得更好的阅读体验和正常的图片.链接,请访问我 ...

  8. Effective C++ 条款13/14 以对象管理资源 || 在资源管理类中小心拷贝行为

    三.资源管理       资源就是一旦你使用了它,将来不用的时候必须归还系统.C++中最常用的资源就是动态内存分配.其实,资源还有 文件描述符.互斥器.图形界面中的字形.画刷.数据库连接.socket ...

  9. opencv2反投影直方图以检測特定的图像内容

    #ifndef HISTOGRAM_H_ #define HISTOGRAM_H_ #include<opencv2/core/core.hpp> #include<opencv2/ ...

  10. SIFT算法中DoG特征点的修正

    SIFT算法中,在DoG空间找到极值点后,需要对极值点进行修正,本文主要详细的讲解一下为什么需要修正,以及如何对极值点进行修正. 下图演示了二维函数离散空间得到的极值点与连续空间的极值点之间的差别 利 ...