[GAS] 구글 앱 스크립트 doGet과 doPost 사용 방법 [구글 앱 스크립트로 외부 요청 처리하기]

2024. 5. 15. 18:07·◎ JavaScript/Google App Script🐑
728x90


- 구글 앱 스크립트 doGet과 doPost 사용 방법

GAS에서 doGet과 doPost는 웹 애플리케이션을 만들 때 사용되는 기본적인 HTTP 요청 핸들러이다.
이 두 함수는 클라이언트에서 웹 애플리케이션으로 HTTP GET 및 POST 요청을 보낼 때 사용된다.

1. doGet

doGet 함수는 HTTP GET 요청을 처리한다. 클라이언트가 웹 애플리케이션의 URL에 쿼리 매개변수를 포함하여 GET 요청을 보내면, 앱스크립트는 doGet 함수를 호출하고 클라이언트에게 응답을 반환한다.

이 함수는 주로 웹 애플리케이션의 초기 화면을 제공하거나, 단순한 데이터 조회 등의 작업에 사용된다.

- Google App Script

// doGet 함수는 HTTP GET 요청을 처리합니다.
function doGet(e) {
  // 클라이언트에게 반환할 텍스트 작성
  var responseText = 'Hello World!';
  return ContentService.createTextOutput(responseText);
}

- JavaScript (외부)

// doGet을 호출하는 함수
function callDoGet() {
  // 구글 앱 스크립트에서 배포한 웹 애플리케이션의 URL 설정
  var url = "https://script.google.com/macros/s/${your-script-id}/exec";

  // fetch를 사용하여 GET 요청 보내기
  fetch(url)
    .then(response => response.text())
    .then(data => {
      console.log("Response from server: ", data); // "Response from server: Hello World!"
    })
    .catch(error => {
      console.error("Error: ", error);
    });
}

2. doPost

doPost 함수는 HTTP POST 요청을 처리한다. 클라이언트가 웹 애플리케이션의 URL에 POST 요청을 보내면, 앱스크립트는 doPost 함수를 호출하고 클라이언트에게 응답을 반환한다.

이 함수는 주로 웹 애플리케이션에서 양식 데이터를 전송하거나, 데이터를 수정 및 처리하는 작업에 사용된다.

- Google App Script

// doPost 함수는 HTTP POST 요청을 처리합니다.
function doPost(e) {
  // POST로 전송된 데이터를 가져옵니다.
  var formData = e.parameter;
  
  // 데이터 처리 로직 작성
  var processedData = processData(formData);
  
  // 클라이언트에게 반환할 JSON 형식의 응답
  var jsonResponse = {
    status: 'success',
    data: processedData
  };
  return ContentService.createTextOutput(JSON.stringify(jsonResponse)).setMimeType(ContentService.MimeType.JSON);
}

// 데이터 처리 함수 예시
function processData(formData) {
  // 여기에 데이터 처리 로직을 작성합니다.
  // 예: 폼 데이터를 데이터베이스에 저장하거나 다른 서비스에 전송하는 등의 작업
  return formData;
}

- JavaScript (외부)

// doPost을 호출하는 함수
function callDoPost() {
  // 구글 앱 스크립트에서 배포한 웹 애플리케이션의 URL 설정
  var url = "https://script.google.com/macros/s/${your-script-id}/exec";

  // POST 요청에 보낼 데이터 설정
  var formData = {
    key1: 'value1',
    key2: 'value2'
  };

  // fetch를 사용하여 POST 요청 보내기
  fetch(url, {
    method: 'POST',
    headers: {
      'Content-Type': 'application/json'
    },
    body: JSON.stringify(formData)
  })
    .then(response => response.json())
    .then(data => {
      console.log("Response from server:", data);
    })
    .catch(error => {
      console.error("Error:", error);
    });
}

728x90
'◎ JavaScript/Google App Script🐑' 카테고리의 다른 글
  • [GAS] 외부에서 구글 스프레드 시트에서 데이터 가져오기 [Google Sheets에서 URL 해시 매핑 데이터 가져오기]
  • [GAS] 외부에서 URL과 해시 값을 받아 스프레드시트에 저장하기 [Google Sheets에 외부 데이터 추가하기]
  • [GAS] 자동으로 구글 캘린더에 일정 추가하기 [구글 스프레드 시트와 캘린더 연동하기]
