service动态更新UI界面

之前我们曾向您介绍过Android的UI设计与后台线程交互,据Android API的介绍,service一般是在后台运行的,没有界面的。那么如何实现service动态更新UI界面呢?
案例:通过service向远程服务器发送请求,根据服务器返回的结果动态更新主程序UI界面,主程序可实时关闭或重启服务。

注册BroadcastReceiver
在主程序activity中注册一个BroadcastReceiver,用于接收Service发布的广播。

Java代码:
@Override
protected void onStart() {
//重写onStart方法
dataReceiver = new DataReceiver();
IntentFilter filter = new IntentFilter();
//创建IntentFilter对象
filter.addAction("com.justel.serviceBC");
registerReceiver(dataReceiver, filter);
//注册Broadcast Receiver super.onStart();
}


停止service命令
主程序activity可发布广播,用于向后台service传递数据或控制信息,如停止service命令。

Java代码:
btnStop.setOnClickListener(new OnClickListener() {
//为按钮添加点击事件监听
@Override
public void onClick(View v) {
//重写onClick方法
Intent myIntent = new Intent();
//创建Intent对象
myIntent.setAction("com.justel.service");
myIntent.putExtra("cmd", CMD_STOP_SERVICE);
sendBroadcast(myIntent);
//发送广播
}

});


接收广播
后台service注册BroadCastReceiver用于接受主程序发送的广播

Java代码:
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
//重写onStartCommand方法
IntentFilter filter = new IntentFilter();
//创建IntentFilter对象
filter.addAction("com.justel.service");
registerReceiver(cmdReceiver, filter);
//注册Broadcast Receiver doJob();
//调用方法启动线程,自己来完成
return super.onStartCommand(intent, flags, startId);
}


实时发送
后台service在doJob()方法中连接服务器并向主程序实时发送广播。

Java代码:
/**
* 启动一个子纯种并连接服务器,接收服务器返回数据data。代码略。。。
*/
Object data;
//服务器返回的数据data
Intent intent = new Intent();
//创建Intent对象
intent.setAction("com.justel.service");
intent.putExtra("data", data);
sendBroadcast(intent);
//发送广播

至此,我们实现了主程序通过接收广播实时更新应用的UI界面。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Consul UI界面上添加鉴权,您可以按照以下步骤进行操作: 1. 在Consul配置文件中启用ACL(Access Control List)功能。打开Consul配置文件(consul.hcl)并确保以下内容: ``` acl { enabled = true } ``` 2. 生成并设置ACL master token。在Consul服务器上运行以下命令生成token: ``` consul acl bootstrap ``` 这将生成一个ACL master token,类似于:`Master Token: XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX`。将此token保存好,因为它将用于配置和管理ACL。 3. 创建和配置用户和权限。使用上一步生成的ACL master token,您可以创建新用户和分配权限。例如,创建一个名为"ui-user"的用户,并为其分配ACL策略: ``` consul acl policy create -name ui-policy -rules 'node_prefix "" { policy = "write" } service_prefix "" { policy = "read" }' consul acl token create -description "UI Token" -policy-name ui-policy ``` 这将生成一个包含ACL令牌的输出,类似于:`AccessorID: XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX`。将此令牌保存好,因为它将用于访问UI界面。 4. 配置Consul UI使用ACL令牌。打开Consul配置文件(consul.hcl)并确保以下内容: ``` ui_config { enabled = true acl_auth_method = "tokens" acl_auth_token = "XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX" } ``` 将`acl_auth_token`替换为上一步生成的ACL令牌。 5. 重新启动Consul服务。保存并关闭Consul配置文件后,重新启动Consul服务以使更改生效。 现在,您可以通过访问Consul UI界面并使用生成的ACL令牌进行身份验证和授权访问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值