① 極光推送java服務端怎麼使用

保存離線消息的時長。秒為單位。最多支持10天(864000秒)。
0 表示該消息不保存離線。
即:用戶版在線馬上發出,當前不權在線用戶將不會收到此消息。
此參數不設置則表示默認,默認為保存1天的離線消息(86400秒)。

② 極光推送java sdk怎麼使用

是的,都是一樣的,但是ios需要上傳APNS推送環境APNs證書文件 建議你創建好應用後,直接下載極光的推送demo 另外,你也可以使用網路雲推送,是免費的

③ java極光推送怎麼調用rest api

  1. 先注冊極光帳號

  2. 創建項目

  3. 手機端根據別名、tag等綁定

  4. 調用rest api,這樣手機端才能收到

④ jpush推送java後台怎麼調用

開發的時候需要引用appache的包commons-httpclient.jar 、commons-codec.jar、commons-logging.jar這些包可以到官網上下載,如果有需要的話也我也可以發給你。
引入上述這些包之後,就可以進行開發了。
這里需要特別說明的兩點是:
1、通過 HttpClient client = new DefaultHttpClient(); 獲得HttpClient對象不支持https,需要自己重寫。
2、我們的MD5編碼要和伺服器那邊的一樣。(我用我自己寫的MD5編碼驗證的時候,總是驗證失敗,後來跟他們的技術人員要了他們的md5的實現方式就通過驗證了)

好了,廢話不多說了,接下來是貼代碼的時候了:
類MySSLSocketFactory用來實現對https的支持

[java] view plain
import java.io.IOException;
import java.net.Socket;
import java.net.UnknownHostException;
import java.security.KeyManagementException;
import java.security.KeyStore;
import java.security.KeyStoreException;
import java.security.NoSuchAlgorithmException;
import java.security.UnrecoverableKeyException;
import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;

import javax.net.ssl.SSLContext;
import javax.net.ssl.TrustManager;
import javax.net.ssl.X509TrustManager;

import org.apache.http.conn.ssl.SSLSocketFactory;

public class MySSLSocketFactory extends SSLSocketFactory {

SSLContext sslContext = SSLContext.getInstance("TLS");

public MySSLSocketFactory(KeyStore truststore) throws NoSuchAlgorithmException, KeyManagementException, KeyStoreException, UnrecoverableKeyException {
super(truststore);

TrustManager tm = new X509TrustManager() {
public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {
}

public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {
}

public X509Certificate[] getAcceptedIssuers() {
return null;
}
};

sslContext.init(null, new TrustManager[] { tm }, null);
}

@Override
public Socket createSocket(Socket socket, String host, int port, boolean autoClose) throws IOException, UnknownHostException {
return sslContext.getSocketFactory().createSocket(socket, host, port, autoClose);
}

@Override
public Socket createSocket() throws IOException {
return sslContext.getSocketFactory().createSocket();
}

}

類ClientUtil 獲取可以支持https的HttpClient對象,調用MySSLSocketFactory 來取得

[java] view plain
import java.security.KeyStore;

import org.apache.http.HttpVersion;
import org.apache.http.client.HttpClient;
import org.apache.http.conn.ClientConnectionManager;
import org.apache.http.conn.scheme.PlainSocketFactory;
import org.apache.http.conn.scheme.Scheme;
import org.apache.http.conn.scheme.SchemeRegistry;
import org.apache.http.conn.ssl.SSLSocketFactory;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.impl.conn.tsccm.ThreadSafeClientConnManager;
import org.apache.http.params.BasicHttpParams;
import org.apache.http.params.HttpParams;
import org.apache.http.params.HttpProtocolParams;
import org.apache.http.protocol.HTTP;
public class ClientUtil {

public static HttpClient getNewHttpClient() {
try {
KeyStore trustStore = KeyStore.getInstance(KeyStore.getDefaultType());
trustStore.load(null, null);

SSLSocketFactory sf = new MySSLSocketFactory(trustStore);
sf.setHostnameVerifier(SSLSocketFactory.ALLOW_ALL_HOSTNAME_VERIFIER);

HttpParams params = new BasicHttpParams();
HttpProtocolParams.setVersion(params, HttpVersion.HTTP_1_1);
HttpProtocolParams.setContentCharset(params, HTTP.UTF_8);

SchemeRegistry registry = new SchemeRegistry();
registry.register(new Scheme("http", PlainSocketFactory.getSocketFactory(), 80));
registry.register(new Scheme("https", sf, 443));

ClientConnectionManager ccm = new ThreadSafeClientConnManager(params, registry);

return new DefaultHttpClient(ccm, params);
} catch (Exception e) {
e.printStackTrace();
return new DefaultHttpClient();
}
}

}

接下來就是調用JPush的api來推送消息了

[java] view plain
import java.util.ArrayList;
import java.util.List;

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.message.BasicNameValuePair;
import org.apache.http.util.EntityUtils;

