Pular para o conteúdo principal

Upload de arquivos no Silverlight

 

file_upload O recurso de upload de arquivos é muito útil e requisitado em certos casos quando se fala de sistemas on line. Logo desenvolver algo nesse sentido em nossas aplicações Silverlight pode se tornar necessário, como foi no meu caso, ou de repente apresentar esse recurso para incrementar um projeto também pode ser uma boa idéia.

Irei disponibilizar aqui um ótimo projeto que encontrei no blog do John Mendez, que serviu de base para a minha implementação, colocarei no post apenas a classe do serviço de upload, o projeto completo pode ser encontrado aqui.

   1: <%@ WebHandler Language="C#" Class="FileUpload" %>



   2:  



   3: using System;



   4: using System.Web;



   5: using System.IO;



   6: using System.Web.Hosting;



   7: using System.Diagnostics;



   8:  



   9: public class FileUpload : IHttpHandler {



  10:  



  11:     private HttpContext _httpContext;



  12:     private string _tempExtension = "_temp";



  13:     private string _fileName;



  14:     private string _docType;



  15:     private bool _lastChunk;



  16:     private bool _firstChunk;



  17:     private long _startByte;



  18:     



  19:     StreamWriter _debugFileStreamWriter;



  20:     TextWriterTraceListener _debugListener;



  21:  



  22:     public void ProcessRequest(HttpContext context)



  23:     {



  24:         _httpContext = context;



  25:  



  26:         if (context.Request.InputStream.Length == 0)



  27:             throw new ArgumentException("No file input");



  28:  



  29:         try



  30:         {



  31:  



  32:             GetQueryStringParameters();



  33:  



  34:             string uploadFolder = GetUploadFolder();



  35:             string tempFileName = _fileName + _tempExtension;



  36:  



  37:             if (_firstChunk)



  38:             {



  39:                 //Delete temp file



  40:                 if (File.Exists(@HostingEnvironment.ApplicationPhysicalPath + "/" + uploadFolder + "/" + tempFileName))



  41:                     File.Delete(@HostingEnvironment.ApplicationPhysicalPath + "/" + uploadFolder + "/" + tempFileName);



  42:  



  43:                 //Delete target file



  44:                 if (File.Exists(@HostingEnvironment.ApplicationPhysicalPath + "/" + uploadFolder + "/" + _fileName))



  45:                     File.Delete(@HostingEnvironment.ApplicationPhysicalPath + "/" + uploadFolder + "/" + _fileName);



  46:  



  47:             }



  48:  



  49:             using (FileStream fs = File.Open(@HostingEnvironment.ApplicationPhysicalPath + "/" + uploadFolder + "/" + tempFileName, FileMode.Append))



  50:             {



  51:                 SaveFile(context.Request.InputStream, fs);



  52:                 fs.Close();



  53:             }



  54:  



  55:             if (_lastChunk)



  56:             {



  57:                 File.Move(HostingEnvironment.ApplicationPhysicalPath + "/" + uploadFolder + "/" + tempFileName, HostingEnvironment.ApplicationPhysicalPath + "/" + uploadFolder + "/" + _fileName);



  58:             }



  59:  



  60:         }



  61:         catch (Exception e)



  62:         {



  63:             throw;



  64:         }



  65:  



  66:     }



  67:  



  68:     private void GetQueryStringParameters()



  69:     {



  70:         _fileName = _httpContext.Request.QueryString["file"];



  71:         _docType = _httpContext.Request.QueryString["docType"];



  72:         _lastChunk = string.IsNullOrEmpty(_httpContext.Request.QueryString["last"]) ? true : bool.Parse(_httpContext.Request.QueryString["last"]);



  73:         _firstChunk = string.IsNullOrEmpty(_httpContext.Request.QueryString["first"]) ? true : bool.Parse(_httpContext.Request.QueryString["first"]);



  74:         _startByte = string.IsNullOrEmpty(_httpContext.Request.QueryString["offset"]) ? 0 : long.Parse(_httpContext.Request.QueryString["offset"]); ;



  75:     }



  76:  



  77:     private void SaveFile(Stream stream, FileStream fs)



  78:     {



  79:         byte[] buffer = new byte[4096];



  80:         int bytesRead;



  81:         while ((bytesRead = stream.Read(buffer, 0, buffer.Length)) != 0)



  82:         {



  83:             fs.Write(buffer, 0, bytesRead);



  84:         }



  85:     }



  86:     protected string GetUploadFolder()



  87:     {



  88:         string folder = ""; //System.Configuration.ConfigurationSettings.AppSettings["UploadFolder"];



  89:  



  90:         switch (_docType)



  91:         {



  92:             case "document":



  93:                 folder = "documents/uploads";



  94:                 break;



  95:             case "image":



  96:                 folder = "documents/images";



  97:                 break;



  98:             default:



  99:                 folder = "documents";



 100:                 break;



 101:         }



 102:         



 103:         if (string.IsNullOrEmpty(folder))



 104:             folder = "documents";



 105:  



 106:         return folder;



 107:     }



 108:  



 109:     



 110:     public bool IsReusable {



 111:         get {



 112:             return false;



 113:         }



 114:     }



 115:  



 116: }


