如何将图片上传到Google云端硬盘共享文件夹并获取其可共享的网址?

时间:2020-10-21 15:03:28

标签: image web url directory

目前,我有一个可以正常工作的Arduino App,它可以拍照,然后将其上传到Goggle Drive文件夹(已经公开),并将一些相关数据存储在Google表格中,包括图像文件名。

但是我需要从在其他地方运行的Web应用程序访问此数据和图像。 图片名称“ filename.jpg”不能作为URL的一部分。

在我当前的解决方案中,使用了两个脚本: 第一次成功传输图像。 第二个命令在Google表格中添加了一行,其中包含所有必要的参数,但在此阶段,我所拥有的只是filename.jpg。

我需要在第二个脚本中添加一些内容,以获取filename.jpg的URL,以便可以将其与相关数据一起存储在Google表格中。

如果我可以将两个脚本的功能合并为一个,则可以完成该任务,因为传输脚本可以访问文件ID,但是我确实需要这方面的帮助。

图像传输脚本:

function doPost(e) {
  var myFoldername = e.parameter.myFoldername;
  var myFile = e.parameter.myFile;
  var myFilename = e.parameter.myFilename;
  //var myFilename = Utilities.formatDate(new Date(), "GMT", "yyyyMMddHHmmss")+"-"+e.parameter.myFilename;
  var myToken = e.parameter.myToken;
  
  var contentType = myFile.substring(myFile.indexOf(":")+1, myFile.indexOf(";"));
  var data = myFile.substring(myFile.indexOf(",")+1);
  data = Utilities.base64Decode(data);
  var blob = Utilities.newBlob(data, contentType, myFilename);
  
  // Save a captured image to Google Drive.
  var folder, folders = DriveApp.getFoldersByName(myFoldername);
  if (folders.hasNext()) {
    folder = folders.next();
  } else {
    folder = DriveApp.createFolder(myFoldername);
  }
  var file = folder.createFile(blob);    
  file.setDescription("Uploaded by " + myFilename);
  
  var imageID = file.getUrl().substring(file.getUrl().indexOf("/d/")+3,file.getUrl().indexOf("view")-1);
  var imageUrl = "https://drive.google.com/uc?authuser=0&id="+imageID;
    
  // Send a link message to Line Notify.
  var res = "Line Notify: ";
  try {
    var url = 'https://notify-api.line.me/api/notify';
    var response = UrlFetchApp.fetch(url, {
      'headers': {
        'Authorization': 'Bearer ' + myToken,
      },
      'method': 'post',
      'payload': {
          'message': imageUrl
      }
    });
    res += response.getContentText();
  } catch(error) {
    res += error;
  } 
    
  return  ContentService.createTextOutput(myFoldername+"/"+myFilename+"\n"+imageUrl+"\n"+res);
}

Google表格脚本:

    var timeZone = "UTC"; //get yours at https://www.timeanddate.com/time/zones/
var dateTimeFormat = "dd/MM/yyyy HH:mm";

var enableSendingEmails = true;
var emailAddress = ""; // comma separate for several emails
// 'bob@example.com';
// 'bob@example.com,admin@example.com';

function doGet(e) {
    var result = 'Ok'; // default result
    if (e.parameter == 'undefined') {
        result = 'No Parameters';
    } else {
      
        var alarm= e.parameter.alarm;
        if (typeof alarm != 'undefined') {

            sendEmail("alarm text:" + stripQuotes(alarm));
            return ContentService.createTextOutput(result);
        }

        var sheet = getSpreadSheet();
        var lastRow = sheet.getLastRow();
        var newRow = 1;
        if (lastRow > 0) {
            var lastVal = sheet.getRange(lastRow, 1).getValue();
          //if there was no info for (sentEmailIfUnitIsOutForMinutes) checkIfDead() function will append row with 'dead' text
          // so checking do we need to override it
            if (lastVal == 'dead')
                newRow = lastRow; //to overwrite "dead" value
            else
                newRow = lastRow + 1;

        }

        var rowData = [];
        var namesOfParams=[];
        for (var param in parseQuery(e.queryString))
          namesOfParams.push(param);
//      namesOfParams=namesOfParams.reverse();
      
      //creatating headers if first row
        if (newRow == 1) {
            rowData[0] = "Date";
            var i = 1;
            for (var i=0; i<namesOfParams.length;i++  ) {
                rowData[i+1] = namesOfParams[i];
            }
            var newRange = sheet.getRange(newRow, 1, 1, rowData.length);
            newRange.setValues([rowData]);
            rowData = [];
            newRow++;
        }

        rowData[0] = Utilities.formatDate(new Date(), timeZone, dateTimeFormat);
    
        for (var i=0; i<namesOfParams.length;i++  ) {

          var value = stripQuotes(e.parameter[namesOfParams[i]]);
             
          rowData[i+1] = value;

        }
        var newRange = sheet.getRange(newRow, 1, 1, rowData.length);
        newRange.setValues([rowData]);
    }
    // Return result of operation
    return ContentService.createTextOutput(result);
}


