極光推送java代碼示例(java集成極光推送)

本文目錄一覽:

如何利用Java語言實現消息推送到手機app

首先APP後台就得有這樣的輪詢程序,比如每次打開app時觸發,比如每隔10分鐘觸發,每次觸發就調用下服務器端的服務,服務端去拉取要推送的信息,或者知道對方的手機號或微信號,那就直接調用短信接口或直接發送微信信息了。

極光推送服務是一款免費的第三方推送消息的平台。極光推送從整體來說還不錯,具有以下優勢:

1、開放註冊,免費向所有的開發者開放使用。

2、極光推送 – JPush SDK

JPush 是經過考驗的大規模 App 推送平台,每天推送消息量級為數百億條。 開發者集成 SDK 後,可以通過調用 API 推送消息。同時,JPush 提供可視化的 web 端控制台發送通知,統計分析推送效果。

3、開發者可以輕鬆地通過極光發送各個移動平台的系統通知,還可以在控制台編輯多種富文本展示模板; 極光還提供自定義消息的透傳,客戶端接到消息內容後根據自己的邏輯自由處理。

4、7*24小時專人專線服務:專屬安全團隊支持,24 小時隨時響應,免除後顧之憂。

極光是一個不錯的選擇,深圳市和訊華谷信息技術有限公司(極光 Aurora Mobile,納斯達克股票代碼:JG)成立於2011年,是中國領先的開發者服務提供商,專註於為開發者提供穩定高效的消息推送、一鍵認證以及流量變現等服務,助力開發者的運營、增長與變現。

同時,極光的行業應用已經拓展至市場洞察、金融風控與商業地理服務,助力各行各業優化決策、提升效率。

push message (短消息推送) 技術Java怎麼實現,有沒有大神可以講解一下

push message (短消息推送) 技術Java怎麼實現步驟如下:

1、手機客戶端client1發送一條“msg1”的文本消息到服務器;

2、服務器收到來自client1的“msg1”消息後,把它add進messageList裡面;

3、服務器檢測到messageList裡面含有消息(開啟服務器時就新建里一個檢測messageList的線程,線程裡面有一個死循環,用於不停檢測messageList是否含有消息);

4、服務器讀取消息數據,如讀取到來自client1發給client2的消息“msg1”,那麼服務器就把“msg1”推送到client2上;

5、client2檢測到服務器推送的消息,做出相應的操作(如:震動、鈴聲、顯示消息等);

6、client2接收到來自服務器推送的“msg1”消息後,client2也回復一條文本消息“msg2”給client1,此過程和client1發送消息給client2一樣。

7、最後,client2就可以顯示來自client1發送的消息“msg1”,而client1則可以顯示來自client2的回復消息“msg2”

短消息推送使用極光推送更方便。正確的使用好推送,活躍度的提升十分明顯是工具類。極光個性化推送滿足用戶多種推送需要,有效提升用戶體驗,利用大數據人工智能技術,實現智能用戶分群,提升消息點擊率,推送安全包確保推送內容準確,拒絕運營事故。

java如何推送消息給前端

Java服務器推送消息給前端主要方法:

Java有兩個接口:

1、”/subscribe”接口:用於消息訂閱,該接口有一個參數topic,即訂閱的消息主題。

2、”/publish”接口:發布消息接口,有兩個參數,topic是發布消息主題,content是發布消息內容。

用戶還可考慮使用用極光推送,JPush 提供四種消息形式:通知,自定義消息,富媒體和本地通知。

1、通知,或者說 Push Notification,即指在手機的通知欄(狀態欄)上會顯示的一條通知信息。 通知主要用來達到提示用戶的目的,應用於新聞內容、促銷活動、產品信息、版本更新提醒、訂單狀態提醒等多種場景;

2、自定義消息:自定義消息不是通知,所以不會被 SDK 展示到通知欄上。其內容完全由開發者自己定義。 自定義消息主要用於應用的內部業務邏輯。一條自定義消息推送過來,有可能沒有任何界面顯示。

