• 목록
  • 아래로
  • 위로
  • 5
  • 네모
  • 조회 수 1744

1531053644050.jpg

- 이미지 출처 : www.infofueguina.com -

 

 

 

 

구글 드라이브 API를 사용하여 사이트의 첨부파일을 업로드 할 때, 업로드한 파일의 소유자를 변경할 필요가 있다.

서비스계정을 사용한다면 드라이브의 유료결제 공간을 사용할 수 없으므로 당연히 필요할 것이고,

각자의 계정을 통해(OAuth2) 업로드를 진행한다고 홰도, 업로더가 파일을 삭제하면 첨부파일을 사용할 수 없게 되므로 소유자 변경이 꼭 필요하다.

 

 

 

그러나 구글은 보안상의 문제로 몇몇 형식을 제외하고는 소유권 이전을 할 수 없도록 막아두었다.

허용된 파일은 구글 문서, 스프레드시트, 프레젠테이션, 설문지, 드로잉, 지도, 폴더로 총 7가지 종류가 있으나,

첨부파일로 올라오는 파일들의 대부분은 저 7개를 만족하지 못한다.

 

 

 

 

 

그래서 조금 번거롭고 아니꼽지만 약간의 꼼수를 사용해야 한다.

 

구글 스크립트(https://script.google.com/) 라는 서비스가 있다.

정확한 서비스명은 구글 앱스 스크립트(GAS) 라고 하는것 같다만, 도메인명은 그냥 script.google 이니 구글 스크립트라고 부르자.

 

어쨌든, 해당 서비스를 사용하면 소유권을 이전할 수 있다.

소유권 이전까지의 흐름은 아래와 같다.

 

 

 

1. API로 파일을 업로드 한다.

2. 업로드한 파일에 소유권을 이전할 계정으로 읽기 권한을 부여한다.

3. 구글 스크립트로 소유권을 이전할 계정의 드라이브에 업로드한 파일을 복사한다.

4.복사한 파일에 기존 업로더의 권한을 부여한다.

5. 기존에 업로드한 파일을 삭제한다.

6. 복사한 파일을 사용하여 다운로드 URL 등을 처리한다.

 

 

 

 

 

나의 경우 폴더를 하나 생성하고, 서비스계정과 유료계정의 권한을 지정한 뒤 해당 폴더에 이동시키는 방식을 사용했다.

아래는 구글 스크립트에서 사용할 수 있는 코드의 예제이다.

 

20180708213556.png

 

code.gs

 

 

웹앱 URL을 생성한 뒤, 파라미터로 fileId=***&folderId=*** 를 추가하여 curl 등의 방식으로 요청하면 된다.

웹앱 URL 생성시 모든 사용자(익명 포함)으로 지정하고, fileId와 folderId 두개 모두에게 권한이 있어야 한다.

 

작성자
네모 71 Lv. (45%) 408540/414720EXP

인스타그램 : http://instg.me/nemo_9l

댓글 5

abnoeh
profile image
저러면 모든 업로드 계정 비밀번호를 관리자가 알고 있어야 하는거 아닌가요?
comment menu
2018.07.08. 22:37

신고

"abnoeh님의 댓글"

이 댓글을 신고 하시겠습니까?

네모 작성자 → abnoeh
profile image
구글 스크립트에서는 스크립트 실행 주체를 선택할 수 있습니다.
어떤 유저가 실행하더라도 관리자 계정으로만 실행이 되는 방식으로도 설정이 가능합니다.
그게 기본값이기도 하구요.
comment menu
2018.07.08. 22:40

신고

"네모님의 댓글"

이 댓글을 신고 하시겠습니까?

NoYeah
profile image
이거 잘 응용하면 호스팅 용량을 (라이믹스의 files 폴더)를 구글 드라이브에서 불러오도록 할 수 있겠네요.
comment menu
2018.07.09. 00:07

신고

"NoYeah님의 댓글"

이 댓글을 신고 하시겠습니까?

네모 작성자 → NoYeah
profile image
네. 그 기능을 제작하다가 소유권 이전이 잘 되지 않아서 어찌저찌 떠올린 방법입니다.
comment menu
2018.07.09. 00:11

신고

"네모님의 댓글"

이 댓글을 신고 하시겠습니까?

abnoeh → NoYeah
profile image
그런식으로 긁어오게 하면 api 제한 (한 유저는 100초에 1000번만 요청 가능)에 걸리지 않을까요?
https://console.developers.google.com/apis/api/drive.googleapis.com/quotas?pli=1


Queries per day 1,000,000,000
Queries per 100 seconds per user 1,000
Queries per 100 seconds 10,000
comment menu
2018.07.09. 20:05

신고

"abnoeh님의 댓글"

이 댓글을 신고 하시겠습니까?

권한이 없습니다.
번호 제목 글쓴이 날짜 조회 수
공지 [작업 완료] 설 명절 맞이 서버 업데이트 안내 3 마스터 마스터 24.02.11.17:21 727
공지 [중요] 호스팅 만료와 관련하여 일부 수칙이 변경됩니다. 4 마스터 마스터 23.01.14.02:23 4398
546 [Python] 소수점 자리수의 출력 - round() vs format() 1 이니스프리 이니스프리 20.02.15.11:53 31765
545 [Python] 파일을 읽어서 각 행을 리스트로 만드는 5가지 방법 이니스프리 이니스프리 18.11.25.22:16 23301
544 안티앨리어싱 옵션: 알고 쓰자. 5 image 하루살이 title: 황금 서버 (30일)하루살이 17.02.25.23:57 19432
543 GIF 파일의 용량을 줄여주는 사이트 - gifgifs.com image 이니스프리 이니스프리 17.10.09.12:57 17666
542 [Python] tqdm과 enumerate를 함께 사용하기 이니스프리 이니스프리 20.05.29.19:07 16482
541 [OpenCV] !_src.empty() in function 'cvtColor' 에러 해결방법 2 이니스프리 이니스프리 19.11.15.20:40 12738
540 윈도우 작업 스케줄러에서 특정 작업이 실행 안 되는 경우 해결방법 (배치파일 등의 상대경로 관련) 2 image 이니스프리 이니스프리 18.10.02.19:38 12375
539 [파이썬] Selenium에서 클릭이 안 될 때의 해결방법 이니스프리 이니스프리 19.10.27.22:20 10372
538 [Python] Requests에서 JSON 데이터를 POST 전송하는 방법 x2 이니스프리 이니스프리 21.08.22.08:16 9597
537 [Selenium] select box, check box, radio button 조작하기 이니스프리 이니스프리 20.06.27.15:47 8446
536 유튜브 iframe api의 autoplay 옵션과 관련하여 1 image 이니스프리 이니스프리 19.01.05.14:45 7530
535 윈도우 MAK 라이센스의 인증 가능횟수 확인방법 4 이니스프리 이니스프리 18.11.21.23:53 7514
534 일본 아마존에서 MP3 음원 구입하는 방법 5 image 제르엘 제르엘 19.12.23.01:28 7367
533 DB 설계하실 때 사용하면 좋을거 같은 사이트 공유합니다. 1 image JAVA JAVA 17.11.21.15:06 6992
532 국전 '빨간집' 위치 및 영업시간 등 정보 3 이니스프리 이니스프리 18.11.30.16:17 6742
531 제조사별 서버 원격관리 툴의 명칭 정리 (iLO, iDRAC, IPMI 등) 이니스프리 이니스프리 18.11.22.22:10 6483
530 해외직구시 카드 중복결제에 대하여 (아마존 등) 9 이니스프리 이니스프리 18.12.30.15:52 6107
529 텔레그램 비밀대화의 스크린캡쳐 방지기능 이니스프리 이니스프리 20.01.20.23:44 5874
528 크롬 원격 데스크톱 조작법 2 이니스프리 이니스프리 20.06.03.23:03 5822
527 윈도우의 CMD 창에서 Ctrl+V로 붙여넣기 (윈도우 10 / 윈도우 8 이하) 3 image 이니스프리 이니스프리 18.11.08.00:15 5756