// Remove leading and trailing single or double quotes

function stripQuotes(value) {
    return value.replace(/^["']|['"]$/g, "");
}

function parseQuery(queryString) {
    var query = {};
    var pairs = (queryString[0] === '?' ? queryString.substr(1) : queryString).split('&');
    for (var i = 0; i < pairs.length; i++) {
        var pair = pairs[i].split('=');
        query[decodeURIComponent(pair[0])] = decodeURIComponent(pair[1] || '');
    }
    return query;
}

function sendEmail(message) {
   if (!enableSendingEmails)
        return;
    var subject = 'Something wrong with your esp';
   MailApp.sendEmail(emailAddress, subject, message);
}


function getSpreadSheet() {
    return SpreadsheetApp.getActiveSheet();
}

欢迎协助。 谢谢 保罗

1 个答案:

答案 0 :(得分:0)

使用以下脚本解决了问题:

var timeZone = "GMT";
var dateTimeFormat   = "dd/MM/yyyy HH:mm:ss";
var logSpreadSheetId = "1W1ypQEkfKNFSqhtfgbjbjFgzHO8LDaTv6mNWTP9h4M8"; 
// logSpreadSheetId is to be copied from the sheet's URL as follows: https://docs.google.com/spreadsheets/d/1W1ypQEkfKNFSqhtfgbjbjFgzHO8LDaTv6mNWTP9h4M8/edit#gid=0

function doPost(e) {
  var myFoldername = e.parameter.myFoldername;
  var myFile = e.parameter.myFile;
  //var myFilename = e.parameter.myFilename;
  //var myFilename = Utilities.formatDate(new Date(), timeZone, "ddMMyyyyHHmmss")+"-"+e.parameter.myFilename;
  var myFilename = Utilities.formatDate(new Date(), timeZone, "ddMMyyyyHHmmss")+".jpg";
  var myToken    = e.parameter.myToken; 
  
  var contentType = myFile.substring(myFile.indexOf(":")+1, myFile.indexOf(";"));
  var data = myFile.substring(myFile.indexOf(",")+1);
  data = Utilities.base64Decode(data);
  var blob = Utilities.newBlob(data, contentType, myFilename);
  
  // Save a captured image to Google Drive.
  var folder, folders = DriveApp.getFoldersByName(myFoldername);
  if (folders.hasNext()) {
    folder = folders.next();
  } else {
    folder = DriveApp.createFolder(myFoldername);
  }
  var file = folder.createFile(blob);    
  file.setDescription("Uploaded by " + myFilename);
  
  var imageID  = file.getUrl().substring(file.getUrl().indexOf("/d/")+3,file.getUrl().indexOf("view")-1);
  var imageUrl = "https://drive.google.com/uc?authuser=0&id="+imageID;

  addLog(myFilename,imageUrl);
 
  return  ContentService.createTextOutput(myFoldername+"/"+myFilename+"\n"+imageUrl+"\n");  //+res);
}

function addLog(myFilename,imageUrl) {
  var spr   = SpreadsheetApp.openById(logSpreadSheetId);
  var sheet = spr.getSheets()[0];
  var data  = sheet.getDataRange().getValues();
  var pos   = sheet.getLastRow();
  
  var rowData  = [];
  
  if(!pos>0){
    pos = 1;
    rowData[0]   = "Date";
    rowData[1]   = "Image";
    rowData[2]   = "URL";
    var newRange = sheet.getRange(pos, 1, 1, rowData.length);
    newRange.setValues([rowData]);
  } 
  pos     = pos +1;
  rowData = [];
  rowData[0]   = Utilities.formatDate(new Date(), timeZone, dateTimeFormat);
  rowData[1]   = myFilename;
  rowData[2]   = imageUrl;
  var newRange = sheet.getRange(pos, 1, 1, rowData.length);
  newRange.setValues([rowData]);
}

此外,为简单起见,工作表和脚本现在位于独立文件上,因为脚本可以使用其ID来引用工作表,如下所示:var logSpreadSheetId =“ 1W1ypQEkfKNFSqhtfgbjbjFgzHO8LDaTv6mNWTP9h4M8” (请使用您自己的工作表的ID。)

相关问题