でRAW形式に戻った後、一時ファイルを削除しますか?私はストリームを使用して、生の形式で動作WCFサービスを持っているWCF
私はfinally
ブロックを使用しようとしましたが、それは右return
後に呼び出されると、ファイルがまだプロセスによって使用されているため、例外がスローされます。
もちろん、これはバックグラウンドワーカーがファイルを削除できるようにするのを待っているような回避策ですが、私の意見ではWebサービスの実装方法とは異なります。
でRAW形式に戻った後、一時ファイルを削除しますか?私はストリームを使用して、生の形式で動作WCFサービスを持っているWCF
私はfinally
ブロックを使用しようとしましたが、それは右return
後に呼び出されると、ファイルがまだプロセスによって使用されているため、例外がスローされます。
もちろん、これはバックグラウンドワーカーがファイルを削除できるようにするのを待っているような回避策ですが、私の意見ではWebサービスの実装方法とは異なります。
解決策はすばやく心に浮かんできました。それは絶対的に論理的です。ファイルコンテンツをメモリに読み込んでファイルを削除するだけです。
public Stream SignDocument(Stream requestStream)
{
string originalFileName = Path.GetTempFileName();
string signedFileName = Path.GetTempFileName();
using (var originalFileStream = File.Open(originalFileName, FileMode.Create, FileAccess.Write))
{
requestStream.CopyTo(originalFileStream);
}
XmlDocumentSigner.SignFile(originalFileName, signedFileName);
byte[] signedFileBytes = File.ReadAllBytes(signedFileName);
File.Delete(signedFileName);
return new MemoryStream(signedFileBytes);
}
using
文は、このコードが同様に失敗しますことを注意:
using (var ms = new MemoryStream(signedFileBytes))
{
return ms;
}
あなたはあなたの回答を見つけることにしました。あなたも複雑ではありませんでした! – TheLethalCoder
@TheLethalCoderありがとう:) –
こちらも参照してください:https://devdump.wordpress.com/2008/12/07/disposing-return-values/。彼らは処分について話しますが、あなたはOperationCompletedに加入してそこのファイルを削除することができます。ファイル全体をメモリにコピーするよりも優れています。 – Evk
を私はそれを試していないが、あなたはファイルを開き、別のストリームにそのストリームを書くことができます。ような何か:
File.Delete(signedFileName);
return ms;
あなたが最初の場所にあるファイルを使用して避けることができない:
は、その後、あなたが行う必要がありますすべてのファイルを削除して、
ms
返す呼び出しですか?代わりに(メモリ内で)ストリームを使用していますか? –@ Christian.K残念なことに、 'XmlDocumentSigner'は非常に特定のアルゴリズム(管理されたファイルベースの代替ライブラリもファイルベースのライブラリもありません)を使用する外部アンマネージDLLライブラリのラッパーであり、ファイルにしか署名できません:( –