inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

React에서 FCM 사용

1113

김민지

작성한 질문수 1

0

안녕하세요 !

FCM으로 푸시 기능을 짜다가,, 도저히 모르겠어서 글 남깁니다 ..!

 

문제는 콘솔에는 푸시 알림이 왔다는 게 찍히는데,

푸시가 보이지 않습니다 ... ㅠㅠ

[ 폴더 구조 ]

[ firebase-messaging-sw.js ]

self.addEventListener('push', function (e) {
  console.log('push: ', e.data.json())
  if (!e.data.json()) return

  const resultData = e.data.json().notification
  const notificationTitle = resultData.title
  const notificationOptions = {
    body: resultData.body,
    icon: resultData.image,
    tag: resultData.tag,
    ...resultData
  }
  console.log('push: ', { resultData, notificationTitle, notificationOptions })

  registration.showNotification(notificationTitle, notificationOptions)
})

[ messaging_init_in_sw.js ]

import { initializeApp } from 'firebase/app'
import { getMessaging, getToken } from 'firebase/messaging'

const firebaseConfig = {
  apiKey: process.env.REACT_APP_FIREBASE_API_KEY,
  authDomain: process.env.REACT_APP_FIREBASE_AUTH_DOMAIN,
  projectId: process.env.REACT_APP_FIREBASE_PROJECT_ID,
  storageBucket: process.env.REACT_APP_FIREBASE_STORAGE_BUCKET,
  messagingSenderId: process.env.REACT_APP_FIREBASE_MESSAGING_SENDER_ID,
  appId: process.env.REACT_APP_FIREBASE_APP_ID,
  measurementId: process.env.REACT_APP_FIREBASE_MEASUREMENT_ID
}

function requestPermission() {
  console.log('푸시 허가 받는 중 ...')

  void Notification.requestPermission().then((permission) => {
    if (permission === 'granted') {
      console.log('푸시 알림이 허용되었습니다.')
    } else {
      console.log('푸시 알림이 허용되지 않았습니다')
    }
  })

  const app = initializeApp(firebaseConfig)
  const messaging = getMessaging(app)

  void getToken(messaging, { vapidKey: process.env.REACT_APP_FIREBASE_VAPID_KEY }).then((token) => {
    if (token.length > 0) {
      console.log('푸시 토큰 : ', token)
    } else {
      console.log('푸시 토큰 실패 !')
    }
  })
}

requestPermission()

 

토큰은 제대로 잘 받아와지는데,,, 혹시 서비스워커 코드에 문제가 있는 걸까요 ..?

react fcm firebase push

답변 1

0

김민지

image

혹시 localhost에서는 불가능한건가요 ..?!

PRD.md

0

6

1

클로드코드 단축키 문의

0

10

0

Shrimp Task Manager npx 설치 질문

0

10

0

클로드 코드 초기 설정이 안되요

1

12

1

클로드 코드 터미널 텍스트 중복 출력

0

15

1

비밀번호 재설정 1회용 이메일 링크

0

16

1

강의교안

0

22

1

DOCs와 스킬관련 PRD 폴더트리

0

15

1

캡쳐이미지 터미널에 복붙하는 방법 (윈도우 사용시)

0

16

1

강의교안

0

25

1

확장프로그램 찾기

1

24

1

/statusline 상태표시줄 표시 왜 안될까요

0

24

1

컴포넌트와 레이아웃

0

22

2

강의 노트 확인 방법

0

28

2

공부방향에 대한 조언

0

20

2

styled-components

0

19

2

터미널 기본명령어 강의교안의 링크가 연결되지 않습니다.

0

28

2

모듈형 규칙: .claude/rules - 메모리에 설정 내용 미반영

0

20

2

커서에서 파일추가 Side bar 추가가 어려워요

0

23

1

섹션 8 git 및 github사용 관련

0

24

2

바이브코딩으로서의 개발공부

0

36

2

github 사용 관련 질문

0

29

2

클로드 코드 명령어 입력란이 맨 밑에 있어요

0

20

2

prd생성 관련 소스..

0

29

2