1

新问题

当我覆盖 blob 然后更新时,浏览器仍在缓存主图像而不是新图像。我读过有一个缓存控制属性,但我无法实现它。我需要清理刚刚上传的 blob 缓存

老问题

我正在尝试使用 connect-busboy 中间件和以下方法覆盖现有的 blob,但该文件没有被覆盖,我不明白为什么。

createBlockBlobFromStream(container, blob, (Stream), streamLength,
options, callback) → {SpeedSummary}

从流中上传块 blob。如果服务上已经存在 blob,它将被覆盖。

app.post('/upload', function(req, res, params) {
    var name;
    req.busboy.on('field', function (fieldname, val) {
      name = val+'.jpg';
    });

 req.busboy.on('file', function (fieldname, file, filename, encoding, mimetype) {
      file.on('data', function (data) {
        console.log(name);
         console.log(data);
        var bufferStream = new stream.PassThrough();
          bufferStream.end(data);
                var blobSvc = azure.createBlobService(accountName, accountKey);
          blobSvc.createBlockBlobFromStream('images', name, bufferStream, data.length, function (error, result, response){
              if (!error) {
                  res.send(200,'upload succeeded')
              } else {
                  res.send(500,JSON.stringify(error))
              }
          })
      });
    });
});
4

1 回答 1

0

根据Azure Storage SDK for Node API Reference

createBlockBlobFromStream(container, blob, (Stream), streamLength, options, callback) → {SpeedSummary}

从流中上传块 blob。如果服务上已经存在 blob,它将被覆盖。为避免覆盖并在 blob 存在时引发错误,请在选项对象中传入 accessConditions 参数。

因此,使用 Azure Storage SDK for Node 覆盖现有的 blob 文件是正确的。

编辑:

看来您遇到了上传问题。我建议您尝试使用createWriteStreamToBlockBlob而不是createBlockBlobFromStream将 blob 上传到 Azure 存储。以下示例使用connect-busboy中间件工作。创建 /public 文件夹。使用文件夹结构:

\index.js

\public\index.html

索引.JS

var express = require('express')
var app = express()
var busboy = require('connect-busboy')
var azure = require('azure-storage')

var accountName = "<acountName>"
var accountKey = "<accountKey>"

app.use(busboy())
app.use(express.static('public'))

app.get('/', function(req, res) {
  res.sendFile('index.html')
})

app.post('/upload', function(req, res, params) {
  req.pipe(req.busboy);

  req.busboy.on('file', function(fieldname, file, filename) {
    var blobSvc = azure.createBlobService(accountName, accountKey)
    file.pipe(blobSvc.createWriteStreamToBlockBlob('mycontainer', filename, function(error) {
      if (!error) {
        res.send(200, 'upload succeeded')
      } else {
        res.send(500, JSON.stringify(error))
      }
    }))

  })
})

app.listen(process.env.PORT || 3000, function() {
  console.log('Example app listening on port 3000!')
})

索引.HTML

<!DOCTYPE html>
<html>
<head>
    <title>Sample</title>
</head>

<body>
    <form action="/upload" method="post" enctype="multipart/form-data">
        Select image to upload:
        <input type="file" name="fileToUpload" id="fileToUpload">
        <input type="submit" value="Upload Image" name="submit">
    </form>
</body>
</html>
于 2016-12-30T02:58:23.523 回答