安卓问题汇总(2022.10.07更新)

1 Android高版本联网失败报错:CLEARTEXT communication ** not permitted by network security policy(链接)

在Android P系统的设备上,如果应用使用的是非加密的明文流量的http网络请求,则会导致该应用无法进行网络请求,https则不会受影响,同样地,如果应用嵌套了webview,webview也只能使用https请求。

针对这个问题,有以下三种解决方法:

(1)APP改用https请求

(2)targetSdkVersion 降到27以下

(3)在AndroidManifest.xml配置文件的<application>标签中直接插入

  android:usesCleartextTraffic="true"

(4)更改网络安全配置

前面两个方法容易理解和实现,具体说说第三种方法,更改网络安全配置。

1.在res文件夹下创建一个xml文件夹,然后创建一个network_security_config.xml文件,文件内容如下:

<?xml version="1.0" encoding="utf-8"?>
<network-security-config>
    <base-config cleartextTrafficPermitted="true" />
</network-security-config>

接着,在AndroidManifest.xml文件下的application标签增加以下属性:

<application
...
 android:networkSecurityConfig="@xml/network_security_config"
...
    />

2 获取设备标识报错java.lang.SecurityException: getDeviceId: The user 10158 does not meet the requirements to access device identifiers.(链接

Android 10(API 级别 29)对不可重置的标识符(包括 IMEI 和序列号)添加了限制。您的应用必须是设备或个人资料所有者应用,具有特殊运营商权限或具有 READ_PRIVILEGED_PHONE_STATE 特许权限,才能访问这些标识符。

3 使用配置项

初始化:

        //初始化配置
        SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(this);
        prefs.registerOnSharedPreferenceChangeListener(this);

        mUseConnecting = prefs.getBoolean(getString(R.string.use_connecting_key),false);
        mEnableScanOnly = prefs.getBoolean(getString(R.string.enable_scan_only_key),false);

监听配置变化:

    @Override
    public void onSharedPreferenceChanged(SharedPreferences sharedPreferences, String key) {
        if(key == getString(R.string.use_connecting_key)){
            mUseConnecting = sharedPreferences.getBoolean(key,false);
        }else if(key == getString(R.string.enable_scan_only_key)){
            mEnableScanOnly = sharedPreferences.getBoolean(key,false);
        }

    }

3 android 开发注册蓝牙广播BluetoothDevice.ACTION_FOUND查找周围设备,没有接收到发现广播的解决方法(链接)

在Android 6之后需要在配置文件添加两个新的权限,且在代码里需要动态请求权限

<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>

<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/>
if (Build.VERSION.SDK_INT >= 6.0) {
     ActivityCompat.requestPermissions(this, new String[]{
               Manifest.permission.ACCESS_FINE_LOCATION},1);
 }

4 重新签名

keytool -genkey -alias aeo_android.keystore -keyalg RSA -validity 20000 -keystore aeo_android.keystore



jarsigner -verbose -keystore aeo_android.keystore newtest.apk aeo_android.keystore

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值