- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在从我的服务器端应用程序发送 GCM 推送通知,它显示成功,但我没有在我的设备上收到这些消息。我的 Google api key 和 Reg id 也是正确的,我在这里发布我的 android 代码。请检查并指出我在这段代码中做错了什么。
AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.gcm.cuser.gcmnotification" >
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.GET_ACCOUNTS" />
<uses-permission android:name="com.google.android.providers.gsf.permission.READ_GSERVICES" />
<uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" />
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name=".MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity
android:name=".HomeActivity"
android:label="@string/title_activity_home" >
</activity>
<receiver
android:name=".GcmBroadcastReceiver"
android:permission="com.google.android.c2dm.permission.SEND" >
<intent-filter>
<action android:name="com.google.android.c2dm.intent.RECEIVE" />
<!-- <action android:name="com.google.android.c2dm.intent.REGISTRATION" /> -->
<category android:name="@string/app_name" />
</intent-filter>
</receiver>
</application>
</manifest>
主 Activity .java
package com.gcm.cuser.gcmnotification;
import java.io.IOException;
import android.app.Activity;
import android.app.ProgressDialog;
import android.content.Context;
import android.content.Intent;
import android.content.SharedPreferences;
import android.os.AsyncTask;
import android.os.Bundle;
import android.text.TextUtils;
import android.util.Log;
import android.view.View;
import android.widget.EditText;
import android.widget.Toast;
import com.google.android.gms.common.ConnectionResult;
import com.google.android.gms.common.GooglePlayServicesUtil;
import com.google.android.gms.gcm.GoogleCloudMessaging;
import com.loopj.android.http.AsyncHttpClient;
import com.loopj.android.http.AsyncHttpResponseHandler;
import com.loopj.android.http.RequestParams;
public class MainActivity extends Activity {
ProgressDialog prgDialog;
RequestParams params = new RequestParams();
GoogleCloudMessaging gcmObj;
Context applicationContext;
String regId = "";
private final static int PLAY_SERVICES_RESOLUTION_REQUEST = 9000;
AsyncTask<Void, Void, String> createRegIdTask;
public static final String REG_ID = "regId";
public static final String EMAIL_ID = "eMailId";
EditText emailET;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
applicationContext = getApplicationContext();
emailET = (EditText) findViewById(R.id.email);
prgDialog = new ProgressDialog(this);
// Set Progress Dialog Text
prgDialog.setMessage("Please wait...");
// Set Cancelable as False
prgDialog.setCancelable(false);
SharedPreferences prefs = getSharedPreferences("UserDetails",
Context.MODE_PRIVATE);
String registrationId = prefs.getString(REG_ID, "");
//When Email ID is set in Sharedpref, User will be taken to HomeActivity
if (!TextUtils.isEmpty(registrationId)) {
Intent i = new Intent(applicationContext, HomeActivity.class);
i.putExtra("regId", registrationId);
startActivity(i);
finish();
}
}
// When Register Me button is clicked
public void RegisterUser(View view) {
String emailID = emailET.getText().toString();
if (!TextUtils.isEmpty(emailID) && Utility.validate(emailID)) {
// Check if Google Play Service is installed in Device
// Play services is needed to handle GCM stuffs
if (checkPlayServices()) {
// Register Device in GCM Server
registerInBackground(emailID);
}
}
// When Email is invalid
else {
Toast.makeText(applicationContext, "Please enter valid email",
Toast.LENGTH_LONG).show();
}
}
// AsyncTask to register Device in GCM Server
private void registerInBackground(final String emailID) {
new AsyncTask<Void, Void, String>() {
@Override
protected String doInBackground(Void... params) {
String msg = "";
try {
if (gcmObj == null) {
gcmObj = GoogleCloudMessaging
.getInstance(applicationContext);
}
regId = gcmObj
.register(ApplicationConstants.GOOGLE_PROJ_ID);
msg = "Registration ID :" + regId;
Log.d("msg1", msg);
} catch (IOException ex) {
msg = "Error :" + ex.getMessage();
}
return msg;
}
@Override
protected void onPostExecute(String msg) {
if (!TextUtils.isEmpty(regId)) {
// Store RegId created by GCM Server in SharedPref
storeRegIdinSharedPref(applicationContext, regId, emailID);
Toast.makeText(
applicationContext,
"Registered with GCM Server successfully.\n\n"
+ msg, Toast.LENGTH_SHORT).show();
} else {
Toast.makeText(
applicationContext,
"Reg ID Creation Failed.\n\nEither you haven't enabled Internet or GCM server is busy right now. Make sure you enabled Internet and try registering again after some time."
+ msg, Toast.LENGTH_LONG).show();
}
}
}.execute(null, null, null);
}
// Store RegId and Email entered by User in SharedPref
private void storeRegIdinSharedPref(Context context, String regId,
String emailID) {
SharedPreferences prefs = getSharedPreferences("UserDetails",
Context.MODE_PRIVATE);
SharedPreferences.Editor editor = prefs.edit();
editor.putString(REG_ID, regId);
editor.putString(EMAIL_ID, emailID);
editor.commit();
storeRegIdinServer();
}
// Share RegID with GCM Server Application (Php)
private void storeRegIdinServer() {
prgDialog.show();
params.put("regId", regId);
// Make RESTful webservice call using AsyncHttpClient object
AsyncHttpClient client = new AsyncHttpClient();
client.post(ApplicationConstants.APP_SERVER_URL, params,
new AsyncHttpResponseHandler() {
// When the response returned by REST has Http
// response code '200'
public void onSuccess(String response) {
// Hide Progress Dialog
prgDialog.hide();
if (prgDialog != null) {
prgDialog.dismiss();
}
Toast.makeText(applicationContext,
"Reg Id shared successfully with Web App ",
Toast.LENGTH_LONG).show();
Intent i = new Intent(applicationContext,
HomeActivity.class);
i.putExtra("regId", regId);
startActivity(i);
finish();
}
// When the response returned by REST has Http
// response code other than '200' such as '404',
// '500' or '403' etc
public void onFailure(int statusCode, Throwable error,
String content) {
// Hide Progress Dialog
prgDialog.hide();
if (prgDialog != null) {
prgDialog.dismiss();
}
// When Http response code is '404'
if (statusCode == 404) {
Toast.makeText(applicationContext,
"Requested resource not found",
Toast.LENGTH_LONG).show();
}
// When Http response code is '500'
else if (statusCode == 500) {
Toast.makeText(applicationContext,
"Something went wrong at server end",
Toast.LENGTH_LONG).show();
}
// When Http response code other than 404, 500
else {
Toast.makeText(
applicationContext,
"Unexpected Error occcured! [Most common Error: Device might "
+ "not be connected to Internet or remote server is not up and running], check for other errors as well",
Toast.LENGTH_LONG).show();
}
}
});
}
// Check if Google Playservices is installed in Device or not
private boolean checkPlayServices() {
int resultCode = GooglePlayServicesUtil
.isGooglePlayServicesAvailable(this);
// When Play services not found in device
if (resultCode != ConnectionResult.SUCCESS) {
if (GooglePlayServicesUtil.isUserRecoverableError(resultCode)) {
// Show Error dialog to install Play services
GooglePlayServicesUtil.getErrorDialog(resultCode, this,
PLAY_SERVICES_RESOLUTION_REQUEST).show();
} else {
Toast.makeText(
applicationContext,
"This device doesn't support Play services, App will not work normally",
Toast.LENGTH_LONG).show();
finish();
}
return false;
} else {
Toast.makeText(
applicationContext,
"This device supports Play services, App will work normally",
Toast.LENGTH_LONG).show();
}
return true;
}
// When Application is resumed, check for Play services support to make sure app will be running normally
@Override
protected void onResume() {
super.onResume();
checkPlayServices();
}
}
HomeActivity.java
package com.gcm.cuser.gcmnotification;
import com.google.android.gms.common.ConnectionResult;
import com.google.android.gms.common.GooglePlayServicesUtil;
import android.app.Activity;
import android.content.Context;
import android.content.SharedPreferences;
import android.os.Bundle;
import android.util.Log;
import android.widget.TextView;
import android.widget.Toast;
public class HomeActivity extends Activity {
TextView msgET, usertitleET;
private final static int PLAY_SERVICES_RESOLUTION_REQUEST = 9000;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_home);
// Intent Message sent from Broadcast Receiver
String str = getIntent().getStringExtra("msg");
// Get Email ID from Shared preferences
SharedPreferences prefs = getSharedPreferences("UserDetails",
Context.MODE_PRIVATE);
String eMailId = prefs.getString("eMailId", "");
// Set Title
usertitleET = (TextView) findViewById(R.id.usertitle);
// Check if Google Play Service is installed in Device
// Play services is needed to handle GCM stuffs
if (!checkPlayServices()) {
Toast.makeText(
getApplicationContext(),
"This device doesn't support Play services, App will not work normally",
Toast.LENGTH_LONG).show();
}
usertitleET.setText("Hello " + eMailId + " !");
// When Message sent from Broadcase Receiver is not empty
if (str != null) {
// Set the message
msgET = (TextView) findViewById(R.id.message);
msgET.setText(str);
}
}
// Check if Google Playservices is installed in Device or not
private boolean checkPlayServices() {
int resultCode = GooglePlayServicesUtil
.isGooglePlayServicesAvailable(this);
// When Play services not found in device
if (resultCode != ConnectionResult.SUCCESS) {
if (GooglePlayServicesUtil.isUserRecoverableError(resultCode)) {
// Show Error dialog to install Play services
GooglePlayServicesUtil.getErrorDialog(resultCode, this,
PLAY_SERVICES_RESOLUTION_REQUEST).show();
} else {
Toast.makeText(
getApplicationContext(),
"This device doesn't support Play services, App will not work normally",
Toast.LENGTH_LONG).show();
finish();
}
return false;
} else {
Toast.makeText(
getApplicationContext(),
"This device supports Play services, App will work normally",
Toast.LENGTH_LONG).show();
}
return true;
}
// When Application is resumed, check for Play services support to make sure
// app will be running normally
@Override
protected void onResume() {
super.onResume();
checkPlayServices();
}
}
GcmBroadcastReciever.java
package com.gcm.cuser.gcmnotification;
/**
* Created by cuser on 28/9/15.
*/
import android.app.Activity;
import android.content.ComponentName;
import android.content.Context;
import android.content.Intent;
import android.support.v4.content.WakefulBroadcastReceiver;
public class GcmBroadcastReceiver extends WakefulBroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
ComponentName comp = new ComponentName(context.getPackageName(),
GCMNotificationIntentService.class.getName());
startWakefulService(context, (intent.setComponent(comp)));
setResultCode(Activity.RESULT_OK);
}
}
GcmNotificationIntentService.java
package com.gcm.cuser.gcmnotification;
/**
* Created by cuser on 28/9/15.
*/
import android.app.IntentService;
import android.app.Notification;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.support.v4.app.NotificationCompat;
import com.google.android.gms.gcm.GoogleCloudMessaging;
public class GCMNotificationIntentService extends IntentService {
// Sets an ID for the notification, so it can be updated
public static final int notifyID = 9001;
NotificationCompat.Builder builder;
public GCMNotificationIntentService() {
super("GcmIntentService");
}
@Override
protected void onHandleIntent(Intent intent) {
Bundle extras = intent.getExtras();
GoogleCloudMessaging gcm = GoogleCloudMessaging.getInstance(this);
String messageType = gcm.getMessageType(intent);
if (!extras.isEmpty()) {
if (GoogleCloudMessaging.MESSAGE_TYPE_SEND_ERROR
.equals(messageType)) {
sendNotification("Send error: " + extras.toString());
} else if (GoogleCloudMessaging.MESSAGE_TYPE_DELETED
.equals(messageType)) {
sendNotification("Deleted messages on server: "
+ extras.toString());
} else if (GoogleCloudMessaging.MESSAGE_TYPE_MESSAGE
.equals(messageType)) {
sendNotification("Message Received from Google GCM Server:\n\n"
+ extras.get(ApplicationConstants.MSG_KEY));
}
}
GcmBroadcastReceiver.completeWakefulIntent(intent);
}
private void sendNotification(String msg) {
Intent resultIntent = new Intent(this, HomeActivity.class);
resultIntent.putExtra("msg", msg);
PendingIntent resultPendingIntent = PendingIntent.getActivity(this, 0,
resultIntent, PendingIntent.FLAG_ONE_SHOT);
NotificationCompat.Builder mNotifyBuilder;
NotificationManager mNotificationManager;
mNotificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
mNotifyBuilder = new NotificationCompat.Builder(this)
.setContentTitle("Alert")
.setContentText("You've received new message.")
.setSmallIcon(R.mipmap.ic_launcher);
// Set pending intent
mNotifyBuilder.setContentIntent(resultPendingIntent);
// Set Vibrate, Sound and Light
int defaults = 0;
defaults = defaults | Notification.DEFAULT_LIGHTS;
defaults = defaults | Notification.DEFAULT_VIBRATE;
defaults = defaults | Notification.DEFAULT_SOUND;
mNotifyBuilder.setDefaults(defaults);
// Set the content for Notification
mNotifyBuilder.setContentText("New message from Server");
// Set autocancel
mNotifyBuilder.setAutoCancel(true);
// Post a notification
mNotificationManager.notify(notifyID, mNotifyBuilder.build());
}
}
实用程序.java
package com.gcm.cuser.gcmnotification;
/**
* Created by cuser on 28/9/15.
*/
import java.util.regex.Matcher;
import java.util.regex.Pattern;
/**
* Class which has Utility methods
*
*/
public class Utility {
private static Pattern pattern;
private static Matcher matcher;
//Email Pattern
private static final String EMAIL_PATTERN =
"^[_A-Za-z0-9-\\+]+(\\.[_A-Za-z0-9-]+)*@"
+ "[A-Za-z0-9-]+(\\.[A-Za-z0-9]+)*(\\.[A-Za-z]{2,})$";
/**
* Validate Email with regular expression
*
* @param email
* @return true for Valid Email and false for Invalid Email
*/
public static boolean validate(String email) {
pattern = Pattern.compile(EMAIL_PATTERN);
matcher = pattern.matcher(email);
return matcher.matches();
}
}
应用程序常量.java
package com.gcm.cuser.gcmnotification;
/**
* Created by cuser on 28/9/15.
*/
public interface ApplicationConstants {
// Php Application URL to store Reg ID created
static final String APP_SERVER_URL = "http://assign.afterklass.in/gcm/gcm.php?shareRegId=true";
// Google Project Number
static final String GOOGLE_PROJ_ID = "847402657944";
// Message Key
static final String MSG_KEY = "m";
}
最佳答案
您没有在 mainfest 中添加服务。只需将其添加到 list 中
<!-- services -->
<service android:name=".GCMNotificationIntentService"
android:exported="false">
<intent-filter>
<action android:name="com.google.android.c2dm.intent.RECEIVE" />
</intent-filter>
</service>
我认为它有效。
关于Android:GCM 推送通知从服务器端成功发送但未在客户端获取,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32947938/
我想在一些计算机之间建立点对点连接,这样用户就可以在没有外部服务器的情况下聊天和交换文件。我的第一个想法如下: 我在服务器上创建了一个中央 ServerSocket,所有应用程序都可以连接到该服务器。
我正在 Unity 中构建多人游戏。为此,我必须将一些值从客户端发送到两个或多个通过服务器连接的客户端。我想将其构建为服务器真实游戏。客户端将使用 Android,他们的数据将通过服务器同步(可能是一
练习 C 网络编程:我正在编写一个简单的 TCP 客户端-服务器应用程序,它应该将消息(在每个客户端的单独线程中)作为字符串从服务器发送到客户端并在客户端(稍后将成为控制台商店应用程序)。我首先发送消
我使用证书身份验证设置了 AWS Client VPN。我正在为客户端-客户端访问系统进行设置,基本上如 this AWS scenario/example 中所述.一切正常,如果我知道他们的 IP
我正在开发一个小型客户端1/客户端2、服务器(线程)TCP 游戏。在尝试处理延迟问题时,我意识到我的 transmitState() 中存在缺陷。它强制将不必要的信息传递到通讯流中,从而造成迟缓,将汽
来自文档:Configurable token lifetimes in Azure Active Directory (Public Preview) 它提到“ secret 客户端”,刷新 tok
Apollo 客户端开发工具无法连接到我的应用程序。我已在 ApolloClient 构造函数中将 connectToDevTools 传递为 true,但没有任何 react 。我也试过this p
我想在 Pod 内使用 Fabric8 kubernetes 客户端 (java)。如何获取部署集群的 kubernetes 客户端? 我可以使用该集群的 kubeconfig 文件获取任何集群的配置
我正在阅读 the security issue with Log4j我了解此产品受此漏洞影响。但是 Oracle 客户端 11.2 和 12 是否受此问题影响? 我找不到这些产品是否使用任何 Log
Eureka 服务器设置 pom.xml 1.8 Hoxton.SR1 org.springframework.cloud spring
我有一个点对点(客户端/服务器)设置(通过本地 LAN),它使用 Netty,一个 Java 网络框架。我使用原始 TCP/IP(例如,没有 HTTP)进行通信和传输。现在,根据要求,我们希望转向 T
上一篇已经实现了ModbusTcp服务器和8个主要的功能码,只是还没有实现错误处理功能。 但是在测试客户端时却发现了上一篇的一个错误,那就是写数据成功,服务器不需要响应。 接下来要做的就是实现Modb
有没有办法将二维十六进制代码数组转换为 png 图像? 数组看起来像这样(只是更大) [ [ '#FF0000', '#00FF00' ], [ '#0000FF'
我是套接字编程的新手。每次我运行客户端程序时,它都会说“无法连接到服务器”。谁能告诉我我在哪里犯了错误。任何帮助将不胜感激。 这是client.c #include #include #inclu
我们在UNIX环境下制作了简单的client.c和server.c程序。我们使用它来传输一个简单的文本文件,首先打开它,然后读取它并使用 open、read 和 send 系统调用发送;在客户端,我接
当我的程序来自 my previous question正在响应客户端,它应该发送加密消息。 当客户端连接时,它会发送一条类似“YourMessage”的消息。现在我想做的是,当客户端连接时,应该以某
我正在使用 C 和 putty 编写客户端/服务器程序。两个 c 文件位于同一系统上。 我目前在向客户端写回其正在使用的框架以及打印我的框架时遇到问题。它打印出 3 0 9 8,但随后开始打印 134
我正在使用 C 中的 select() 制作一个模拟快餐或其他任何东西的客户端服务器。 我有客户随机点 1-5 种“食物”。服务器每 30 秒决定一次。所有客户最喜欢的食物是什么?他为那些客户提供服务
对于单机游戏,基本的游戏循环是(来源:维基百科) while( user doesn't exit ) check for user input run AI move enemies
1、CentOS安装TortoiseSVN 复制代码 代码如下: yum install -y subversion 2、SVN客户端命令
我是一名优秀的程序员,十分优秀!