接收广播处理短消息 Manifest.permission.RECEIVE_SMS

本文展示了如何在Android应用中实现接收和处理短消息的广播接收器。通过检查权限并动态注册BroadcastReceiver,当收到SMS_RECEIVED广播时,应用会显示发送者号码和短信内容。

接收广播处理短消息 Manifest.permission.RECEIVE_SMS

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {

// if (checkSelfPermission(Manifest.permission.SEND_SMS) == PackageManager.PERMISSION_DENIED) {

// Log.d("permission", "permission denied to SEND_SMS - requesting it")

String[] permissions ={Manifest.permission.SEND_SMS,Manifest.permission.READ_SMS,Manifest.permission.RECEIVE_SMS};

requestPermissions(permissions, 1);

// }

}

//动态注册广播接收

Receiver_SMS sms=new Receiver_SMS();

IntentFilter filter=new IntentFilter();

filter.addAction("android.provider.Telephony.SMS_RECEIVED");

registerReceiver(sms,filter);

}

public class Receiver_SMS extends BroadcastReceiver {

private final String TAG=MyReceiver.class.getSimpleName();

@Override

public void onReceive(Context context, Intent intent) {

// TODO: This method is called when the BroadcastReceiver is receiving an Intent broadcast.

Toast.makeText(context, "Broad cast Received", Toast.LENGTH_SHORT).show();

Log.e(TAG,"RECEIVE_SMS Broad cast Received !");

Bundle bundle=intent.getExtras();

Object[] pdus=(Object[]) bundle.get("pdus");//提取短信消息

SmsMessage[] messages=new SmsMessage[pdus.length];

for(int i=0;i<messages.length;i++){

messages[i]=SmsMessage.createFromPdu((byte[]) pdus[i]);

}

String address=messages[0].getOriginatingAddress();//获取发送号码

String fullMessage="";

for(SmsMessage message: messages){

fullMessage+=message.getMessageBody();//获取短信内容

}

Toast.makeText(context, "接收到短消息:"+address+" 内容:"+fullMessage, Toast.LENGTH_SHORT).show();

Log.e(TAG,fullMessage);

}

}

### Android权限ACCESS_COARSE_LOCATION和ACCESS_LOCATION_EXTRA_COMMANDS的使用 #### ACCESS_COARSE_LOCATION权限 ACCESS_COARSE_LOCATION权限允许应用访问设备的大概位置信息,这种位置信息的精度较低,通常通过Wi-Fi或移动网络基站获取[^1]。为了在应用中使用该权限,需要在AndroidManifest.xml文件中声明如下内容: ```xml <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /> ``` 此外,在运行时还需要动态请求此权限(适用于Android 6.0及以上版本)。以下是一个示例代码,展示如何动态请求ACCESS_COARSE_LOCATION权限: ```kotlin val rxPermissions = RxPermissions(this) rxPermissions.request(android.Manifest.permission.ACCESS_COARSE_LOCATION) .subscribe { granted -> if (granted) { // 用户已授予权限 Log.i("TAG", "ACCESS_COARSE_LOCATION granted") } else { // 用户拒绝了权限 Log.i("TAG", "ACCESS_COARSE_LOCATION denied") } } ``` #### ACCESS_LOCATION_EXTRA_COMMANDS权限 ACCESS_LOCATION_EXTRA_COMMANDS权限允许应用通过`ILocationManager`接口发送额外的命令给位置提供程序[^4]。此权限通常用于高级定位功能,例如调整GPS芯片的行为或执行特定的调试操作。与ACCESS_COARSE_LOCATION不同,ACCESS_LOCATION_EXTRA_COMMANDS并不直接涉及位置数据的访问。 要在应用中使用该权限,也需要在AndroidManifest.xml中声明: ```xml <uses-permission android:name="android.permission.ACCESS_LOCATION_EXTRA_COMMANDS" /> ``` 需要注意的是,ACCESS_LOCATION_EXTRA_COMMANDS权限通常不需要用户显式授予,因为它不涉及敏感的用户数据。然而,确保仅在必要时使用此权限,并遵循最小权限原则。 #### 权限使用的注意事项 - 在AndroidManifest.xml中声明权限是必要的第一步,但自Android 6.0(API级别23)起,某些权限需要在运行时动态请求[^3]。 - 对于ACCESS_COARSE_LOCATION权限,建议在请求时向用户提供清晰的理由,以提高用户接受的可能性。 - 确保应用在未获得相应权限的情况下不会崩溃或出现异常行为。 ### 示例代码 以下是一个完整的示例,展示如何同时请求ACCESS_COARSE_LOCATION和ACCESS_LOCATION_EXTRA_COMMANDS权限: ```kotlin val rxPermissions = RxPermissions(this) // 请求ACCESS_COARSE_LOCATION权限 rxPermissions.request(android.Manifest.permission.ACCESS_COARSE_LOCATION) .subscribe { granted -> if (granted) { Log.i("TAG", "ACCESS_COARSE_LOCATION granted") } else { Log.i("TAG", "ACCESS_COARSE_LOCATION denied") } } // 请求ACCESS_LOCATION_EXTRA_COMMANDS权限 rxPermissions.request(android.Manifest.permission.ACCESS_LOCATION_EXTRA_COMMANDS) .subscribe { granted -> if (granted) { Log.i("TAG", "ACCESS_LOCATION_EXTRA_COMMANDS granted") } else { Log.i("TAG", "ACCESS_LOCATION_EXTRA_COMMANDS denied") } } ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值