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