我在终端中为azure定义了环境变量,如下所示,
SET AZURE_STORAGE_ACCOUNT=accountname
SET SAS_TOKEN="sr=c&sp=rwl&sig=signatureKey%3D&sv=2017-04-17&se=2018-03-10"
在定义变量之后,我在azure blob存储函数中调用了这些变量,比如
AZURE_STORAGE_ACCOUNT= process.env.AZURE_STORAGE_ACCOUNT;
SAS_TOKEN = process.env.SAS_TOKEN;
var blobUri = "http://"+AZURE_STORAGE_ACCOUNT+".blob.core.windows.net";
var blobService = azureStorage.createBlobServiceWithSas(blobUri, SAS_TOKEN).withFilter(new azureStorage.ExponentialRetryPolicyFilter());
blobService.createBlockBlobFromLocalFile('mycontainer', 'sparks-events-data', fileToWrite, function(error, result, response) {
if (!error) {
console.log("upload successful..");
} else {
console.log(error);
}});
当我运行上面的文件时,我得到的错误就像
StorageError:服务器无法验证请求。确保正确形成Authorization标头的值,包括签名。
但是当我直接在代码中调用SAS令牌时,它工作正常。我这样用
var sasKey = "sr=c&sp=rwl&sig=signatureKey%3D&sv=2017-04-17&se=2018-03-10";
var blobService = azureStorage.createBlobServiceWithSas(blobUri, sasKey ).withFilter(new azureStorage.ExponentialRetryPolicyFilter());
这对我来说可以。我需要将SAS令牌设置为环境变量。这就是我所缺少的。请有人建议我解决这个问题。提前致谢,
export
代替那些env vars。导出变量会导致变量由在该shell中启动的后续进程继承。
export SAS_TOKEN="..."
在编译自己的env var secrets处理逻辑之前,您可能需要查看此npm包。我们已经破解了这一点,作为一个民众 - https://github.com/motdotla/dotenv
在Windowsland中,只需使用set
,但请确保您的Node进程在同一个终端窗口中启动:
C:\lab> set KEY="secret"
C:\lab> type app.js
let key = process.env.KEY;
console.log('KEY is ' + key);
C:\lab> node app.js
KEY is "secret"
小心那些报价!