3、富媒體:JPush 支持開發者發送圖文並茂的通知,從而更好的傳達信息,帶來更豐富的用戶互動。 JPush 提供了 5 種模板,開發者可以通過填充模板的內容,發送 landing page、彈窗、信息流形式的富媒體通知。 開發者還可以直接通過 URL 發送預先編輯好的頁面。

4、本地通知:本地通知 API 不依賴於網絡,無網條件下依舊可以觸發;本地通知的定時時間是自發送時算起的,不受中間關機等操作的影響。 本地通知與網絡推送的通知是相互獨立的,不受保留最近通知條數上限的限制。

極光推送還可以通過使用標籤,別名,Registration ID 和用戶分群,開發者可以向特定的一個或多個用戶推送消息。

java消息推送,一個實時數據的web顯示該怎麼做

javaweb消息實時推送可以使用極光平台進行實現。具體操作如下:

1、首先先到到極光官網上註冊一個賬號,並創建一個應用;

2、前台進行實時訂閱及接收;

3、前台進行實時推送;

4、後台也進行實時推送;

5、極光的實現原理很簡單,就是推送消息的一端只負責推送,而需要接收的頁面需要預先訂閱。

消息推送軟件,選擇極光是個不錯的選擇,而且安全性和穩定性都不錯。極光作為合作夥伴,體現了以映客為代表的頭部互動娛樂及社交平台對極光服務能力的認可及技術實力的信賴。

極光將始終堅持“助力開發者運營、增長和變現,邁向成功”的使命,還用更專業、高效、安全、穩定、智能的開發者服務及出色的機器學習數據分析能力,為更多合作夥伴的智能化用戶運營“錦上添花”。

jpush推送java後台怎麼調用

原創作品,可以轉載,但是請標註出處地址

Java後台實現極光推送有兩種方式,一種是使用極光推送官方提供的推送請求API:,另一種則是使用官方提供的第三方Java SDK,這裡先進行第一種方式推送的實現代碼:

import org.apache.http.HttpResponse;

import org.apache.http.client.HttpClient;

import org.apache.http.client.methods.HttpPost;

import org.apache.http.entity.StringEntity;

import org.apache.http.impl.client.DefaultHttpClient;

import org.apache.http.util.EntityUtils;

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

import com.alibaba.fastjson.JSONArray;

import net.sf.json.JSONObject;

import sun.misc.BASE64Encoder;

/**

 * java後台極光推送方式一:使用Http API

 * 此種方式需要自定義http請求發送客戶端:HttpClient 

*/

@SuppressWarnings({ “deprecation”, “restriction” })

public class JiguangPush {

    private static final Logger log = LoggerFactory.getLogger(JiguangPush.class);

    private String masterSecret = “xxxxxxxxxxxxxxxxxxxx”;

    private String appKey = “xxxxxxxxxxxxxxxxxxx”;

    private String pushUrl = “”;    

    private boolean apns_production = true;    

    private int time_to_live = 86400;

    private static final String ALERT = “推送信息”;    

    /**

     * 極光推送

     */

    public void jiguangPush(){

        String alias = “123456”;//聲明別名

        try{

            String result = push(pushUrl,alias,ALERT,appKey,masterSecret,apns_production,time_to_live);

            JSONObject resData = JSONObject.fromObject(result);

                if(resData.containsKey(“error”)){

                    log.info(“針對別名為” + alias + “的信息推送失敗!”);

                    JSONObject error = JSONObject.fromObject(resData.get(“error”));

                    log.info(“錯誤信息為:” + error.get(“message”).toString());

                }

            log.info(“針對別名為” + alias + “的信息推送成功!”);

        }catch(Exception e){

            log.error(“針對別名為” + alias + “的信息推送失敗!”,e);

        }

    }

    

