我正在使用此代码创建一个即使应用程序未运行也必须运行的BroadcastReceiver。
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import org.apache.http.HttpResponse;
import org.apache.http.client.ClientProtocolException;
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.message.BasicHeader;
import org.apache.http.params.HttpConnectionParams;
import org.apache.http.protocol.HTTP;
import org.apache.http.util.EntityUtils;
import org.json.JSONException;
import org.json.JSONObject;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.content.SharedPreferences;
import android.util.Log;
public class ReminderClass extends BroadcastReceiver {
SharedPreferences myPrefs;
String prefuName, pref_usr_fname, prefdev_id, pref_usr_lname, pref_uid,
pref_usr_email, ret, dates_btw;;
String event_desc, e_time, s_time, event_title, day_event_id;
ArrayList<String> day_data = new ArrayList<String>();
ArrayList<String> st_time = new ArrayList<String>();
ArrayList<String> et_time = new ArrayList<String>();
ArrayList<String> day_eve_id = new ArrayList<String>();
ArrayList<String> day_eve_title = new ArrayList<String>();
int MILLIS_IN_FIFTEEN_MINS = 1000 * 60 * 15 ;
SimpleDateFormat dateFormat = new SimpleDateFormat("hh:mm a");
@Override
public void onReceive(Context con, Intent _intent) {
// TODO Auto-generated method stub
Log.v("inside the broadcast receiver1 >>","broadcast1");
if (_intent.getAction().equals("REMINDER")) {
Log.v("inside the broadcast receiver2 >>","broadcast2");
myPrefs = con.getSharedPreferences("myPrefs", 1);
prefuName = myPrefs.getString("u_name", "");
pref_usr_fname = myPrefs.getString("fname", "");
prefdev_id = myPrefs.getString("dev_id", "");
pref_usr_lname = myPrefs.getString("lname", "");
pref_uid = myPrefs.getString("id", "");
pref_usr_email = myPrefs.getString("email", "");
Log.v("pref name>>> ", prefuName);
Log.v("pref pass >>", pref_usr_fname);
Log.v("prev devid >>", prefdev_id);
Log.v("pref_usr_fname", pref_usr_fname);
Log.v("pref_usr_lname", pref_usr_lname);
Log.v("pref_uid", pref_uid);
Log.v("pref_usr_email", pref_usr_email);
try {
HttpClient client = new DefaultHttpClient();
HttpConnectionParams.setConnectionTimeout(client.getParams(), 10000); // Timeout
// Limit
HttpResponse response;
HttpPost post = null;
JSONObject json = new JSONObject();
post = new HttpPost("my_url");
json.put("user_id", pref_uid);
post.setHeader("Content-Type", "application/json");
post.setHeader("Accept", "application/json");
StringEntity se = new StringEntity(json.toString());
se.setContentEncoding(new BasicHeader(HTTP.CONTENT_TYPE,
"application/json"));
post.setEntity(se);
response = client.execute(post);
Log.v("Response >>>", response + "");
ret = EntityUtils.toString(response.getEntity());
Log.v("My calendar response", ret);
} catch (UnsupportedEncodingException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
} catch (ClientProtocolException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
} catch (org.apache.http.ParseException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
} catch (JSONException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
} catch (IOException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
}
else
{
Log.v("Broadcast not working >>","broadcast not working");
}
}
}
在我的清单中,
<receiver
android:name=".ReminderClass"
android:enabled="true" android:permission="android.permission.INTERNET">
<intent-filter>
<action android:name="REMINDER" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</receiver>
我的广播没有被调用。我做错了什么?
答案 0 :(得分:0)
第1步:从android:permission
删除<intent-filter>
,除非您确实要求发送广播的任何人都必须拥有INTERNET
权限。
步骤2:使用唯一的操作字符串,可能是包含您的包名称的字符串,而不是REMINDER
。
第3步:将所有代码移出BroadcastReceiver
并转移到其他内容,例如IntentService
。您当前的代码正在主应用程序线程上执行网络I / O.因此,您的代码将在Android 4.x设备上崩溃,并且仅仅是早期Android版本上的非常坏主意。
答案 1 :(得分:0)
我解决了我的问题。我添加了一个服务,并在BroadcastReceiver中调用该服务,该服务检查启动完成时间。在服务的Oncreate()方法中,我实现了一个每分钟运行一次的线程。我在线程的run方法中使用了我的代码。