메뉴 건너뛰기

프로그램언어

조회 수 6044 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
이번에 골치아픈 프로젝트인 스프링기반의 자바웹서버에서 안드로이드앱으로 푸시알림을
보내야 하는 프로젝트를 진행중이였습니다. 어쩌다 보니 푸시 알림을 앱이 못 받아서
서버키가 문제인지 Device token이 문제인지 가장 간단한 디버깅 조건이 필요했습니다.

구글링을 해보니 PHP로 보내는 FCM소스가 있었으나 배열로 되어 있어서 배열 부분은 제거
하고 가장 간단하게 서버키와 Device token 1:1 로 바꿔봤습니다.

저같은 경우를 위해서 가장 간단한 fcm푸시 알림을 테스트 하기위한 PHP소스입니다.

<?php 
function send_notification ($tokens, $message)
{
$url = 'https://fcm.googleapis.com/fcm/send';
$fields = array(
'registration_ids' => $tokens,
'data' => $message
);
        $key = "서버키를 여기다 넣으세요";
$headers = array(
'Authorization:key =' . $key,
'Content-Type: application/json'
);
       
 $ch = curl_init();
       curl_setopt($ch, CURLOPT_URL, $url);?
       curl_setopt($ch, CURLOPT_POST, true);
       curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
       curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
       curl_setopt ($ch, CURLOPT_SSL_VERIFYHOST, 0);  
       curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
       curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($fields));
       $result = curl_exec($ch);           
       if ($result === FALSE) {
           die('Curl failed: ' . curl_error($ch));
       }
       curl_close($ch);
       return $result;
}
    


     $tokens = array();
     $tokens[0] = "디바이스 토큰을 여기다 넣으세요";
  
     $myMessage = "Message Test"
     if ($myMessage == ""){
$myMessage = "Newly registered.";
     }

     $message = array("message" => $myMessage);
     $message_status = send_notification($tokens, $message);
     echo $message_status;

 ?>

List of Articles
번호 제목 날짜 조회 수
280 MYSQL DB 다중접속을 해결 하는 한 방법 2021.03.26 284
279 MySQL DB 중복여부 검사하여 없는 것만 추가 2015.04.14 20157
278 MYSQL DB의 모든 테이블에서 문자열 검색 하기 2021.03.26 915
277 MYSQL 업데이트 두 번 하기 2014.02.27 19729
276 mysql 에러 구문 표시 2014.02.27 20349
275 MySQL(MariaDB) 테이블 만들기 2018.03.28 8153
274 mysql_affected_rows — 최근 MySQL 작업으로 변경된 행 개수를 얻음 2016.12.23 18807
273 mysql_free_result(); 관련 오류 2021.03.25 288
272 mysql_insert_id 2016.12.23 18750
271 mysql_real_escape_string 이진 데이터를 입력할 경우 이 함수를 사용해야 함 2016.12.23 18635
270 mysql_result — 결과 데이터를 반환 2016.12.23 18958
269 MySQL테이블의 내용을 엑셀파일(xls)로 다운로드 하기 2018.07.24 4798
268 parse_ini_file — Parse a configuration file 2016.12.23 19751
267 PEAR DB 관련 함수들 2021.03.26 690
266 PHP $_SERVER 함수 2019.02.25 1558
265 PHP + 유튜브(youtube) 동영상 업로드 연동 소스 2021.01.21 1140
264 PHP - 공공 DATA XML 파싱(PHP 버전) 2023.01.12 269
263 PHP continue 문 file 2015.04.14 21097
262 php date 날짜 관련 함수 file 2021.03.27 411
261 PHP eregi가 빠를까, strpos가 빠를까? 2018.10.27 4091
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 17 Next
/ 17

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved