Ho un servizio WCF che restituisce un flusso molto simile al seguente:Come controllo Stream.Null?
public Stream StreamFile(string filepath)
{
try
{
// Grab the file from wherever it is
// Throw an exception if it doesn't exist
return fileStream;
}
catch (Exception ex)
{
// Log the exception nicely in a place of my user's choosing
}
return Stream.Null;
}
ho usato per tentare di restituire null, ma ho cominciato a correre in questo problema se il file non è stato trovato: WCF - MessageBodyMember - Stream - "Value cannot be null"
Restituendo Stream.Null, mi sono liberato di quell'errore, ma ora ho un altro problema: come fa il mio cliente a sapere se ho inviato di nuovo Stream.Null? Non posso/non devo controllare la lunghezza, perché questi file possono essere abbastanza grandi, ma anche se non lo fossero, mi troverei di fronte a questo problema: Find Length of Stream object in WCF Client?
Ecco il mio (molto semplificato) codice cliente , solo per i posteri, ma il problema per me con il solo download di Stream.Null è che finisco con un file vuoto, e a nessuno piace.
public FileInfo RetrieveFile(string fileToStream, string directory)
{
Stream reportStream;
string filePath = Path.Combine(directory, "file.txt");
using (Stream incomingStream = server.StreamFile(fileToStream))
{
if (incomingStream == null) throw new FileExistsException(); // Which totally doesn't work
using (FileStream outgoingStream = File.Open(filePath, FileMode.Create, FileAccess.Write))
{
incomingStream.CopyTo(outgoingStream);
}
}
return new FileInfo(filePath);
}
Sembra che io sto solo la progettazione di questo metodo sbagliato in qualche modo, ma non riesco a pensare ad un modo migliore per farlo che non comporta un'eccezione non rilevata. Eventuali suggerimenti?
'Stream.Null' non ha nulla a che fare con' null' o alcun valore di fallback speciale, è un'istanza di stream speciale che corrisponde al flusso DOS 'NUL' o'/dev/null' su Linux/POSIX. Quindi non dovresti restituirlo. – Dai
Se ci si trova in una condizione di errore, si consideri l'utilizzo del sistema "Fault" di WCF che viene utilizzato per indicare ai client che una risposta tipica (ad esempio con un oggetto 'Stream' adatto) non può essere completata. – Dai
Aggiungi un messaggio di stato all'inizio del flusso. Il client leggerà lo stato dall'inizio del messaggio e rimuoverà prima di elaborare il resto dei dati. Questo è un ottimo design robusto e le persone che dicono che non è necessario eliminano importanti informazioni di debug che sono importanti quando si verificano condizioni di errore. – jdweng