Android蓝牙自动配对Demo,亲测好使!!!

article/2025/10/8 10:30:14

 


 

蓝牙自动配对,即搜索到其它蓝牙设备之后直接进行配对,不需要弹出配对确认框或者密钥输入框。


转载请注明出处http://blog.csdn.net/qq_25827845/article/details/52400782


源码下载地址:https://github.com/chaohuangtianjie994/BlueTooth-AutoPair

 

经过最近一段时间得研究,针对网上给出的案例。总结了一个亲测好使的Demo。

说明如下:

1、本Demo用来连接蓝牙设备HC-05,如果你要连接其他蓝牙设备,注意修改相关名字以及修改设备初试pin值。

2、将Demo安装在Android手机上,点击按钮,可以实现与目标蓝牙设备的自动配对。

3、若目标蓝牙设备为Android手机的蓝牙,则只能保证本设备不弹出配对框,对方还是会弹出配对框。但是!!不管目标蓝牙点击“确认”or“取消”,在本设备中都显示已经成功配对。实测表明,确实已经配对了,可以进行数据传输。

4、由于使用了广播机制,所以需要在Androidmanifest.xml进行如下配置。

先配置蓝牙使用权限:

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

然后配置action,将需要用到的广播进行注册

<receiver android:name="com.ywq.broadcast.BluetoothReceiver" >
    <intent-filter android:priority="1000">
        <action android:name="android.bluetooth.device.action.PAIRING_REQUEST"/>
        <action android:name="android.bluetooth.device.action.FOUND" />
    </intent-filter>
</receiver>


程序运行流程:

1、点击按钮,判断蓝牙是否打开,,执行bluetoothAdapter.startDiscovery();由本地蓝牙设备扫描远程蓝牙设备,startDiscovery()方法是一个异步方法,调用后立即返回。该方法会进行蓝牙设备的搜索,持续12秒。

2、搜索时,系统会发送3个广播,分别为:ACTION_DISCOVERY_START:开始搜索 、ACTION_DISCOVERY_FINISHED:搜索结束、 ACTION_FOUND:找到设备,该Intent中包含两个extra fields;         

3、在广播接收类中BluetoothReceiver.java中,当设备找到之后会执行其onReceive方法。

4、String action = intent.getAction(); //得到action,

第一次action的值为BluetoothDevice.ACTION_FOUND,当找到的设备是我们目标蓝牙设备时,调用createBond方法来进行配对。ClsUtils.createBond(btDevice.getClass(), btDevice);该方法执行后,系统会收到一个请求配对的广播,即android.bluetooth.device.action.PAIRING_REQUEST。最后进行自动配对操作。

5、配对操作借助工具类ClsUtils.java得到了Android蓝牙API中隐藏的方法,实现自动配对,不弹出配对框的功能。



代码如下:

MainActivity.java

package com.example.mybuletooth;import android.app.Activity;
import android.bluetooth.BluetoothAdapter;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;public class MainActivity extends Activity implements OnClickListener{/** Called when the activity is first created. */ private Button autopairbtn=null;private BluetoothAdapter bluetoothAdapter = BluetoothAdapter.getDefaultAdapter();@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);autopairbtn=(Button) findViewById(R.id.button1);autopairbtn.setOnClickListener(this);}//设置按钮的监听方法@Overridepublic void onClick(View arg0) {if (!bluetoothAdapter.isEnabled()){bluetoothAdapter.enable();//异步的,不会等待结果,直接返回。}else{bluetoothAdapter.startDiscovery();}}
}


BluetoothReceiver.java

