php實現簡單消息發送+極光推送系統

前幾天剛寫完的一個東西,寫的比較簡單,沒有使用其餘插件,原生php+計劃任務實現php

極光推送的代碼android

 

/*
  $receiver="registration_id" : [ "4312kjklfds2", "8914afd2", "45fdsa31" ];
  $receiver="tag" : [ "深圳", "廣州", "北京" ]
  $receiver=  "tag" : [ "深圳", "廣州" ]
  $receiver= "tag_and" : [ "女", "會員"]
  //自定義類型推送類型

  $m_type = 'http';//推送附加字段的類型
  $m_txt = 'http://www.groex.cn/';//推送附加字段的類型對應的內容(可不填) 多是url,多是一段文字。
  $m_time = '86400';//離線保留時間
 *
 * { "platform" : "all" }
 *
 * { "platform" : ["android", "ios"] }
 *  測試成不成功記得看管理平臺上面的統計信息,由於以前把apns_production參數設置成了生產環境,調用接口成功,但是卻沒有用戶,後來改成了開發環境,就成功了。
 */

function jiguang_send($receive, $content, $platform, $m_type, $m_txt, $m_time) {

    $appkey = ''; //AppKey
    $secret = ''; //Secret

    $postUrl = "https://api.jpush.cn/v3/push";

    $base64 = base64_encode("$appkey:$secret");
    $header = array("Authorization:Basic $base64", "Content-Type:application/json");
    $data = array();
    $data['platform'] = $platform;          //目標用戶終端手機的平臺類型android,ios,winphone
    $data['audience'] = $receive;      //目標用戶

    $data['notification'] = array(
        //統一的模式--標準模式
        "alert" => $content,
        //安卓自定義
        "android" => array(
            "alert" => $content,
            "title" => "",
            "builder_id" => 1,
            "extras" => array("type" => $m_type, "txt" => $m_txt)
        ),
        //ios的自定義
        "ios" => array(
            "alert" => $content,
            "badge" => "1",
            "sound" => "default",
            "extras" => array("type" => $m_type, "txt" => $m_txt)
        )
    );

    //蘋果自定義---爲了彈出值方便調測
    $data['message'] = array(
        "msg_content" => $content,
        "extras" => array("type" => $m_type, "txt" => $m_txt)
    );

    //附加選項
    $data['options'] = array(
        "sendno" => time(),
        "time_to_live" => $m_time, //保存離線時間的秒數默認爲一天
        "apns_production" => false, //布爾類型   指定 APNS 通知發送環境:0開發環境,1生產環境。或者傳遞false和true
    );
    $param = json_encode($data);
//    $postUrl = $this->url;
    $curlPost = $param;

    $ch = curl_init();                                      //初始化curl
    curl_setopt($ch, CURLOPT_URL, $postUrl);                 //抓取指定網頁
    curl_setopt($ch, CURLOPT_HEADER, 0);                    //設置header
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);            //要求結果爲字符串且輸出到屏幕上
    curl_setopt($ch, CURLOPT_POST, 1);                      //post提交方式
    curl_setopt($ch, CURLOPT_POSTFIELDS, $curlPost);
    curl_setopt($ch, CURLOPT_HTTPHEADER, $header);           // 增長 HTTP Header(頭)裏的字段
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);        // 終止從服務端進行驗證
    curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
    $return_data = curl_exec($ch);                                 //運行curl
    curl_close($ch);

    return $return_data;
}

由於後面發現極光推送能夠自定義分類推送消息,其餘我也沒看明白,我本身就根據用戶的性別,座標,gps返回的城市本身去查詢極光返回的id
去推送,結果發現對於app開發和php後臺開發來講都容易的多

app開發只須要對接基本的sdk就能夠了



消息系統設計,這裏混合了極光推送的任務表

主表
CREATE TABLE `v1_jiguang_user_data` (
  `jg_id` int(10) NOT NULL AUTO_INCREMENT,
  `jiguang_id` varchar(200) CHARACTER SET utf8 NOT NULL,
  `user_id` int(10) NOT NULL,
  `app_type` varchar(200) CHARACTER SET utf8 NOT NULL,
  `is_sent` int(2) NOT NULL DEFAULT '1' COMMENT '斷定是都接受app推送,默認1是推送 2是不推送',
  `time` int(11) NOT NULL COMMENT '登陸時間',
  `user_sex` int(2) DEFAULT NULL COMMENT '性別 1爲男 0爲女',
  `longitude` varchar(30) CHARACTER SET utf8 DEFAULT NULL COMMENT '經度',
  `latitude` varchar(30) CHARACTER SET utf8 DEFAULT NULL COMMENT '緯度',
  `region_tag` varchar(40) CHARACTER SET utf8 DEFAULT NULL COMMENT '地區tag',
  PRIMARY KEY (`jg_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
 
 

 



從表

CREATE TABLE `v1_push_message_history` (
`push_message_history_id` int(10) NOT NULL AUTO_INCREMENT,
`user_id` int(10) NOT NULL COMMENT '操做用戶',
`content` text CHARACTER SET utf8 COMMENT '推送內容',
`receiver` text CHARACTER SET utf8 COMMENT 'receiver消息標識',
`platform` text CHARACTER SET utf8 COMMENT '推送平臺',
`msg_type` int(10) DEFAULT '1' COMMENT '消息類型 1 系統消息 2活動消息 3還款提醒 ',
`time` int(11) DEFAULT NULL COMMENT '發佈時間',
PRIMARY KEY (`push_message_history_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;ios



任務表

CREATE TABLE `v1_message_task` (
`task_id` int(10) NOT NULL AUTO_INCREMENT,
`task_type` varchar(100) CHARACTER SET utf8 NOT NULL COMMENT '任務類型',
`message_content` varchar(400) CHARACTER SET utf8 NOT NULL COMMENT '信息內容',
`user_id` int(10) NOT NULL COMMENT '信貸員ID',
`time` int(11) NOT NULL COMMENT '執行時間',
PRIMARY KEY (`task_id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1git

 

而後在crontab裏面執行就能夠了,查詢的時候只須要根據v1_jiguang_user_data的男,女,地區來查詢,推送給執行用戶,否則就所有發送,直接把json

$receiver="registration_id" : [ "4312kjklfds2", "8914afd2", "45fdsa31" ];這樣發送就Ok了
相關文章
相關標籤/搜索