    /**

     * 組裝極光推送專用json串

     * @param alias

     * @param alert

     * @return json

     */

    public static JSONObject generateJson(String alias,String alert,boolean apns_production,int time_to_live){

        JSONObject json = new JSONObject();

        JSONArray platform = new JSONArray();//平台

        platform.add(“android”);

        platform.add(“ios”);

        

        JSONObject audience = new JSONObject();//推送目標

        JSONArray alias1 = new JSONArray();

        alias1.add(alias);

        audience.put(“alias”, alias1);

        

        JSONObject notification = new JSONObject();//通知內容

        JSONObject android = new JSONObject();//android通知內容

        android.put(“alert”, alert);

        android.put(“builder_id”, 1);

        JSONObject android_extras = new JSONObject();//android額外參數

        android_extras.put(“type”, “infomation”);

        android.put(“extras”, android_extras);

        

        JSONObject ios = new JSONObject();//ios通知內容

        ios.put(“alert”, alert);

        ios.put(“sound”, “default”);

        ios.put(“badge”, “+1”);

        JSONObject ios_extras = new JSONObject();//ios額外參數

        ios_extras.put(“type”, “infomation”);

        ios.put(“extras”, ios_extras);

        notification.put(“android”, android);

        notification.put(“ios”, ios);

        

        JSONObject options = new JSONObject();//設置參數

        options.put(“time_to_live”, Integer.valueOf(time_to_live));

        options.put(“apns_production”, apns_production);

        

        json.put(“platform”, platform);

        json.put(“audience”, audience);

        json.put(“notification”, notification);

        json.put(“options”, options);

        return json;

        

    }

    

    /**

     * 推送方法-調用極光API

     * @param reqUrl

     * @param alias

     * @param alert

     * @return result

     */

    public static String push(String reqUrl,String alias,String alert,String appKey,String masterSecret,boolean apns_production,int time_to_live){

        String base64_auth_string = encryptBASE64(appKey + “:” + masterSecret);

        String authorization = “Basic ” + base64_auth_string;

        return sendPostRequest(reqUrl,generateJson(alias,alert,apns_production,time_to_live).toString(),”UTF-8″,authorization);

    }

    

    /**

     * 發送Post請求(json格式)

     * @param reqURL

     * @param data

     * @param encodeCharset

     * @param authorization

     * @return result

     */

    @SuppressWarnings({ “resource” })

    public static String sendPostRequest(String reqURL, String data, String encodeCharset,String authorization){

        HttpPost httpPost = new HttpPost(reqURL);

        HttpClient client = new DefaultHttpClient();

        HttpResponse response = null;

        String result = “”;

        try {

             StringEntity entity = new StringEntity(data, encodeCharset);

             entity.setContentType(“application/json”);

             httpPost.setEntity(entity);

             httpPost.setHeader(“Authorization”,authorization.trim());

             response = client.execute(httpPost);

             result = EntityUtils.toString(response.getEntity(), encodeCharset);

        } catch (Exception e) {

            log.error(“請求通信[” + reqURL + “]時偶遇異常,堆棧軌跡如下”, e);  

        }finally{

            client.getConnectionManager().shutdown();

        }

        return result;

    }

     /** 

* BASE64加密工具

*/

     public static String encryptBASE64(String str) {

         byte[] key = str.getBytes();

       BASE64Encoder base64Encoder = new BASE64Encoder();

       String strs = base64Encoder.encodeBuffer(key);

         return strs;

     }

}

以上代碼中使用的是第一種方式實現推送,下面介紹第二種方式:使用java SDK

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

import cn.jiguang.common.ClientConfig;

import cn.jiguang.common.resp.APIConnectionException;

import cn.jiguang.common.resp.APIRequestException;

import cn.jpush.api.JPushClient;

import cn.jpush.api.push.PushResult;

import cn.jpush.api.push.model.Options;

import cn.jpush.api.push.model.Platform;

import cn.jpush.api.push.model.PushPayload;

