Service是Android系统中提供的四大组件之一。它是运行在后台的一种服务,一般声明周期较长,不直接与用户进行交互。

   服务不能自己运行,需要通过调用Context.startService()或Context.bindService()方法启动服务。这两个方法都可以启动Service,但是它们的使用场合有所不同。
    1. 使用startService()方法启用服务,调用者与服务之间没有关连,即使调用者退出了,服务仍然运行。

    如果打算采用Context.startService()方法启动服务,在服务未被创建时,系统会先调用服务的onCreate()方法,接着调用onStart()方法。

    如果调用startService()方法前服务已经被创建,多次调用startService()方法并不会导致多次创建服务,但会导致多次调用onStart()方法。

    采用startService()方法启动的服务,只能调用Context.stopService()方法结束服务,服务结束时会调用onDestroy()方法。
    2. 使用bindService()方法启用服务,调用者与服务绑定在了一起,调用者一旦退出,服务也就终止,大有“不求同时生,必须同时死”的特点。

    onBind()只有采用Context.bindService()方法启动服务时才会回调该方法。该方法在调用者与服务绑定时被调用,当调用者与服务已经绑定,多次调用Context.bindService()方法并不会导致该方法被多次调用。

    采用Context.bindService()方法启动服务时只能调用onUnbind()方法解除调用者与服务解除,服务结束时会调用onDestroy()方法。
 
