강의

멘토링

커뮤니티

인프런 커뮤니티 질문&답변

hib4888님의 프로필 이미지
hib4888

작성한 질문수

[리뉴얼] React로 NodeBird SNS 만들기

카카오톡 공유하기 & 강좌 마무리

lambda 함수 오류 질문드리겠습니다.

작성

·

297

0

안녕하세요 제로초님 강의를 들으면서 lambda함수를 구현하여 이미지 업로드 테스트를 했습니다.

근데 다음과 같이 로그이벤트를 확인해보니 AccessDenied 에러가 발생하면서 s3에 thumb폴더도 생기지 않았습니다.

확실하지는 않지만 해당 문제에 대해서 구글링해보니 버킷권한과 관련된 에러인것같아서

강의를 보면서 처음부터 실습하고, 오타도 확인해봤지만 방법을 찾지 못해 질문드립니다.

바쁘시겠지만 해당 문제에 관해서 피드백해주시면 감사하겠습니다.

참고자료도 함께 첨부하겠습니다.

CloudWatch Management Console - Chrome 2022-11-06 오후 10_35_50 (2).pngCloudWatch Management Console - Chrome 2022-11-06 오후 10_35_56 (2).pngCloudWatch Management Console - Chrome 2022-11-06 오후 10_36_02 (2).png

CloudWatch Management Console - Chrome 2022-11-06 오후 10_38_07 (2).pngCloudWatch Management Console - Chrome 2022-11-06 오후 10_38_11 (2).pngCloudWatch Management Console - Chrome 2022-11-06 오후 10_38_26.pngCloudWatch Management Console - Chrome 2022-11-06 오후 10_38_28.png

recipe-io - S3 bucket - Chrome 2022-11-06 오후 10_33_47 (2).png

 /lambda/index.js

const AWS = require('aws-sdk');
const sharp = require('sharp');

const s3 = new AWS.S3();

exports.handler = async (event, context, callback) => {
  const Bucket = event.Records[0].s3.bucket.name; // react-nodebird-s3
  const Key = decodeURIComponent(event.Records[0].s3.object.key); // original/12312312_abc.png
  console.log(Bucket, Key);
  const filename = Key.split('/')[Key.split('/').length - 1];
  const ext = Key.split('.')[Key.split('.').length - 1].toLowerCase();
  const requiredFormat = ext === 'jpg' ? 'jpeg' : ext;
  console.log('filename', filename, 'ext', ext);

  try {
    const s3Object = await s3.getObject({ Bucket, Key }).promise();
    console.log('original', s3Object.Body.length);
    const resizedImage = await sharp(s3Object.Body)
      .resize(400, 400, { fit: 'inside' })
      .toFormat(requiredFormat)
      .toBuffer();
    await s3.putObject({
      Bucket,
      Key: `thumb/${filename}`,
      Body: resizedImage,
    }).promise();
    console.log('put', resizedImage.length);
    return callback(null, `thumb/${filename}`);
  } catch (error) {
    console.error(error)
    return callback(error);
  }
}

 

개발자도구를 확인했을때는 특별한 오류가 발생되지 않습니다.

게시글 작성 _ Recipe.io - Chrome 2022-11-06 오후 8_59_49.png

 

답변 1

0

제로초(조현영)님의 프로필 이미지
제로초(조현영)
지식공유자

에러메시지 보시면 다운로드+(1)로 +가 들어가있습니다. 특수문자가 들어가버린것같은데

저장할 때 encodeURIComponent로 한글과 특수문자를 인코딩해서 저장하세요.

hib4888님의 프로필 이미지
hib4888
질문자

답변 감사합니다!!

hib4888님의 프로필 이미지
hib4888

작성한 질문수

질문하기