import cn.jpush.api.push.model.audience.Audience;

import cn.jpush.api.push.model.notification.AndroidNotification;

import cn.jpush.api.push.model.notification.IosNotification;

import cn.jpush.api.push.model.notification.Notification;

/**

 * java後台極光推送方式二:使用Java SDK

 */

@SuppressWarnings({ “deprecation”, “restriction” })

public class JiguangPush {

    private static final Logger log = LoggerFactory.getLogger(JiguangPush.class);

    private static String masterSecret = “xxxxxxxxxxxxxxxxx”;

    private static String appKey = “xxxxxxxxxxxxxxxx”;

    private static final String ALERT = “推送信息”;    

    /**

     * 極光推送

     */

    public void jiguangPush(){

        String alias = “123456”;//聲明別名

        log.info(“對別名” + alias + “的用戶推送信息”);

        PushResult result = push(String.valueOf(alias),ALERT);

        if(result != null  result.isResultOK()){

            log.info(“針對別名” + alias + “的信息推送成功!”);

        }else{

            log.info(“針對別名” + alias + “的信息推送失敗!”);

        }

    }

    

    /**

     * 生成極光推送對象PushPayload(採用java SDK)

     * @param alias

     * @param alert

     * @return PushPayload

     */

    public static PushPayload buildPushObject_android_ios_alias_alert(String alias,String alert){

        return PushPayload.newBuilder()

                .setPlatform(Platform.android_ios())

                .setAudience(Audience.alias(alias))

                .setNotification(Notification.newBuilder()

                        .addPlatformNotification(AndroidNotification.newBuilder()

                                .addExtra(“type”, “infomation”)

                                .setAlert(alert)

                                .build())

                        .addPlatformNotification(IosNotification.newBuilder()

                                .addExtra(“type”, “infomation”)

                                .setAlert(alert)

                                .build())

                        .build())

                .setOptions(Options.newBuilder()

                        .setApnsProduction(false)//true-推送生產環境 false-推送開發環境(測試使用參數)

                        .setTimeToLive(90)//消息在JPush服務器的失效時間(測試使用參數)

                        .build())

                .build();

    }

    /**

     * 極光推送方法(採用java SDK)

     * @param alias

     * @param alert

     * @return PushResult

     */

    public static PushResult push(String alias,String alert){

        ClientConfig clientConfig = ClientConfig.getInstance();

        JPushClient jpushClient = new JPushClient(masterSecret, appKey, null, clientConfig);

        PushPayload payload = buildPushObject_android_ios_alias_alert(alias,alert);

        try {

            return jpushClient.sendPush(payload);

        } catch (APIConnectionException e) {

            log.error(“Connection error. Should retry later. “, e);

            return null;

        } catch (APIRequestException e) {

            log.error(“Error response from JPush server. Should review and fix it. “, e);

            log.info(“HTTP Status: ” + e.getStatus());

            log.info(“Error Code: ” + e.getErrorCode());

            log.info(“Error Message: ” + e.getErrorMessage());

            log.info(“Msg ID: ” + e.getMsgId());

            return null;

        }    

    }

}

可以看出使用Java SDK實現推送的方式很簡單,代碼量也少,理解起來也不難,官方提供的SDK中講很多內容都實現了,我們只是需要配置一下信息,然後發起推送即可。需要注意的是使用第二種方式,需要導入極光官網提供的jar包。

直接在maven中的pom文件中加入:

dependency

    groupIdcn.jpush.api/groupId

    artifactIdjpush-client/artifactId

    version3.2.15/version

/dependency

注意:在這裡極有可能會出現jar包衝突:具體哪個包我也忘記了,好像是個日誌包,你找到後刪除即可。

原本我們項目中也是採用第二種方式實現的,但是最後在提交代碼時發現一個問題,那就是雖然我們只是帶入了官網提供的那三個jar包,但是最後一統計,竟然無緣無故增多了80+個jar包,如此多的jar包提交過於臃腫,而且不現實,所以才臨時改變方案,採用第一種方式進行編碼。

