私はアプリを作成し、PushKit Voipを追加しました。私がそれをコンパイルして、Xcodeからすべてうまく走れば、私はプッシュを受け取ることができます。PushKit Voipのテスト方法を教えてください。
しかし、私がTestFlightからインストールした場合、プッシュは行われません。
なぜですか?私は彼らに同じように送る。
私はアプリを作成し、PushKit Voipを追加しました。私がそれをコンパイルして、Xcodeからすべてうまく走れば、私はプッシュを受け取ることができます。PushKit Voipのテスト方法を教えてください。
しかし、私がTestFlightからインストールした場合、プッシュは行われません。
なぜですか?私は彼らに同じように送る。
サイレントプッシュ通知ペイロードを受信すると、サイレントプッシュ通知が通知センターに送信されないため、ローカル通知をスケジュールする必要があります。あなたのローカル通知サウンドファイルの再生(最大30秒)まで、アプリケーションはバックグラウンドまたはキル状態で呼び出されます。ここではアクティビティが必要ですが、UIアクティビティは必要ありません。
インタラクティブローカル通知をタップしている間に、さらなるUIアクティビティを実行できます。
あなたの仕事を達成するために以下の構造を使用してください。
使用
<?php
// Put your device token here (without spaces):
$deviceToken = '123456789';
//
// Put your private key's passphrase here:
$passphrase = 'ProjectName';
// Put your alert message here:
$message = 'My first push notification!';
$ctx = stream_context_create();
stream_context_set_option($ctx, 'ssl', 'local_cert', 'PemFileName.pem');
stream_context_set_option($ctx, 'ssl', 'passphrase', $passphrase);
// Open a connection to the APNS server
$fp = stream_socket_client(
// 'ssl://gateway.push.apple.com:2195', $err,
'ssl://gateway.sandbox.push.apple.com:2195', $err,
$errstr, 60, STREAM_CLIENT_CONNECT|STREAM_CLIENT_PERSISTENT, $ctx);
if (!$fp)
exit("Failed to connect: $err $errstr" . PHP_EOL);
echo 'Connected to APNS' . PHP_EOL;
// Create the payload body
$body['aps'] = array(
'content-available'=> 1,
'alert' => $message,
'sound' => 'default',
'badge' => 0,
);
// Encode the payload as JSON
$payload = json_encode($body);
// Build the binary notification
$msg = chr(0) . pack('n', 32) . pack('H*', $deviceToken) . pack('n', strlen($payload)) . $payload;
// Send it to the server
$result = fwrite($fp, $msg, strlen($msg));
if (!$result)
echo 'Message not delivered' . PHP_EOL;
else
echo 'Message successfully delivered' . PHP_EOL;
// Close the connection to the server
fclose($fp);
使用以下このsimplepush.phpファイルは、場所や火のコマンドをsimplepush.phpに行くPEMファイルを作成し、その後、上記のコード
$ openssl x509 -in aps_development.cer -inform der -out PushCert.pem
# Convert .p12 to .pem. Enter your pass pharse which is the same pwd that you have given while creating the .p12 certificate. PEM pass phrase also same as .p12 cert.
$ openssl pkcs12 -nocerts -out PushKey1.pem -in pushkey.p12
Enter Import Password:
MAC verified OK
Enter PEM pass phrase:
Verifying - Enter PEM pass phrase:
# To remove passpharse for the key to access globally. This only solved my stream_socket_client() & certificate capath warnings.
$ openssl rsa -in PushKey1.pem -out PushKey1_Rmv.pem
Enter pass phrase for PushChatKey1.pem:
writing RSA key
# To join the two .pem file into one file:
$ cat PushCert.pem PushKey1_Rmv.pem > ApnsDev.pem
でそれを使用するコマンド - > php simplepush.php
この方法で、プッシュキットの通知設定アーキテクチャをテストできます。もしあなたのセットアップソケットアーキテクチャ並行してDownload
import UIKit
import PushKit
class AppDelegate: UIResponder, UIApplicationDelegate,PKPushRegistryDelegate{
func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
let types: UIRemoteNotificationType = [.Alert, .Badge, .Sound]
application.registerForRemoteNotificationTypes(types)
self. PushKitRegistration()
return true
}
//MARK: - PushKitRegistration
func PushKitRegistration()
{
let mainQueue = dispatch_get_main_queue()
// Create a push registry object
if #available(iOS 8.0, *) {
let voipRegistry: PKPushRegistry = PKPushRegistry(queue: mainQueue)
// Set the registry's delegate to self
voipRegistry.delegate = self
// Set the push type to VoIP
voipRegistry.desiredPushTypes = [PKPushTypeVoIP]
} else {
// Fallback on earlier versions
}
}
@available(iOS 8.0, *)
func pushRegistry(registry: PKPushRegistry!, didUpdatePushCredentials credentials: PKPushCredentials!, forType type: String!) {
// Register VoIP push token (a property of PKPushCredentials) with server
let hexString : String = UnsafeBufferPointer<UInt8>(start: UnsafePointer(credentials.token.bytes),
count: credentials.token.length).map { String(format: "%02x", $0) }.joinWithSeparator("")
print(hexString)
}
@available(iOS 8.0, *)
func pushRegistry(registry: PKPushRegistry!, didReceiveIncomingPushWithPayload payload: PKPushPayload!, forType type: String!) {
// Process the received push
// From here you have to schedule your local notification
}
}
https://www.raywenderlich.com/123862/push-notifications-tutorial
。その後、ソケットは、ユーザーがオンライン/オフラインでデータをブロードキャストするために使用され、APIを呼び出すことなくソケットを使用することができます。サーバー上のソケットアーキテクチャは、デバイスからの要求を行わずにオンライン/オフラインユーザーのデータをデバイスに送信します。どこかお手伝いできるかどうか教えてください。
幸いなコーディングがあります。
testflightに何も問題ありません。あなたの証明書やPEMファイルに問題があり、一致しないか、testflightでアプリケーションを作るときに正しく設定されていない可能性があります。 – Hasya
@ハシャ、どの証明書が必要なのか、どうすれば適切に入手できるのか教えていただけますか?私はすべてを削除して新しいものを追加するという意味ですか? – user7065798
試しましたか? – Hasya