package com.ywq.broadcast;import com.ywq.tools.ClsUtils;
import android.bluetooth.BluetoothDevice;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.util.Log;public class BluetoothReceiver extends BroadcastReceiver{String pin = "1234";  //此处为你要连接的蓝牙设备的初始密钥,一般为1234或0000public BluetoothReceiver() {}//广播接收器,当远程蓝牙设备被发现时,回调函数onReceiver()会被执行 @Overridepublic void onReceive(Context context, Intent intent) {String action = intent.getAction(); //得到actionLog.e("action1=", action);BluetoothDevice btDevice=null;  //创建一个蓝牙device对象// 从Intent中获取设备对象btDevice = intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE); if(BluetoothDevice.ACTION_FOUND.equals(action)){  //发现设备Log.e("发现设备:", "["+btDevice.getName()+"]"+":"+btDevice.getAddress());if(btDevice.getName().contains("HC-05"))//HC-05设备如果有多个,第一个搜到的那个会被尝试。{if (btDevice.getBondState() == BluetoothDevice.BOND_NONE) {  Log.e("ywq", "attemp to bond:"+"["+btDevice.getName()+"]");try {//通过工具类ClsUtils,调用createBond方法ClsUtils.createBond(btDevice.getClass(), btDevice);} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}}}elseLog.e("error", "Is faild");}else if(action.equals("android.bluetooth.device.action.PAIRING_REQUEST")) //再次得到的action,会等于PAIRING_REQUEST{Log.e("action2=", action);if(btDevice.getName().contains("HC-05")){Log.e("here", "OKOKOK");try {//1.确认配对ClsUtils.setPairingConfirmation(btDevice.getClass(), btDevice, true);//2.终止有序广播Log.i("order...", "isOrderedBroadcast:"+isOrderedBroadcast()+",isInitialStickyBroadcast:"+isInitialStickyBroadcast());abortBroadcast();//如果没有将广播终止,则会出现一个一闪而过的配对框。//3.调用setPin方法进行配对...boolean ret = ClsUtils.setPin(btDevice.getClass(), btDevice, pin);} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}}elseLog.e("提示信息", "这个设备不是目标蓝牙设备");}}
}

工具类ClsUtils.java