代碼中採用的是別名方式進行推送,需要在在手機APP端進行別名設置,最好就是在用戶登錄之後就設置好,這樣只要用戶登錄一次,它的綁定別名就可以保存到極光服務器,而我們推送時,指定這個別名,就能將信息推送到對應用戶的手機上。

其實我們發起推送請求,只是將信息發送到了極光服務器之上,這個信息有一個保存時限,默認一天,只要用戶登錄手機APP,極光服務器就會將信息自動推送到對應別名的手機上,由此可見,信息並非由我們後天直接推送到手機,而是通過極光服務器這個中轉站,而這正式極光的工作。

注意:這裡告知一個技巧,這個別名設置的時候,其實直接將用戶ID設置為別名即可,既方便,又安全,不用再去想辦法生成一個唯一的串來進行標識,甚至需要在後台數據庫中用戶表中新增字段。

原創文章,作者:EZ40V,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/127895.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
EZ40V的頭像EZ40V
上一篇 2024-10-03 23:16
下一篇 2024-10-03 23:16

相關推薦

  • Python周杰倫代碼用法介紹

    本文將從多個方面對Python周杰倫代碼進行詳細的闡述。 一、代碼介紹 from urllib.request import urlopen from bs4 import Bea…

    編程 2025-04-29
  • Java JsonPath 效率優化指南

    本篇文章將深入探討Java JsonPath的效率問題,並提供一些優化方案。 一、JsonPath 簡介 JsonPath是一個可用於從JSON數據中獲取信息的庫。它提供了一種DS…

    編程 2025-04-29
  • java client.getacsresponse 編譯報錯解決方法

    java client.getacsresponse 編譯報錯是Java編程過程中常見的錯誤,常見的原因是代碼的語法錯誤、類庫依賴問題和編譯環境的配置問題。下面將從多個方面進行分析…

    編程 2025-04-29
  • Java Bean加載過程

    Java Bean加載過程涉及到類加載器、反射機制和Java虛擬機的執行過程。在本文中,將從這三個方面詳細闡述Java Bean加載的過程。 一、類加載器 類加載器是Java虛擬機…

    編程 2025-04-29
  • Java騰訊雲音視頻對接

    本文旨在從多個方面詳細闡述Java騰訊雲音視頻對接,提供完整的代碼示例。 一、騰訊雲音視頻介紹 騰訊雲音視頻服務(Cloud Tencent Real-Time Communica…

    編程 2025-04-29
  • Python字符串寬度不限制怎麼打代碼

    本文將為大家詳細介紹Python字符串寬度不限制時如何打代碼的幾個方面。 一、保持代碼風格的統一 在Python字符串寬度不限制的情況下,我們可以寫出很長很長的一行代碼。但是,為了…

    編程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介紹

    本文將詳細介紹Java Milvus SearchParam withoutFields的相關知識和用法。 一、什麼是Java Milvus SearchParam without…

    編程 2025-04-29
  • Python基礎代碼用法介紹

    本文將從多個方面對Python基礎代碼進行解析和詳細闡述,力求讓讀者深刻理解Python基礎代碼。通過本文的學習,相信大家對Python的學習和應用會更加輕鬆和高效。 一、變量和數…

    編程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java語言中的一個版本,於2014年3月18日發布。本文將從多個方面對Java 8中某一周的周一進行詳細的闡述。 一、數組處理 Java 8新特性之一是Stream…

    編程 2025-04-29
  • Java判斷字符串是否存在多個

    本文將從以下幾個方面詳細闡述如何使用Java判斷一個字符串中是否存在多個指定字符: 一、字符串遍歷 字符串是Java編程中非常重要的一種數據類型。要判斷字符串中是否存在多個指定字符…

    編程 2025-04-29

發表回復

登錄後才能評論