【发布时间】:2021-08-05 08:59:35
【问题描述】:
我正在尝试在 VS2019 中创建一个 blob 库。我创建了一个带有 HTTPS 配置、.NET Core 3.1 且没有身份验证的 ASP .NET Core (MVC) 项目。我在 Azure 中有 blob 存储,但在这个项目中,我使用的是启用了模拟器的 Azure 存储资源管理器。 当我开始一个项目时,它向我显示了一个很好的 html 页面,并且我可以选择上传它的按钮工作正常,但是当我按下上传按钮时,我收到错误“https://localhost:44330 / Home / UploadAsync”。我认为这可能是由于我在 homecontroller 中看不到的一个错误,因为我已经用 css 文件实现了它和 html。
我将补充一点,使用命令"StorageConnectionString": "UseDevelopmentStorage=true" 在appsettings.json 文件中建立连接。在模拟器中之后,我看到名称中包含代码的新文件夹。我正在使用 WindowsAzure.Storage 包。
家庭控制器代码:
namespace WebApplication.Controllers
{
public class HomeController : Controller
{
static CloudBlobClient _blobClient;
const string _blobContainerName = "imagecontainer";
private readonly IConfiguration _configuration;
static CloudBlobContainer _blobContainer;
public HomeController(IConfiguration configuration)
{
_configuration = configuration;
}
public async Task<ActionResult> Index()
{
try
{
var storageConnectionString = _configuration.GetValue<string>("StorageConnectionString");
var storageAccount = CloudStorageAccount.Parse(storageConnectionString);
_blobClient = storageAccount.CreateCloudBlobClient();
_blobContainer = _blobClient.GetContainerReference(_blobContainerName);
await _blobContainer.CreateIfNotExistsAsync();
await _blobContainer.SetPermissionsAsync(new BlobContainerPermissions { PublicAccess = BlobContainerPublicAccessType.Blob });
List<Uri> allBlobs = new List<Uri>();
BlobContinuationToken blobContinuationToken = null;
do
{
var response = await _blobContainer.ListBlobsSegmentedAsync(blobContinuationToken);
foreach (IListBlobItem blob in response.Results)
{
if (blob.GetType() == typeof(CloudBlockBlob))
allBlobs.Add(blob.Uri);
}
blobContinuationToken = response.ContinuationToken;
} while (blobContinuationToken != null);
return View(allBlobs);
}
catch (Exception ex)
{
ViewData["message"] = ex.Message;
ViewData["trace"] = ex.StackTrace;
return View("Error");
}
}
[HttpPost]
public async Task<ActionResult> UploadAsync()
{
try
{
var request = await HttpContext.Request.ReadFormAsync();
if (request.Files == null)
{
return BadRequest("Could not upload files");
}
var files = request.Files;
if (files.Count == 0)
{
return BadRequest("Could not upload empty files");
}
for (int i = 0; i < files.Count; i++)
{
var blob = _blobContainer.GetBlockBlobReference(GetRandomBlobName(files[i].FileName));
using (var stream = files[i].OpenReadStream())
{
await blob.UploadFromStreamAsync(stream);
}
}
return RedirectToAction("Index");
}
catch (Exception ex)
{
ViewData["message"] = ex.Message;
ViewData["trace"] = ex.StackTrace;
return View("Error");
}
}
[HttpPost]
public async Task<ActionResult> DeleteImage(string name)
{
try
{
Uri uri = new Uri(name);
string filename = Path.GetFileName(uri.LocalPath);
var blob = _blobContainer.GetBlockBlobReference(filename);
await blob.DeleteIfExistsAsync();
return RedirectToAction("Index");
}
catch (Exception ex)
{
ViewData["message"] = ex.Message;
ViewData["trace"] = ex.StackTrace;
return View("Error");
}
}
[HttpPost]
public async Task<ActionResult> DeleteAll()
{
try
{
BlobContinuationToken blobContinuationToken = null;
do
{
var response = await _blobContainer.ListBlobsSegmentedAsync(blobContinuationToken);
foreach (IListBlobItem blob in response.Results)
{
if (blob.GetType() == typeof(CloudBlockBlob))
await ((CloudBlockBlob)blob).DeleteIfExistsAsync();
}
blobContinuationToken = response.ContinuationToken;
} while (blobContinuationToken != null);
return RedirectToAction("Index");
}
catch (Exception ex)
{
ViewData["message"] = ex.Message;
ViewData["trace"] = ex.StackTrace;
return View("Error");
}
}
private string GetRandomBlobName(string filename)
{
string ext = Path.GetExtension(filename);
return string.Format("{0:10}_{1}{2}", DateTime.Now.Ticks, Guid.NewGuid(), ext);
}
public IActionResult Privacy()
{
return View();
}
[ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)]
public IActionResult Error()
{
return View(new ErrorViewModel { RequestId = Activity.Current?.Id ?? HttpContext.TraceIdentifier });
}
}
}
【问题讨论】:
-
可以分享html内容吗?
标签: c# .net azure asp.net-core blob