【每日收获1】

来源:互联网 发布:网络信息安全培训班 编辑:程序博客网 时间:2024/06/04 18:59

W/蓝牙手机间通信 单次传递数据后就结束连接

原因 BluetoothSocket socket = serverSocket.accept();是一个阻塞语句,只有在连接成功或者失败才会返回。

解决方案 为.accept();方法加上一个逻辑判断if,在socket自动关闭并且检测到客户端或者服务器端有一端无法进行读取行为是,重新申请。

猜想 有一部分有可能是华为和三星手机蓝牙连接的问题。


E/Broken Pipe

原因 客户端与服务器的连接已经关闭(都可能关闭,一般都是客户端主动关闭),然而有一端仍然向另一端写数据。

解决方案 在接收到由Broken Pipe传出来的IOException(其实是SocketException)时,主动关闭该连接,并且看要求重新申请连接。


I/Android6.0 蓝牙权限问题

原因 在Android6.0之后,蓝牙增加了一个动态权限,需要在程序中动态申请。

系统解决方案 在AndroidManifest.xml中除了添加

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

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

之外,还需要添加如下权限

<uses-permission-sdk-23 android:name ="android.permission.ACCESS_COARSE_LOCATION"/>

除此之外还需要在使用的时候动态申请权限

//判断是否有权限if (ContextCompat.checkSelfPermission(this,        Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED) {//请求权限      ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.ACCESS_COARSE_LOCATION},            MY_PERMISSIONS_REQUEST_ACCESS_COARSE_LOCATION);//判断是否需要 向用户解释,为什么要申请该权限    if(ActivityCompat.shouldShowRequestPermissionRationale(this,            Manifest.permission.READ_CONTACTS)) {        Toast.makeText(this, "shouldShowRequestPermissionRationale", Toast.LENGTH_SHORT).show();    }}
权限申请结果

@Overridepublic void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[]      grantResults) {  super.onRequestPermissionsResult(requestCode, permissions, grantResults);}
关于更详细的内容可以看http://blog.csdn.net/uana_777/article/details/51211535


纯粹是个人为了整理日常收获的文章,参考了其他的很多大神博客,无法一一感谢,只能作为一个抱有向往之心的菜鸟继续前行。

0 0
原创粉丝点击