Уведомления Firebase не доставляются, если отправлены, кроме консоли Firebase - PullRequest
1 голос
/ 17 февраля 2020

У меня действительно странная проблема: уведомления, отправленные с консоли Firebase, доставляются правильно, поэтому проект настроен и сертификаты верны, но когда я отправляю уведомление из приложения, оно не работает. Я использую следующий метод для отправки уведомлений.

func sendPushNotification(to token: String, title: String, body: String, Type: String) {

        let urlString = "https://fcm.googleapis.com/fcm/send"
        let url = NSURL(string: urlString)!
        let paramString: [String : Any] =
            [
                "message" :[
                    "to" : token,
                    "notification" : ["title" : title, "body" : body],
                    "data" : ["notification_type": Type]
                ],
                "to" : token
            ]

        print(paramString)
        let request = NSMutableURLRequest(url: url as URL)
        request.httpMethod = "POST"
        request.httpBody = try? JSONSerialization.data(withJSONObject:paramString, options: [.prettyPrinted])
        request.setValue("application/json", forHTTPHeaderField: "Content-Type")
        request.setValue("key=AAAApQ9EAjg:XXXX", forHTTPHeaderField: "Authorization")
        let task =  URLSession.shared.dataTask(with: request as URLRequest)  { (data, response, error) in
            do {
                if let jsonData = data {
                    if let jsonDataDict  = try JSONSerialization.jsonObject(with: jsonData, options: JSONSerialization.ReadingOptions.allowFragments) as? [String: AnyObject] {
                        NSLog("Received data:\n\(jsonDataDict))")
                    }
                }
            } catch let err as NSError {
                print(err.debugDescription)
            }
        }
        task.resume()



    }

Я также пытался отправить через curl следующим методом

<?php
/**
 * Created by PhpStorm.
 * User: ussaidiqbal
 * Date: 2020-02-17
 * Time: 19:45
 */

$url = "https://fcm.googleapis.com/fcm/send";
$token = "eMIK6wGOTUUutqp62vEIr-:XXXXXX";
$serverKey = 'AIzaSyCJFUydXXXXXXXXXX';
$title = "Title";
$body = "Body of the message";
$notification = array('title' =>$title , 'text' => $body, 'sound' => 'default', 'badge' => '1');
$arrayToSend = array('to' => $token, 'notification' => $notification,'priority'=>'high');
$json = json_encode($arrayToSend);
$headers = array();
$headers[] = 'Content-Type: application/json';
$headers[] = 'Authorization: key='. $serverKey;
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);

curl_setopt($ch, CURLOPT_CUSTOMREQUEST,

    "POST");
curl_setopt($ch, CURLOPT_POSTFIELDS, $json);
curl_setopt($ch, CURLOPT_HTTPHEADER,$headers);
//Send the request
$response = curl_exec($ch);
//Close request
if ($response === FALSE) {
    die('FCM Send Error: ' . curl_error($ch));
}
curl_close($ch);

Я также пытался отправить через PostMan , используя следующую полезную нагрузку

{
    "notification":{
        "title": "XXXXX",
        "body": "XXXXX"
    },
  "to": "XXXXXXX"
}

Это ответ на запрос

{
    "multicast_id": 36126XXXXXXXX,
    "success": 1,
    "failure": 0,
    "canonical_ids": 0,
    "results": [
        {
            "message_id": "0:1581960379105057~~~~~~~~~~"
        }
    ]
}

Похоже, что ни один из описанных выше методов не работает. Я делаю не так? Я пробовал оба Legacy server key и Server key , но не повезло. Кто-нибудь сталкивался с такой проблемой?

Ответы [ 3 ]

0 голосов
/ 17 февраля 2020

Я также думаю, что ваша paramString имеет неправильные свойства. Попробуйте это:

        let paramString: [String : Any] = [
            "to" : token,
            "notification" : ["title" : title, "text" : body],
            "time_to_live" : 60000,
            "sound" : "default"
        ]
0 голосов
/ 19 февраля 2020

Итак, потратив много времени, я понял, и все работает нормально. Так что если кто-то еще сталкивается с этой проблемой, он может решить, открыв ваш файл AppDelegate.swift, найдите функцию didRegisterForRemoteNotificationsWithDeviceToken и замените ее следующим кодом

 func application(_ application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data) {
        print("APNs token retrieved: \(deviceToken)")
        // With swizzling disabled you must set the APNs token here.
         Messaging.messaging().apnsToken = deviceToken
    }

После этого все, кажется, работает нормально.

0 голосов
/ 17 февраля 2020
struct NotificationStruct: Codable {
    var notification: NotificationBodyStruct?
    var to: String?
    var time_to_live = 60000
}

struct NotificationBodyStruct: Codable {
    var title: String?
    var text: String?
    var sound: String?
}    



func sendNotificationtoken: String, name: String, completion: @escaping(Bool) -> Void) {
    do {
        let noti = NotificationStruct(notification: NotificationBodyStruct(title: name, text: text, sound: "default"), to: "\(token)", time_to_live: 6000)
        let body = try JSONEncoder().encode(noti)

        makeConnection(body: body) { (success) in
            DispatchQueue.main.async {
                completion(true)
            }
        }
    } catch {
        print("sendNotification \(error.localizedDescription)")
        DispatchQueue.main.async {
            completion(false)
        }
    }
}    



private func makeConnection(body: Data, completion: @escaping(Bool) -> Void) {
    guard let url = URL(string: "http://gcm-http.googleapis.com/gcm/send") else {
            completion(false)
            return
    }

    var request = URLRequest(url: url)
    request.httpMethod = "POST"
    request.allHTTPHeaderFields = ["Content-Type": "application/json", "Authorization": "key=A**YOUR_KEY**A"]
    request.httpBody = body

    let session = URLSession.shared
    let dataTask = session.dataTask(with: request, completionHandler: { (data, response, error) -> Void in
        guard error == nil else {
            print("Error NotificationHelper ", error?.localizedDescription ?? "")
            completion(false)
            return
        }

        guard let httpResponse = response as? HTTPURLResponse else {
            print("httpResponse error NotificationHelper ")
            completion(false)
            return
        }


        guard httpResponse.statusCode  < 500 else {
            print("Error NotificationHelper < 500 \(httpResponse)", response ?? "" )
            completion(false)
            return
        }

        guard (httpResponse.statusCode >= 200 && httpResponse.statusCode <= 299) else {
            print("error NotificationHelper  >= 200 && httpResponse.statusCode <= 299 \(httpResponse)", response ?? "" )
            completion(false)
            return
        }

        guard let _ = data  else {
            print("Problem with Data NotificationHelper ")
            completion(false)
            return
        }

        completion(true)
    })
    dataTask.resume()
}
...