这里我采用了第一种方法启动 startService(new Intent(this, LocalService.class));不过首先需要在AndroidManifest.xml文件中注册声明我们新建的Service,在application标签内添加 <service android:name=".LocalService" />即可。
下面是实现的方法,开启新线程,每隔一分钟从服务器获取消息,若产生消息,则在手机状态栏通知该消息。
public class LocalService extends Service {
private static String info = null;
private String TAG = "localservice";// 定义打印信息标识
private NotificationManager mNM;// 定义状态栏通知
private final IBinder mBinder = new LocalBinder();// 实例化LocalBinder // public static native void getSqlInfo(); public class LocalBinder extends Binder {
LocalService getService() {
return LocalService.this;
}
} public IBinder onBind(Intent intent) {
Log.i(TAG, "this is onBind");
return mBinder;
} // 实现创建方法
public void onCreate() {
Log.i(TAG, "this is onCreate");
mNM = (NotificationManager) getSystemService(NOTIFICATION_SERVICE);// 获取通知栏管理器 } // 实现开始方法
public int onStartCommand(Intent intent, int flags, int startId) {
Log.i(TAG, "received start id" + startId + ":" + intent); // 开启线程
MessageThread messageThread = new MessageThread();
messageThread.start(); return START_STICKY;
} // 实现销毁方法
public void onDestory() {
Log.i(TAG, "this is onDestory");
mNM.cancel("qqq", 0);
} // 实现解除bind方法
public boolean onUnbind(Intent intent) {
Log.i(TAG, "this is onUnbind");
return super.onUnbind(intent);
} private void showNotification(String serverMessage) {
int icon = R.drawable.icon; // 通知图标
CharSequence tickerText = "local sevice has started" + serverMessage; // 状态栏显示的通知文本提示
long when = System.currentTimeMillis(); // 通知产生的时间,会在通知信息里显示
// 用上面的属性初始化Nofification// 实例化状态通知
Notification notification = new Notification(icon, tickerText, when); PendingIntent contentIntent = PendingIntent.getActivity(this, 0,
new Intent(this, HelloPush.class), 0);// 定义通知栏单击时间触发的intent notification.defaults |= Notification.DEFAULT_SOUND;// 添加声音
// notification.defaults |= Notification.DEFAULT_VIBRATE;// 添加震动
notification.defaults |= Notification.DEFAULT_LIGHTS;// 添加LED灯提醒
notification.flags = Notification.FLAG_AUTO_CANCEL;// 在通知栏上点击此通知后自动清除此通知 notification.setLatestEventInfo(this, "Local Service", tickerText,
contentIntent);// 设置该状态栏通知消息的单击事件
mNM.notify("qqq", 0, notification);// 通知栏显示该通知 } /**
* 从服务器端获取消息
*
*/
class MessageThread extends Thread {
// 运行状态,下一步骤有大用
public boolean isRunning = true; @SuppressLint("SimpleDateFormat")
public void run() {
System.out.println("running++++++++++++++");
while (isRunning) {
try { // 获取服务器消息
String serverMessage = getServerMessage(); SimpleDateFormat formatter = new SimpleDateFormat("HH:mm");
Date curDate = new Date(System.currentTimeMillis());// 获取当前时间
String str = formatter.format(curDate);
System.out.println("++++++++++++" + str);// &&str=="08:00"
if (serverMessage != null && !"".equals(serverMessage)
// &&"15:00".equalsIgnoreCase(str)
) {
showNotification(serverMessage);
}
// 休息1分钟
System.out.println("sleeping now+++++");
Thread.sleep(60000);
System.out.println("sleep ended+++++");
} catch (InterruptedException e) {
System.out.println("thread sleep error++++");
e.printStackTrace();
}
}
}
} /**
* @return 返回服务器要推送的消息,否则如果为空的话,不推送
*/
public String getServerMessage() {
System.out.println("getServerMessage++++++++");
info = null;
// getSqlInfo();
// getSql();
info = connecting();
System.out.println("getServerMessage+++++++" + info);
return info;
} // public static int ReturnInfo(final String title) {
// System.out.println("ReturnInfo+++++++++" + title);
// info = title;
// return 1;
// }
//
// public void getSql() {
// try {
// String url = "jdbc:mysql://192.168.1.104:80/test";
// String user = "root";
// String pwd = "";
//
// // 加载驱动,这一句也可写为:Class.forName("com.mysql.jdbc.Driver");
// Class.forName("com.mysql.jdbc.Driver").newInstance();
// // 建立到MySQL的连接
// Connection conn = DriverManager.getConnection(url, user, pwd);
//
// // 执行SQL语句
// java.sql.Statement stmt = conn.createStatement();// 创建语句对象,用以执行sql语言
// ResultSet rs = stmt.executeQuery("select * from push where id = 1");
//
// // 处理结果集
// while (rs.next()) {
// String name = rs.getString("name");
// info = name;
// System.out.println(name);
// }
// rs.close();// 关闭数据库
// conn.close();
// } catch (Exception ex) {
// System.out.println("Error : " + ex.toString());
// }
// } public String connecting() {
/* 存放http请求得到的结果 */
String result = "";
// String ss = null;
String name = null; /* 将要发送的数据封包 */
ArrayList<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>();
nameValuePairs.add(new BasicNameValuePair("id", "1")); InputStream is = null;
// http post
try {
/* 创建一个HttpClient的一个对象 */
HttpClient httpclient = new DefaultHttpClient(); /* 创建一个HttpPost的对象 */
HttpPost httppost = new HttpPost(
"http://192.168.1.104:80/ying/yy.php"); /* 设置请求的数据 */
httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs)); /* 创建HttpResponse对象 */
HttpResponse response = httpclient.execute(httppost); /* 获取这次回应的消息实体 */
HttpEntity entity = response.getEntity(); /* 创建一个指向对象实体的数据流 */
is = entity.getContent();
} catch (Exception e) {
System.out.println("Connectiong Error");
}
// convert response to string
try {
BufferedReader reader = new BufferedReader(new InputStreamReader(
is, "iso-8859-1"), 8);
StringBuilder sb = new StringBuilder();
String line = null;
while ((line = reader.readLine()) != null) {
sb.append(line + "/n");
}
is.close(); result = sb.toString();
System.out.println("get = " + result);
} catch (Exception e) {
System.out.println("Error converting to String");
} // parse json data
try {
/* 从字符串result创建一个JSONArray对象 */
JSONArray jArray = new JSONArray(result); for (int i = 0; i < jArray.length(); i++) {
JSONObject json_data = jArray.getJSONObject(i);
System.out.println("Success");
System.out.println("result " + json_data.toString());
// ct_id=json_data.getInt("id");
name = json_data.getString("name");
// if (i == 0) {
// ss = json_data.toString();
// } else {
// ss += json_data.toString();
// }
}
} catch (JSONException e) {
System.out.println("Error parsing json");
}
return name;
}
}

下面是php代码

<?php
require_once("conn.php");
session_start(); $q=mysql_query("SELECT name FROM push WHERE id='".$_REQUEST['id']."'");
while($e=mysql_fetch_assoc($q))
$output[]=$e;
print(json_encode($output));
mysql_close();
?>