예르미(yermi)
예르미(yermi)
끊임없이 제 자신을 계발하는 개발자입니다👨🏻‍💻
  • 예르미(yermi)
    예르미의 코딩노트
    예르미(yermi)
  • 전체
    오늘
    어제
    • 분류 전체보기 (937)
      • ◎ Java (133)
        • Java☕ (93)
        • JSP📋 (26)
        • Applet🧳 (6)
        • Interview👨🏻‍🏫 (8)
      • ◎ JavaScript (48)
        • JavaScript🦎 (25)
        • jQuery🌊 (8)
        • React🌐 (2)
        • Vue.js🔰 (6)
        • Node.js🫒 (3)
        • Google App Script🐑 (4)
      • ◎ HTML5+CSS3 (17)
        • HTML5📝 (8)
        • CSS3🎨 (9)
      • ──────────── (0)
      • ▣ Framework (67)
        • Spring🍃 (36)
        • Spring Boot🍀 (12)
        • Bootstrap💜 (3)
        • Selenium🌕 (6)
        • MyBatis🐣 (10)
      • ▣ Tools (47)
        • API🎯 (18)
        • Library🎲 (15)
        • JitPack🚀 (3)
        • Jenkins👨🏻 (7)
        • Thymeleaf🌿 (4)
      • ▣ Server (32)
        • Apache Tomcat🐱 (14)
        • Apache HTTP Server🛡️ (1)
        • Nginx🧶 (7)
        • OracleXE💿 (4)
        • VisualSVN📡 (4)
      • ▣ OS : 운영체제 (18)
        • cmd : 명령프롬프트💻 (10)
        • Linux🐧 (8)
      • ▣ SQL : Database (56)
        • Oracle SQL🏮 (26)
        • PL SQL💾 (9)
        • MySQL🐬 (6)
        • MariaDB🦦 (6)
        • H2 Database🔠 (3)
        • SQL 실전문제🐌 (6)
      • ────────── (0)
      • ◈ Human Project (86)
        • Mini : Library Service📚 (15)
        • 화면 설계 [HTML]🐯 (10)
        • 서버 프로그램 구현🦁 (15)
        • Team : 여수어때🛫 (19)
        • Custom : Student🏫 (9)
        • Custom : Board📖 (18)
      • ◈ Yermi Project (40)
        • 조사모아(Josa-moa)📬 (5)
        • Riddle-Game🧩 (6)
        • 맛있을 지도🍚 (2)
        • 어디 가! 박대리!🙋🏻‍♂️ (5)
        • 조크베어🐻‍❄️ (4)
        • Looks Like Thirty🦉 (2)
        • Toy Project💎 (12)
        • 오픈소스 파헤치기🪐 (4)
      • ◈ Refactoring (15)
        • Mini : Library Service📚 (8)
        • 서버 프로그램 구현🦁 (1)
        • Team : 여수어때🛫 (0)
        • 쿼리 튜닝일지🔧 (6)
      • ◈ Coding Test (89)
        • 백준(BOJ)👨🏻‍💻 (70)
        • 프로그래머스😎 (2)
        • 코드트리🌳 (7)
        • 알고리즘(Algorithm)🎡 (10)
      • ◈ Study (102)
        • 기초튼튼 개발지식🥔 (25)
        • HTTP 웹 지식💡 (4)
        • 클린코드(Clean Code)🩺 (1)
        • 디자인패턴(GoF)🥞 (12)
        • 다이어그램(Diagram)📈 (4)
        • 파이썬(Python)🐍 (16)
        • 에러노트(Error Note)🧱 (34)
        • 웹 보안(Web Security)🔐 (6)
      • ◈ 공부모임 (39)
        • 혼공학습단⏰ (18)
        • 코드트리 챌린지👊🏻 (2)
        • 개발도서 100독👟 (8)
        • 나는 리뷰어다🌾 (11)
      • ◈ 자격증 공부 (37)
        • 정보처리기사🔱 (16)
        • 정보처리산업기사🔅 (9)
        • 컴퓨터활용능력 1급📼 (12)
      • ─────────── (0)
      • ◐ 기타 (113)
        • 알아두면 좋은 팁(tip)✨ (46)
        • 개발자의 일상🎈 (44)
        • 개발도서 서평🔍 (10)
        • 개발관련 세미나🎤 (2)
        • 블로그 꾸미기🎀 (9)
        • 사도신경 프로젝트🎚️ (2)
  • 인기 글

  • 최근 댓글

  • 태그

    Project
    spring
    백준 티어
    Oracle
    자바스크립트
    BOJ
    백준
    javascript
    Java
    CSS
    SQL
    Database
    코딩
    jsp
    html
    프로그래밍
    Error Note
    코딩 테스트
    일상
    꿀팁
  • 250x250
  • hELLO· Designed By정상우.v4.10.3
예르미(yermi)
[GAS] 구글 앱 스크립트 doGet과 doPost 사용 방법 [구글 앱 스크립트로 외부 요청 처리하기]
상단으로

티스토리툴바