Comentários

  1. Olá parceiro, estou aqui avisando sobre a alteração do meu banner, e gostaria de pedir que pegue o novo banner em nosso blog e altere em sua página.

    att.

    Humor com Risada
    www.humorcomrisada.blogspot.com

    ResponderExcluir
  2. Pra onde fica o arquivo que fiz upload?

    ResponderExcluir
  3. Olá anonimo, verifique o método GetUploadFolder.

    []s...

    ResponderExcluir

Postar um comentário

Obrigado por Participar do programero, fique a vontade para agradecer, retificar, perguntar ou sugerir.

Mais visitadas

Funções de data Oracle

  Com o Oracle é possível obter uma série de resultados a partir de uma ou mais datas, como por exemplo verificar o último dia do mês ou verificar a quantidade de meses entre duas datas, então vamos a alguns exemplos:   Data atual do sistema: SYSDATE Remover meses de uma data: ADD_MONTHS(SYSDATE, -1) Adicionar meses de uma data: ADD_MONTHS(SYSDATE, +1) Buscar o último dia do mês: LAST_DAY(SYSDATE) Primeiro dia do mês: TRUNC(SYSDATE, ‘MONTH’) Quantidade de meses entre duas datas: MONTHS_BETWEEN(SYSDATE, ‘27/07/1982’) Primeiro dia do ano: TRUNC(SYSDATE, ‘YEAR’) Dias da semana: DECODE( TO_NUMBER( TO_CHAR          (SYSDATE, ‘D’) ) ,1, ‘domingo’ ,2, ‘segunda-feira’ ,3, ‘terça-feira’ ,4, ‘quarta-feira’ ,5, ‘quinta-feira’ ,6, ‘sexta-feira’ ,7,’sábado’ )

Funções de Data e Hora (Delphi)

É muito comum nos depararmos no dia a dia com a necessidade de manipular datas e horas, seja para um calculo de permanência, dias de atraso enfim, é praticamente escapar de alguma situação que necessite desse tipo de controle. Assim como a necessidade e se utilizar algum recurso para manipular as datas e horas de alguma maneira e freqüente, as duvidas de como o faze-lo também é, basta um breve olhar em qualquer fórum especializado e lá está, alguma duvida relacionada, por isso decidi falar um pouco sobre uma unit muito poderosa chamada DateUtils para a manipulação de data e hora, com um grande numero de métodos e classes que facilitam a vida de qualquer um. Alguns exemplos: CompareDate(constA, B: TDateTime): TValueRelationship; Compara apenas a data de dois valores (do tipo TDateTime) retornando: LessThanValue O primeiro valor é menor que o segundo EqualsValue Os valores são iguais GreaterThanValue O primeiro valor é maior que o segundo CompareDateTime(const A, B: TD

Manipular arquivos com PL/SQL (Oracle)

O bom e velho arquivo, é impressionante como lidamos com seus vários tipos durante todos os dias, bom hoje vamos mostrar um jeito simples de se escrever e ler arquivos apenas com a codificação nativa do Oracle. A primeira coisa a fazer é criar um diretório válido configurado no Oracle, e permissões de acesso a esse diretório para o usuário de banco onde faremos o exemplo, sendo assim suponhamos que nosso usuário de banco se chame programero, e nosso diretório real esteja em c:\programero, então logado como SYSTEM devemos executar os seguintes comandos: 1: -- cria diretorio 2: create or replace directory DIR_PROGRAMERO as ' C:\PROGRAMERO '; 3: -- concede permissão de escrita e leitura para nosso usuário 4: grant read , write on directory DIR_PROGRAMERO to PROGRAMERO; Para escrever, basicamente precisamos apenas saber onde esse arquivo ficará, no nosso caso no diretório criado acima, segue o código de escrita: 1: declare 2: -- nosso handler 3: v_a