本文整理匯總了C#中Microsoft.WindowsAzure.Storage.File.CloudFile.UploadFromStream方法的典型用法代碼示例。如果您正苦於以下問題:C# CloudFile.UploadFromStream方法的具體用法?C# CloudFile.UploadFromStream怎麽用?C# CloudFile.UploadFromStream使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類Microsoft.WindowsAzure.Storage.File.CloudFile
的用法示例。
在下文中一共展示了CloudFile.UploadFromStream方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: UploadText
public static void UploadText(CloudFile file, string text, Encoding encoding, AccessCondition accessCondition = null, FileRequestOptions options = null, OperationContext operationContext = null)
{
byte[] textAsBytes = encoding.GetBytes(text);
using (MemoryStream stream = new MemoryStream())
{
stream.Write(textAsBytes, 0, textAsBytes.Length);
stream.Seek(0, SeekOrigin.Begin);
file.ServiceClient.DefaultRequestOptions.ParallelOperationThreadCount = 2;
file.UploadFromStream(stream, accessCondition, options, operationContext);
}
}
示例2: DoDownloadRangeToByteArray
/// <summary>
/// Single put file and get file
/// </summary>
/// <param name="fileSize">The file size.</param>
/// <param name="bufferSize">The output buffer size.</param>
/// <param name="bufferOffset">The output buffer offset.</param>
/// <param name="fileOffset">The file offset.</param>
/// <param name="length">Length of the data range to download.</param>
/// <param name="option">0 - Sync, 1 - APM and 2 - APM overload.</param>
private void DoDownloadRangeToByteArray(CloudFile file, int fileSize, int bufferSize, int bufferOffset, long? fileOffset, long? length, int option)
{
int downloadLength;
byte[] buffer = GetRandomBuffer(fileSize);
byte[] resultBuffer = new byte[bufferSize];
byte[] resultBuffer2 = new byte[bufferSize];
using (MemoryStream originalFile = new MemoryStream(buffer))
{
if (option == 0)
{
file.UploadFromStream(originalFile);
downloadLength = file.DownloadRangeToByteArray(resultBuffer, bufferOffset, fileOffset, length);
}
else if (option == 1)
{
using (AutoResetEvent waitHandle = new AutoResetEvent(false))
{
ICancellableAsyncResult result = file.BeginUploadFromStream(originalFile,
ar => waitHandle.Set(),
null);
waitHandle.WaitOne();
file.EndUploadFromStream(result);
result = file.BeginDownloadRangeToByteArray(resultBuffer,
bufferOffset,
fileOffset,
length,
ar => waitHandle.Set(),
null);
waitHandle.WaitOne();
downloadLength = file.EndDownloadRangeToByteArray(result);
}
}
else
{
using (AutoResetEvent waitHandle = new AutoResetEvent(false))
{
ICancellableAsyncResult result = file.BeginUploadFromStream(originalFile,
ar => waitHandle.Set(),
null);
waitHandle.WaitOne();
file.EndUploadFromStream(result);
OperationContext context = new OperationContext();
result = file.BeginDownloadRangeToByteArray(resultBuffer,
bufferOffset,
fileOffset,
length,
null,
null,
context,
ar => waitHandle.Set(),
null);
waitHandle.WaitOne();
downloadLength = file.EndDownloadRangeToByteArray(result);
}
}
int downloadSize = Math.Min(fileSize - (int)(fileOffset.HasValue ? fileOffset.Value : 0), bufferSize - bufferOffset);
if (length.HasValue && (length.Value < downloadSize))
{
downloadSize = (int)length.Value;
}
Assert.AreEqual(downloadSize, downloadLength);
for (int i = 0; i < bufferOffset; i++)
{
Assert.AreEqual(0, resultBuffer[i]);
}
for (int j = 0; j < downloadLength; j++)
{
Assert.AreEqual(buffer[(fileOffset.HasValue ? fileOffset.Value : 0) + j], resultBuffer[bufferOffset + j]);
}
for (int k = bufferOffset + downloadLength; k < bufferSize; k++)
{
Assert.AreEqual(0, resultBuffer[k]);
}
}
}
示例3: DoDownloadRangeToByteArrayNegativeTests
private void DoDownloadRangeToByteArrayNegativeTests(CloudFile file)
{
int fileLength = 1024;
int resultBufSize = 1024;
byte[] buffer = GetRandomBuffer(fileLength);
byte[] resultBuffer = new byte[resultBufSize];
using (MemoryStream stream = new MemoryStream(buffer))
{
file.UploadFromStream(stream);
TestHelper.ExpectedException(() => file.DownloadRangeToByteArray(resultBuffer, 0, 1024, 1), "Try invalid length", HttpStatusCode.RequestedRangeNotSatisfiable);
StorageException ex = TestHelper.ExpectedException<StorageException>(() => file.DownloadToByteArray(resultBuffer, 1024), "Provide invalid offset");
Assert.IsInstanceOfType(ex.InnerException, typeof(NotSupportedException));
ex = TestHelper.ExpectedException<StorageException>(() => file.DownloadRangeToByteArray(resultBuffer, 1023, 0, 2), "Should fail when offset + length required is greater than size of the buffer");
Assert.IsInstanceOfType(ex.InnerException, typeof(NotSupportedException));
ex = TestHelper.ExpectedException<StorageException>(() => file.DownloadRangeToByteArray(resultBuffer, 0, 0, -10), "Fail when a negative length is specified");
Assert.IsInstanceOfType(ex.InnerException, typeof(ArgumentOutOfRangeException));
TestHelper.ExpectedException<ArgumentOutOfRangeException>(() => file.DownloadRangeToByteArray(resultBuffer, -10, 0, 20), "Fail if a negative offset is provided");
ex = TestHelper.ExpectedException<StorageException>(() => file.DownloadRangeToByteArray(resultBuffer, 0, -10, 20), "Fail if a negative file offset is provided");
Assert.IsInstanceOfType(ex.InnerException, typeof(ArgumentOutOfRangeException));
}
}
示例4: DoDownloadToByteArrayTest
/// <summary>
/// Single put file and get file
/// </summary>
/// <param name="fileSize">The file size.</param>
/// <param name="bufferOffset">The file offset.</param>
/// <param name="option"> 0 - Sunc, 1 - APM and 2 - APM overload.</param>
private void DoDownloadToByteArrayTest(CloudFile file, int fileSize, int bufferSize, int bufferOffset, int option)
{
int downloadLength;
byte[] buffer = GetRandomBuffer(fileSize);
byte[] resultBuffer = new byte[bufferSize];
byte[] resultBuffer2 = new byte[bufferSize];
using (MemoryStream originalFile = new MemoryStream(buffer))
{
if (option == 0)
{
file.UploadFromStream(originalFile);
downloadLength = file.DownloadToByteArray(resultBuffer, bufferOffset);
}
else if (option == 1)
{
using (AutoResetEvent waitHandle = new AutoResetEvent(false))
{
ICancellableAsyncResult result = file.BeginUploadFromStream(originalFile,
ar => waitHandle.Set(),
null);
waitHandle.WaitOne();
file.EndUploadFromStream(result);
result = file.BeginDownloadToByteArray(resultBuffer,
bufferOffset,
ar => waitHandle.Set(),
null);
waitHandle.WaitOne();
downloadLength = file.EndDownloadToByteArray(result);
}
}
else
{
using (AutoResetEvent waitHandle = new AutoResetEvent(false))
{
ICancellableAsyncResult result = file.BeginUploadFromStream(originalFile,
ar => waitHandle.Set(),
null);
waitHandle.WaitOne();
file.EndUploadFromStream(result);
OperationContext context = new OperationContext();
result = file.BeginDownloadToByteArray(resultBuffer,
bufferOffset, /* offset */
null, /* accessCondition */
null, /* options */
context, /* operationContext */
ar => waitHandle.Set(),
null);
waitHandle.WaitOne();
downloadLength = file.EndDownloadToByteArray(result);
}
}
int downloadSize = Math.Min(fileSize, bufferSize - bufferOffset);
Assert.AreEqual(downloadSize, downloadLength);
for (int i = 0; i < file.Properties.Length; i++)
{
Assert.AreEqual(buffer[i], resultBuffer[bufferOffset + i]);
}
for (int j = 0; j < bufferOffset; j++)
{
Assert.AreEqual(0, resultBuffer2[j]);
}
if (bufferOffset + fileSize < bufferSize)
{
for (int k = bufferOffset + fileSize; k < bufferSize; k++)
{
Assert.AreEqual(0, resultBuffer2[k]);
}
}
}
}
示例5: DoDownloadRangeToByteArrayTask
/// <summary>
/// Single put file and get file
/// </summary>
/// <param name="fileSize">The file size.</param>
/// <param name="bufferSize">The output buffer size.</param>
/// <param name="bufferOffset">The output buffer offset.</param>
/// <param name="fileOffset">The file offset.</param>
/// <param name="length">Length of the data range to download.</param>
/// <param name="overload">Run with overloaded parameters.</param>
private void DoDownloadRangeToByteArrayTask(CloudFile file, int fileSize, int bufferSize, int bufferOffset, long? fileOffset, long? length, bool overload)
{
int downloadLength;
byte[] buffer = GetRandomBuffer(fileSize);
byte[] resultBuffer = new byte[bufferSize];
byte[] resultBuffer2 = new byte[bufferSize];
using (MemoryStream originalFile = new MemoryStream(buffer))
{
if (overload)
{
file.UploadFromStream(originalFile);
downloadLength = file.DownloadRangeToByteArrayAsync(
resultBuffer, bufferOffset, fileOffset, length, null, null, new OperationContext()).Result;
}
else
{
file.UploadFromStream(originalFile);
downloadLength = file.DownloadRangeToByteArrayAsync(resultBuffer, bufferOffset, fileOffset, length).Result;
}
int downloadSize = Math.Min(fileSize - (int)(fileOffset.HasValue ? fileOffset.Value : 0), bufferSize - bufferOffset);
if (length.HasValue && (length.Value < downloadSize))
{
downloadSize = (int)length.Value;
}
Assert.AreEqual(downloadSize, downloadLength);
for (int i = 0; i < bufferOffset; i++)
{
Assert.AreEqual(0, resultBuffer[i]);
}
for (int j = 0; j < downloadLength; j++)
{
Assert.AreEqual(buffer[(fileOffset.HasValue ? fileOffset.Value : 0) + j], resultBuffer[bufferOffset + j]);
}
for (int k = bufferOffset + downloadLength; k < bufferSize; k++)
{
Assert.AreEqual(0, resultBuffer[k]);
}
}
}