package com.ywq.tools;/************************************ 蓝牙配对函数 * **************/import java.lang.reflect.Method;  
import java.lang.reflect.Field;  
import android.bluetooth.BluetoothDevice;  
import android.util.Log;  public class ClsUtils   
{  /** * 与设备配对 参考源码:platform/packages/apps/Settings.git * /Settings/src/com/android/settings/bluetooth/CachedBluetoothDevice.java */  static public boolean createBond(Class btClass, BluetoothDevice btDevice)  throws Exception  {  Method createBondMethod = btClass.getMethod("createBond");  Boolean returnValue = (Boolean) createBondMethod.invoke(btDevice);  return returnValue.booleanValue();  }  /** * 与设备解除配对 参考源码:platform/packages/apps/Settings.git * /Settings/src/com/android/settings/bluetooth/CachedBluetoothDevice.java */  static public boolean removeBond(Class<?> btClass, BluetoothDevice btDevice)  throws Exception  {  Method removeBondMethod = btClass.getMethod("removeBond");  Boolean returnValue = (Boolean) removeBondMethod.invoke(btDevice);  return returnValue.booleanValue();  }  static public boolean setPin(Class<? extends BluetoothDevice> btClass, BluetoothDevice btDevice,  String str) throws Exception  {  try  {  Method removeBondMethod = btClass.getDeclaredMethod("setPin",  new Class[]  {byte[].class});  Boolean returnValue = (Boolean) removeBondMethod.invoke(btDevice,  new Object[]  {str.getBytes()});  Log.e("returnValue", "" + returnValue);  }  catch (SecurityException e)  {  // throw new RuntimeException(e.getMessage());  e.printStackTrace();  }  catch (IllegalArgumentException e)  {  // throw new RuntimeException(e.getMessage());  e.printStackTrace();  }  catch (Exception e)  {  // TODO Auto-generated catch block  e.printStackTrace();  }  return true;  }  // 取消用户输入  static public boolean cancelPairingUserInput(Class<?> btClass,  BluetoothDevice device)  throws Exception  {  Method createBondMethod = btClass.getMethod("cancelPairingUserInput");  
//        cancelBondProcess(btClass, device);Boolean returnValue = (Boolean) createBondMethod.invoke(device);  return returnValue.booleanValue();  }  // 取消配对  static public boolean cancelBondProcess(Class<?> btClass,  BluetoothDevice device)  throws Exception  {  Method createBondMethod = btClass.getMethod("cancelBondProcess");  Boolean returnValue = (Boolean) createBondMethod.invoke(device);  return returnValue.booleanValue();  } //确认配对static public void setPairingConfirmation(Class<?> btClass,BluetoothDevice device,boolean isConfirm)throws Exception {Method setPairingConfirmation = btClass.getDeclaredMethod("setPairingConfirmation",boolean.class); setPairingConfirmation.invoke(device,isConfirm);}/** * * @param clsShow */  static public void printAllInform(Class clsShow)  {  try  {  // 取得所有方法  Method[] hideMethod = clsShow.getMethods();  int i = 0;  for (; i < hideMethod.length; i++)  {  Log.e("method name", hideMethod[i].getName() + ";and the i is:"  + i);  }// 取得所有常量  Field[] allFields = clsShow.getFields();  for (i = 0; i < allFields.length; i++)  {  Log.e("Field name", allFields[i].getName());  }}  catch (SecurityException e)  {  // throw new RuntimeException(e.getMessage());  e.printStackTrace();  }  catch (IllegalArgumentException e)  {  // throw new RuntimeException(e.getMessage());  e.printStackTrace();  }  catch (Exception e)  {  // TODO Auto-generated catch block  e.printStackTrace();  }  }  
}  

Androidmanifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"package="com.example.mybuletooth"android:versionCode="1"android:versionName="1.0" ><uses-sdkandroid:minSdkVersion="8"android:targetSdkVersion="21" /><uses-permission android:name="android.permission.BLUETOOTH"/><uses-permission android:name="android.permission.BLUETOOTH_ADMIN"/><applicationandroid:allowBackup="true"android:icon="@drawable/ic_launcher"android:label="@string/app_name"android:theme="@style/AppTheme" ><activityandroid:name=".MainActivity"android:label="@string/app_name" ><intent-filter><action android:name="android.intent.action.MAIN" /><category android:name="android.intent.category.LAUNCHER" /></intent-filter></activity><receiver android:name="com.ywq.broadcast.BluetoothReceiver" ><intent-filter android:priority="1000"><action android:name="android.bluetooth.device.action.PAIRING_REQUEST"/><action android:name="android.bluetooth.device.action.FOUND" /></intent-filter></receiver></application></manifest>


布局配置文件activity_main.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"android:paddingBottom="@dimen/activity_vertical_margin"android:paddingLeft="@dimen/activity_horizontal_margin"android:paddingRight="@dimen/activity_horizontal_margin"android:paddingTop="@dimen/activity_vertical_margin"tools:context="com.example.mybuletooth.MainActivity" ><Buttonandroid:id="@+id/button1"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_alignParentLeft="true"android:layout_alignParentTop="true"android:layout_marginLeft="54dp"android:layout_marginTop="56dp"android:text="自动配对" /><TextViewandroid:id="@+id/textView1"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_centerVertical="true"android:text="点击按钮,自动搜索蓝牙设备,并且进行配对" /></RelativeLayout>


针对网上其它帖子中的demo不好使的原因,在此给出一些我的看法,是不是这样不敢保证,至少部分是这些原因吧。。。

1、出现一个一闪而过的配对框怎么办?

答:那是因为广播没有停止,须得调用abortBroadcast();将广播停止。

2、自动配对框还是会弹出来怎么办?

答:网上好多帖子代码有误,或者没有说清楚。请注意相关配置和工具类中函数的使用。



这是本人亲测好使的自动配对Demo,仅供参考,希望对大家有所帮助。有问题可以联系我。



 

重要更新:********************************************************************************


2016-10-20 ,今天和一个咨询我的小伙伴详细的聊了会儿天。他的问题是,下图所示的if语句块进不去。

 

它的btDevice.getBondState( )=12,但是BluetoothDevice.BOND_NONE=10,这不是肯定进不去么。哭

其中,查阅SDK,可以看到BluetoothDevice的这几个函数和数字的含义是什么。

参考网址:http://www.cnblogs.com/over140/archive/2010/12/21/1912482.html

如下所示:

 

 

 

我一看,天呐,很明显的低级错误。我让他打开设置看看,是否显示已经配对。结果自然是已经配对了。

产生原因:这个demo在跑之前,他已经在手机-设置-蓝牙中手动把目标蓝牙配对了。那还玩个毛呀大哭

 

当手动取消配对后,程序运行正常,log打印和预期一样,自动配对实现。

 

 

 

提示:

通过这个小失误,可以看出,评论里好多说这也不行,那也不行的。既然好多人都说好使,那你为什么就不行呢?还是多从自身找问题吧,心思缜密点,避免这种低级失误。大哥,你是程序猿好不好。

                                         

 


源码下载地址:https://github.com/chaohuangtianjie994/BlueTooth-AutoPair


如果对你有帮助,记得点赞哦~欢迎大家关注我的博客,有问题可以进群366533258讨论哈~





http://chatgpt.dhexx.cn/article/TBdMEFOR.shtml

相关文章

HC05蓝牙模块配对指南(教程)

HC05蓝牙模块配对指南&#xff08;教程&#xff09; 1.准备两个蓝牙模块&#xff0c;一个作为主机&#xff0c;一个作为从机 本人调试过程中用到的是正点原子的HC05蓝牙模块&#xff0c;其余模块的调试大同小异。 2.进入AT状态 进入AT状态有2种方法&#xff1a; 1,上电同时…

android 实现ble蓝牙自动配对连接

蓝牙自动配对&#xff0c;即搜索到其它蓝牙设备之后直接进行配对&#xff0c;不需要弹出配对确认框或者密钥输入框。 本文章用来连接蓝牙设备ai-thinker&#xff0c;如果你要连接其他蓝牙设备&#xff0c;注意修改相关名字以及修改设备初试pin值。 将Demo安装在Android手机上…

一篇文章带你解读蓝牙配对绑定

BLE配对绑定解读 什么是低功耗蓝牙配对&#xff1f;什么又是绑定&#xff1f;配对和绑定有什么区别&#xff1f;配对有什么好处&#xff1f;如何删除绑定信息&#xff1f;如何确定配对的安全等级&#xff1f;just work的配对一定就不安全吗&#xff1f;如何开发自己的配对应用…

蓝牙配对流程(一)

一、扫描 被动扫描&#xff08;主从之间没有扫描请求与扫描响应&#xff09; 2.主动扫描&#xff08;主从之间有扫描请求与扫描响应&#xff09; 二、过滤 1、信息匹配&#xff08;是否在白名单&#xff09; 三、建立连接 1、建立连接 建立连接后的结果&#xff1a; 连接成…

蓝牙协议和配对

蓝牙协议 蓝牙协议分层 物理层&#xff08;PHA&#xff09;&#xff0c;链路层&#xff08;LL&#xff09;&#xff0c;HCI&#xff08;可选&#xff09;,GAP层&#xff0c;L2CAP&#xff0c;SMP &#xff0c; ATT &#xff0c;GATT GAP层角色总结 对于蓝牙的主机和蓝牙的从…

蓝牙(二)蓝牙搜索、配对、连接

1.搜索 从上一节我们可以知道&#xff0c;蓝牙状态发生了改变&#xff0c;并发生了回调。咱们就从回调开始。 DevicePickerFragment.java 用于蓝牙设置界面的蓝牙配置和管理 Overridepublic void onBluetoothStateChanged(int bluetoothState) {super.onBluetoothStateChange…

Android蓝牙配对

上一篇博客介绍了Android ble的一些情况。 http://blog.csdn.net/guijiaoba/article/details/41172403 蓝牙如果链接好&#xff0c;能够读写&#xff0c;基本上完成了。蓝牙还有个比较烦人的东西&#xff0c;就是蓝牙配对。 Android ble4.0使用的配对方式和原先版本的配对方式…

Android蓝牙开发(二)之蓝牙配对和蓝牙连接

上篇文章&#xff1a;https://blog.csdn.net/huangliniqng/article/details/82185983 讲解了打开蓝牙设备和搜索蓝牙设备&#xff0c;这篇文章来讲解蓝牙配对和蓝牙连接 1.蓝牙配对 搜索到蓝牙设备后&#xff0c;将设备信息填充到listview中&#xff0c;点击listiew则请求配对…

BLE蓝牙的连接和配对过程

一 连接 同一款手机&#xff0c;为什么跟某些设备可以连接成功&#xff0c;而跟另外一些设备又连接不成功&#xff1f;同一个设备&#xff0c;为什么跟某些手机可以建立连接&#xff0c;而跟另外一些手机又无法建立连接&#xff1f;同一个手机&#xff0c;同一个设备&#xff…

BLE蓝牙的配对过程浅析

BLE蓝牙配对过程 在了解到Bluetooth协议的大概后&#xff0c;本篇文章简单的梳理一下BLE蓝牙的配对过程和配对过程的数据格式&#xff0c;对于后面理解蓝牙的集中配对模式及相关漏洞浅浅奠定一下基础。 和经典蓝牙一样&#xff0c;协议为处于连接状态的BLE设备&#xff0c;定…

蓝牙设备的连接与配对

蓝牙是一种短距离无线通信技术&#xff0c;它由爱立信公司于1994年创制&#xff0c;原本想替代连接电信设备的数据线&#xff0c;但是后来发现它也能用于移动设备之间的数据传输&#xff0c;所以蓝牙技术在手机上获得了长足发展。 因为手机内部的通讯芯片一般同时集成了2G/3G/4…

Android 蓝牙连接,蓝牙配对,自动连接蓝牙

趁热打铁&#xff0c;这篇文章写于刚写完蓝牙配对Demo&#xff0c;主要介绍配对蓝牙的具体编码步骤&#xff0c;开整! 首先上效果图&#xff0c;看一下是否符合读者现在的需求 主要核心代码没有想象中那么复杂&#xff0c;首先要去申请一下权限&#xff0c;不仅需要蓝牙权限…

蓝牙配对方式

4种蓝牙配对方式&#xff0c;通俗地说&#xff1a; 1.Numeric Comparison&#xff1a;配对双方都显示一个6位的数字&#xff0c;由用户来核对数字是否一致&#xff0c;一致即可配对。例如手机之间的配对。 2.Just Works&#xff1a;用于配对没有显示没有输入的设备&#xff0c;…

蓝牙的配对和连接的建立过程

蓝牙的建立过程是一个复杂的过程&#xff0c;即使有过相当一段工作和使用经验的人&#xff0c;如果不仔细去了解还是理解不全。 平时我们用蓝牙耳机听音乐&#xff0c;和不同的设备共享文件&#xff0c;打电话等&#xff0c;都有一个配对--连接--传输数据的过程。 配对&#…

蓝牙|标准蓝牙配对方式

蓝牙:BlueTooth,是一种无线技术标准&#xff0c;可实现固定设备、移动设备和楼宇个人域网之间的短距离数据交换&#xff0c;蓝牙又分为传统/标准蓝牙和BLE蓝牙。 在了解配对方式前&#xff0c;先了解设备的IOCapacity,IOCapcaity是由设备InputCapacity和OutputCapacity组合而成…

蓝牙学习八(配对与绑定)

1.简介 Paring&#xff08;配对&#xff09;和Bonding&#xff08;绑定&#xff09;是实现蓝牙射频通信安全的一种机制&#xff0c;有两点需要注意&#xff1a; Paring/bonding实现的是蓝牙链路层的安全&#xff0c;对应用层来说是完全透明的。也就是说&#xff0c;不管有没有…

蓝牙 - 配对和连接

什么是蓝牙配对&#xff1f; 蓝牙配对是为了连接设备的一种信息注册方法。通过在设备之间注册设备信息&#xff08;配对&#xff09;&#xff0c;它们可以连接。要使用一个蓝牙设备&#xff0c;你必须首先将其与另一个蓝牙设备配对。配对有点像交换电话号码。类似于你必须与你…

Java 接口回调机制

日常开发中接口回调机制无处不在&#xff0c;刚开始用时却总是晕晕乎乎&#xff0c;网上也有很多相关的文章介绍&#xff0c;但总是没有看得太明白&#xff0c;今天端午假期正好花时间来总结一下&#xff0c;我们按如下顺序介绍 一、什么是接口回调 在应用开发中&#xff0c;接…

Android 接口回调

Android接口回调讲解 回调定义回调机制回调意义接口回调的实现步骤参考 网上看了一堆&#xff0c;感觉有点零散&#xff0c;我自己总结一下。 回调定义 正式定义 回调函数就是一个通过函数指针调用的函数。如果你把函数的指针&#xff08;地址&#xff09;作为参数传递给另一…

理解Java接口回调

初步认识&#xff1a; 实现步骤&#xff1a; 1、创建一个回调接口。 2、创建一个回调对象实现回调接口。 3、创建一个控制器对象&#xff0c;将回调对象作为参数传给控制器对象&#xff0c;控制器对象负责检查某个场景是否出现或某个条件是否满足&#xff0c;当满足时&#…