- 외부에서 URL과 해시 값을 받아 스프레드시트에 저장하기
웹 애플리케이션을 개발하다보면 외부에서 전달된 데이터를 스프레드시트에 저장해야 할 때가 있다. 오늘은 GAS를 사용하여 외부에서 전달된 URL과 해시 값을 받아와 스프레드시트에 저장하는 방법에 대해 알아본다.
아래 코드는 doPost 함수와 writeToSpreadsheet 함수로 구성되어 있다.
doPost 함수는 외부에서 전달된 URL과 해시 값을 가져와서 스프레드시트에 입력한다. 그리고 writeToSpreadsheet 함수는 받아온 데이터를 실제로 스프레드시트에 입력하는 역할을 한다.
// doPost 함수는 전달된 URL과 해시 값을 스프레드시트에 입력합니다.
function doPost(e) {
// 전달된 데이터에서 URL과 해시 값을 가져옵니다.
var url = e.parameter.url;
var hash = e.parameter.hash;
// URL 또는 해시 값이 없는 경우 에러 메시지를 반환합니다.
if (!url || !hash) {
return ContentService.createTextOutput('Please provide both URL and hash parameters.');
}
// 데이터를 스프레드시트에 입력합니다.
writeToSpreadsheet(url, hash);
// 성공 메시지를 반환합니다.
return ContentService.createTextOutput('Data successfully added to the spreadsheet.');
}
// 스프레드시트에 데이터를 입력하는 함수
function writeToSpreadsheet(url, hash) {
var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet();
// 마지막 행에 데이터를 추가합니다.
var lastRow = sheet.getLastRow();
sheet.getRange(lastRow + 1, 1).setValue(url);
sheet.getRange(lastRow + 1, 2).setValue(hash);
}
이 코드는 외부에서 POST 요청을 받아와서 URL과 해시 값을 추출하고, 그 값을 스프레드시트에 저장한다.
doPost 함수에서는 전달된 데이터에서 URL과 해시 값을 가져오고, 이를 writeToSpreadsheet 함수로 전달하여 스프레드시트에 저장한다.
JavaScript에서 불러오는 방법은 아래와 같다.
// 데이터 저장하기
async function saveData(url, hash) {
try {
const response = await fetch(`https://script.google.com/macros/s/${GOOGLE_APPS_SCRIPT_ID}/exec`, {
method: 'POST',
body: new URLSearchParams({
'url': url,
'hash': hash
})
});
if (!response.ok) {
throw new Error('네트워크 응답이 올바르지 않습니다.');
}
const data = await response.text();
} catch (error) {
console.error(error);
}
}