[CoreBluetooth] API MISUSE: can only accept this command while in the powered on state(iOS蓝牙)

已标记关键词 清除标记
相关推荐
<div><p><strong>Information</strong> This GitHub Issue page is for reporting issues or asking questions regarding the iOS DFU library. For general DFU questions, SDK questions, etc, please check our <a href="https://devzone.nordicsemi.com/">DevZone</a>. Make sure you are using the latest version of the library: <a href="http://cocoapods.org/pods/iOSDFULibrary"><img alt="Version" src="http://img.shields.io/cocoapods/v/iOSDFULibrary.svg" /></a> Also, before creating a new issue, make sure similar issue isn't already opened in <a href="https://github.com/NordicSemiconductor/IOS-Pods-DFU-Library/issues">open</a> or <a href="https://github.com/NordicSemiconductor/IOS-Pods-DFU-Library/issues?q=is%3Aissue+is%3Aclosed">closed</a> issues.</p> <p><strong>Device information (please complete the following information):</strong> - Device: iPhone 8 - OS: 13.3</p> <p><strong>Describe the bug</strong> Hello, I have a device called FATTO.</p> <p>When I launch the DFU it works 1 time out of 10.</p> <p>All the other times when it does not work, it is because after changing the name of the device it connects to another device (to an iMac / other device ble / unknown device, ...), or I get error 302</p> <p>In the room there are some ble devices.</p> <p>Why after having changed the name of the Fatto device, it disconnects and connects to another device ??</p> <p><strong>First Log</strong></p> <pre><code> Connecting  [Callback] Central Manager did update state to: Powered ON  Connecting to FATTO...  centralManager.connect(peripheral, options: nil)  [Callback] Central Manager did connect peripheral  Connected to FATTO  Discovering services...  peripheral.discoverServices(nil)  Services discovered  Starting Secure DFU...  Connected to FATTO  Services discovered  Secure DFU Service found  Discovering characteristics in DFU Service...  peripheral.discoverCharacteristics(nil, for: FE59)  DFU characteristics discovered Starting  Enabling indications for 8EC90003-F315-4F60-9FB8-838830DAEA50...  peripheral.setNotifyValue(true, for: 8EC90003-F315-4F60-9FB8-838830DAEA50)  Indications enabled for 8EC90003-F315-4F60-9FB8-838830DAEA50  Buttonless DFU indications enabled  Application with buttonless update found Enabling DFU Mode  Trying setting bootloader name to Dfu92741  Writing to characteristic 8EC90003-F315-4F60-9FB8-838830DAEA50...  peripheral.writeValue(0x02084466753932373431, for: 8EC90003-F315-4F60-9FB8-838830DAEA50, type: .withResponse)  Data written to 8EC90003-F315-4F60-9FB8-838830DAEA50  Indication received from 8EC90003-F315-4F60-9FB8-838830DAEA50, value (0x):200201  Response (Op Code = 2, Status = 1) received  Bootloader name changed successfully  Writing to characteristic 8EC90003-F315-4F60-9FB8-838830DAEA50...  peripheral.writeValue(0x01, for: 8EC90003-F315-4F60-9FB8-838830DAEA50, type: .withResponse)  Data written to 8EC90003-F315-4F60-9FB8-838830DAEA50  Indication received from 8EC90003-F315-4F60-9FB8-838830DAEA50, value (0x):200101  Response (Op Code = 1, Status = 1) received imediate  [Callback] Central Manager did disconnect peripheral  Disconnected by the remote device  Scanning for the DFU Bootloader... 2020-02-03 12:31:12.207149+0200 fatto[1643:729929] [CoreBluetooth] API MISUSE: <cbperipheral: identifier="396215C7-F83E-8584-BAA3-E669AF7B95F1," name="FATTO," state="disconnected"> can only accept commands while in the connected state  DFU Bootloader found  Connecting to Unknown device.. // Why does it connect to another device?  centralManager.connect(peripheral, options: nil) </cbperipheral:></code></pre> <p><strong>Second Log</strong></p> <pre><code> Connecting  [Callback] Central Manager did update state to: Powered ON  Connecting to FATTO...  centralManager.connect(peripheral, options: nil)  [Callback] Central Manager did connect peripheral  Connected to FATTO  Discovering services...  peripheral.discoverServices(nil)  Services discovered  Starting Secure DFU...  Connected to FATTO  Services discovered  Secure DFU Service found  Discovering characteristics in DFU Service...  peripheral.discoverCharacteristics(nil, for: FE59)  DFU characteristics discovered Starting  Enabling indications for 8EC90003-F315-4F60-9FB8-838830DAEA50...  peripheral.setNotifyValue(true, for: 8EC90003-F315-4F60-9FB8-838830DAEA50)  Indications enabled for 8EC90003-F315-4F60-9FB8-838830DAEA50  Buttonless DFU indications enabled  Application with buttonless update found Enabling DFU Mode  Trying setting bootloader name to MyFattoDFU // Custom name  Writing to characteristic 8EC90003-F315-4F60-9FB8-838830DAEA50...  peripheral.writeValue(0x02084d7920466974746f, for: 8EC90003-F315-4F60-9FB8-838830DAEA50, type: .withResponse)  Data written to 8EC90003-F315-4F60-9FB8-838830DAEA50  Indication received from 8EC90003-F315-4F60-9FB8-838830DAEA50, value (0x):200201  Response (Op Code = 2, Status = 1) received  Bootloader name changed successfully  Writing to characteristic 8EC90003-F315-4F60-9FB8-838830DAEA50...  peripheral.writeValue(0x01, for: 8EC90003-F315-4F60-9FB8-838830DAEA50, type: .withResponse)  Data written to 8EC90003-F315-4F60-9FB8-838830DAEA50  Indication received from 8EC90003-F315-4F60-9FB8-838830DAEA50, value (0x):200101  Response (Op Code = 1, Status = 1) received  [Callback] Central Manager did disconnect peripheral  Disconnected by the remote device  Scanning for the DFU Bootloader...  DFU Bootloader found with name [TV] Samsung 7 Series (43) // Why does it connect to another device?  Connecting to [TV] Samsung 7 Series (43)...  centralManager.connect(peripheral, options: nil) </code></pre> <p><strong>Third log</strong></p> <pre><code> Connecting  [Callback] Central Manager did update state to: Powered ON  Connecting to FATTO...  centralManager.connect(peripheral, options: nil)  [Callback] Central Manager did connect peripheral  Connected to FATTO  Discovering services...  peripheral.discoverServices(nil)  Services discovered  Starting Secure DFU...  Connected to FATTO  Services discovered  Secure DFU Service found  Discovering characteristics in DFU Service...  peripheral.discoverCharacteristics(nil, for: FE59)  DFU characteristics discovered Starting  Enabling indications for 8EC90003-F315-4F60-9FB8-838830DAEA50...  peripheral.setNotifyValue(true, for: 8EC90003-F315-4F60-9FB8-838830DAEA50)  Indications enabled for 8EC90003-F315-4F60-9FB8-838830DAEA50  Buttonless DFU indications enabled  Application with buttonless update found Enabling DFU Mode  Trying setting bootloader name to Dfu05637  Writing to characteristic 8EC90003-F315-4F60-9FB8-838830DAEA50...  peripheral.writeValue(0x02084466753035363337, for: 8EC90003-F315-4F60-9FB8-838830DAEA50, type: .withResponse)  Data written to 8EC90003-F315-4F60-9FB8-838830DAEA50  Indication received from 8EC90003-F315-4F60-9FB8-838830DAEA50, value (0x):200201  Response (Op Code = 2, Status = 1) received  Bootloader name changed successfully  Writing to characteristic 8EC90003-F315-4F60-9FB8-838830DAEA50...  peripheral.writeValue(0x01, for: 8EC90003-F315-4F60-9FB8-838830DAEA50, type: .withResponse)  Data written to 8EC90003-F315-4F60-9FB8-838830DAEA50  Indication received from 8EC90003-F315-4F60-9FB8-838830DAEA50, value (0x):200101  Response (Op Code = 1, Status = 1) received  [Callback] Central Manager did disconnect peripheral  Disconnected by the remote device  Scanning for the DFU Bootloader...  DFU Bootloader found  Connecting to Michael 15" MacBook Pro... // Why??  centralManager.connect(peripheral, options: nil) 2020-02-03 12:12:43.365278+0200 fatto[1629:725403] [CoreBluetooth] API MISUSE: <cbperipheral: identifier="396215C7-F83E-8584-BAA3-E669AF7B95F1," name="FATTO," state="disconnected"> can only accept commands while in the connected state  [Callback] Central Manager did connect peripheral  Connected to Michael 15" MacBook Pro // ??  Discovering services...  peripheral.discoverServices([FE59])  Services discovered  DFU Service not found  No services found  Did you connect to the correct target? It might be that the previous services were cached: toggle Bluetooth from iOS settings to clear cache. Also, ensure the device contains the Service Changed characteristic  Disconnecting...  centralManager.cancelPeripheralConnection(peripheral)  [Callback] Central Manager did disconnect peripheral  Disconnected Error: 302 </cbperipheral:></code></pre> <p>My initiator is very simple:</p> <pre><code> let initiator = DFUServiceInitiator(queue: nil).with(firmware: firmware) initiator.delegate = self initiator.progressDelegate = self initiator.peripheralSelector = self initiator.logger = self </code></pre> <p>What is the problem?</p><p>该提问来源于开源项目:NordicSemiconductor/IOS-Pods-DFU-Library</p></div>
©️2020 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页