/**
* 調用遠程api實現推送
* @author naiyu
*
*/
public class PushMsgUtil {

// public static final String PUSH_URL = "https://api.jpush.cn:443/sendmsg/sendmsg";
public static final String PUSH_URL = "http://api.jpush.cn:8800/sendmsg/sendmsg";

public static void pushMsg(String msg) {
BasicNameValuePair name = new BasicNameValuePair("username", "test"); //用戶名
BasicNameValuePair sendno = new BasicNameValuePair("sendno", "3621"); // 發送編號。由開發者自己維護,標識一次發送請求
BasicNameValuePair appkeys = new BasicNameValuePair("appkeys", "your appkeys"); // 待發送的應用程序(appKey),只能填一個。
BasicNameValuePair receiver_type = new BasicNameValuePair("receiver_type", "4");
//驗證串,用於校驗發送的合法性。
BasicNameValuePair verification_code = new BasicNameValuePair("verification_code", getVerificationCode());
//發送消息的類型:1 通知 2 自定義
BasicNameValuePair msg_type = new BasicNameValuePair("msg_type", "1");
BasicNameValuePair msg_content = new BasicNameValuePair("msg_content", msg);
//目標用戶終端手機的平台類型,如: android, ios 多個請使用逗號分隔。
BasicNameValuePair platform = new BasicNameValuePair("platform", "android");
List<BasicNameValuePair> datas = new ArrayList<BasicNameValuePair>();
datas.add(name);
datas.add(sendno);
datas.add(appkeys);
datas.add(receiver_type);
datas.add(verification_code);
datas.add(msg_type);
datas.add(msg_content);
datas.add(platform);
try {
HttpEntity entity = new UrlEncodedFormEntity(datas, "utf-8");
HttpPost post = new HttpPost(PUSH_URL);
post.setEntity(entity);
HttpClient client = ClientUtil.getNewHttpClient();
HttpResponse reponse = client.execute(post);
HttpEntity resEntity = reponse.getEntity();
System.out.println(EntityUtils.toString(resEntity));
} catch (Exception ex) {
ex.printStackTrace();
}

}

private static String getVerificationCode() {

String username = "test"; //username 是開發者Portal帳戶的登錄帳戶名
String password = "pasword";
int sendno = 3621;
int receiverType = 4;
String md5Password = StringUtils.toMD5(password);; //password 是開發者Portal帳戶的登錄密碼

String input = username + sendno + receiverType + md5Password;
String verificationCode = StringUtils.toMD5(input);
return verificationCode;
}

public static void main(String[] args) {
String msg = "{\"n_title\":\"來點外賣\",\"n_content\":\"你好\"}";
System.out.println(msg);
PushMsgUtil.pushMsg(msg);
}

}

⑤ java極光推送報Authentication failed! Please check authentication params according to docs怎麼解決

錯誤信息已經說明,你的簽名有問題

⑥ java極光推送andriod報For any platform notification, alert field is needed. It canbe empty string

錯誤信息都告訴你了,你少了一個欄位

⑦ 極光推送java服務端完成後怎麼發送消息

setEnableSSL boolean enableSSL (true為使用復制ssl, 默認為不使用ssl) 是否啟動ssl安全連接

sendNotificationWithImei
int sendNo(發送編號),
String imei (IMEI字元串) ,
String msgTitle (消息標題/通知標題) ,
String msgContent (消息內容/通知內容) 發送帶IMEI的通知

sendNotificationWithImei int sendNo ,
String imei ,
String msgTitle ,
String msgContent ,
int builderId (自定義通知欄樣式Id) ,
Map<String, Object>extra (附屬信息) 自定義通知欄(沒有則填寫0)
以及傳遞附屬信息

sendCustomMessageWithImei
int sendNo ,
String imei ,
String msgTitle ,
String msgConte

⑧ java後台極光推送最新版 ios 怎麼指定證書環境

創建應用程序ID
登陸 iOS Dev Center 選擇進入iOS Provisioning Portal。
在 iOS Provisioning Portal中,點擊App IDs進入App ID列表。

創建 App ID,如果 ID 已經存在可以直接跳過此步驟

為 App 開啟 Push Notification 功能。如果是已經創建的 App ID 也可以通過設置開啟 Push Notification 功能。

根據實際情況完善 App ID 信息並提交,注意此處需要指定具體的 Bundle ID 不要使用通配符。

配置和下載證書
如果你之前沒有創建過 Push 證書或者是要重新創建一個新的,請在證書列表下面新建。

新建證書需要注意選擇證書種類(開發證書用於開發和調試使用,生產證書用於 App Store 發布)

點擊 Continue 後選擇證書對應的應用ID,然後繼續會出現「About Creating a Certificate Signing Request (CSR)」。

根據它的說明創建打開KeychainAccess 創建 Certificate Signing Request。

填寫「User Email Address」和「Common Name」 後選擇 Saved to disk 進行保存 。

繼續返回Apple developer 網站點擊 Continue ,上傳剛剛生成的 .certSigningRequest 文件生成 APNs Push Certificate。
下載並雙擊打開證書,證書打開時會啟動「鑰匙串訪問」工具。
在「鑰匙串訪問」中你的證書會顯示在「我的證書」中,注意選擇「My Certificates」 和"login"

導出 .p12 證書文件
在「鑰匙串訪問」中,選擇剛剛加進來的證書,選擇右鍵菜單中的「導出「...」」。

注意要選「login」和「My Certificates」 導出證書時要選中證書文件,不要展開private key。

將文件保存為Personal Information Exchange (.p12)格式。

保存p12文件時,可以為其設置密碼,也可以讓密碼為空。
上傳證書
在 JPush 管理 Portal 上,針對某應用程序,上傳上面步驟得到 .p12 證書文件。這是 iOS SDK 能夠接收到 JPush 推送消息的必要步驟。

⑨ java極光推送怎麼調用自定義消息介面

// 對android和ios設備發送復
JPushClient jpush = new JPushClient(masterSecret, appKey);

// 對android和ios設備發制送,同時指定離線消息保存時間
JPushClient jpush = new JPushClient(masterSecret, appKey, timeToLive);

// 指定某種設備發送
JPushClient jpush = new JPushClient(masterSecret, appKey, DeviceEnum.Android);

// 指定某種設備發送,並且指定離線消息保存時間
JPushClient jpush = new JPushClient(masterSecret, appKey, timeToLive, DeviceEnum.IOS);