Android Service服务的更多相关文章

  1. Android Service 服务(三)—— bindService与remoteService

    (转自:http://blog.csdn.net/ithomer/article/details/7366396)   一.bindService简介 bindService是绑定Service服务, ...

  2. Android Service 服务

    一. Service简介 Service是android 系统中的四大组件之一(Activity.Service.BroadcastReceiver.ContentProvider),它跟Activi ...

  3. Android Service 服务(一)—— Service .

    http://blog.csdn.net/ithomer/article/details/7364024 一. Service简介 Service是android 系统中的四大组件之一(Activit ...

  4. [Android] Service服务详解以及如何使service服务不被杀死

    排版上的细节有些不好看,主要是我用的MarkDown编辑器预览和这里的不一样,在那个上面的样式很舒服.这里要改的地方太多就不想改了,将就看吧.下次写的时候注意.还有看到错误给我提啊. 本文链接:htt ...

  5. android service服务的学习

    1.Service简单概述   Service(服务)是一个一种可以在后台执行长时间运行操作而没有用户界面的应用组件.服务可由其他应用组件启动(如Activity),服务一旦被启动将在后台一直运行,即 ...

  6. Android Service 服务(二)—— BroadcastReceiver

    (转自:http://blog.csdn.net/ithomer/article/details/7365147) 一. BroadcastReceiver简介 BroadcastReceiver,用 ...

  7. Android service 服务的应用之电话监听器以及短信监听器

    首先建立一个项目工程文件,如下图所示:

  8. Android Service服务的生命周期

    与activity类似,服务也存在生命周期回调方法,你可以实现这些方法来监控服务的状态变化,并在适当的时机执行一些操作. 以下代码提纲展示了服务的每个生命周期回调方法: public class Ex ...

  9. Android -- service 服务的创建与使用,生命周期,电话监控器

    1. 为什么使用service 应用程序 : 一组组件(activity  service provider receiver)的集合. 一般情况 一个应用程序 会对应一个进程. 一般情况 关闭掉应用 ...

随机推荐

  1. eclipse 报错 import ... cannot be resolved 处理方法

    项目上右键,properties, 找java build path,切到libraies标签,将爆红的jdk编辑一下,选用你需要的jdk版本,一般1..我看你类的httpServlet报错,也是这个 ...

  2. (六)6.13 Neurons Networks Implements of stack autoencoder

    对于加深网络层数带来的问题,(gradient diffuse  局部最优等)可以使用逐层预训练(pre-training)的方法来避免 Stack-Autoencoder是一种逐层贪婪(Greedy ...

  3. 【解题报告】POJ-1106 Transmitters

    原题地址:http://poj.org/problem?id=1106 题目大意: 给定一些平面的点以及一个圆心和半径,过圆心作一个半圆,求点在半圆中点最多多少个. 解题思路: 首先将给定点中和圆心的 ...

  4. vim 大小写转化命令

    vim中大小写转化的命令是<blockquote>gu或者gU</blockquote>形象一点的解释就是小u意味着转为小写:大U意味着转为大写. 剩下的就是对这两个命令的限定 ...

  5. HALCON基础知识

    HALCON 1. 语法范式 Syntax Style 1.1. 基本格式 1.1.1. 算子格式 算子(输入图像参数:输出图像参数:输入控制参数:输出控制参数) 其中四个参数任意一个可以为空 e.g ...

  6. Javascript高级程序设计

    根据叶小钗同学的建议,觉得有必要去读读Javascript高级程序设计,不想装B,只想仔细读读,源代码参考. 偶第一个想法,就是去读面向对象和事件那块,不仅关键,而且是薄弱点儿,所以必须去干掉这个短板 ...

  7. Symfony2 学习笔记之插件格式

    一个bundle类似于其它框架中的插件,但是比插件表现更好.它跟其它框架最主要的不同是在Symfony2中所有东西都是bundle,包括核心框架功能和你写的所有应用程序代码.Symfony2中,bun ...

  8. Undefined symbols for architecture armv7

    xcode编译过程中出现如下问题Undefined symbols for architecture armv7:... ld: symbol(s) not found for architectur ...

  9. synchronized作用范围及用法

    1.多线程的同步: 1.1.同步机制: 在多线程中,可能有多个线程试图访问一个有限的资源,必须预防这种情况的发生.所以引入了同步机制:在线程使用一个资源时为其加锁,这样其他的线程便不能访问那个资源了, ...

  10. 分享我的PL/SQL的优化设置,为开发全面提速

    打开[工具]–[首选项]: 1.登陆历史:勾选[存储历史]和[带口令存储],方便下次登陆,免去每次都输入密码的烦恼: 2.编辑器: a.勾选[语法高亮]允许: b.关键词大小写选择大写: c.配置自动 ...