欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

云卡门禁苹果SDK_BLEDOOR_SDK_IOS_2016_12_15

程序员文章站 2023-11-29 21:03:58
// // BLElib.h // BLElib // // Created by szbosk on 16/8/16. // Copyright © 2016年 szbosk. All rights reserved. // #import @interface BLElib : NSObject... ......
//
//  blelib.h
//  blelib
//
//  created by szbosk on 16/8/16.
//  copyright © 2016年 szbosk. all rights reserved.
//

#import <foundation/foundation.h>
@interface blelib : nsobject


/**
 *  单例调用
 *
 *  @return 无
 */
+ (blelib *)shardinstance;

/**
 *  传入对应的数据,进行开门 内部封装了蓝牙扫描,蓝牙数据发送。
 *  本sdk只封装了开门功能,云平台功能完全由客户自行开发。
 *  刷卡记录参考业务逻辑:刷卡记录是直接通过app上传到云服务器。
 *  如果网络畅通,开门成功时直接上传云服务器。如果开门时网络不通先保存本地数据库,下次进入app或android后台服务注册网络通知,再次网络畅通时上传。
 *
 *  所传入的字符串为16进制表示的字符串,例如:ffff
 *
 *  @param mac    需要连接的蓝牙设备的mac地址,注意:需要使用我司的蓝牙设备,且前缀为bledoor  。取蓝牙广播名字的后8个字母。 bledoor-xxxxxxxx, 也就是取8位。  
 *  sdk包已经封装了蓝牙设备扫描,只要把这个xxxxxxxx传过去,sdk会自动扫描这个设备便按参数发送开门数据。也可以自己先扫描到设备后再调用sdk去开门。
 *  @param rfid   所需要的rfid  (长度8位) 用户的id,4个字节8个16进制字符,产生新用户时,app开发商自己的服务器自增1分配给用户。设备有刷卡记录。如果是从一体机门禁设备里采集,这个唯一的id就是标识那个用户刷的卡。
 *  每个记录有个id号,这个rfid表示是那个刷的卡。如果是刷卡的时候,有联网就用自己的账号体系标识上传刷卡记录,可以rfid默认00000001,他没有用处。参考:没网的时候,刷卡记录可以缓存app本地。有网时再上传。
 *  @param blepwd 所设置的蓝牙设备的密码  (长度12位)  设备默认出厂密码 6c69755f1762
 *  @param cell   授权的四位开门匹配小区  (长度4位) 默认写死 0001
 *  @param addr   授权的四位开门匹配地址  (长度4位) 0001到00fe  1到254
 *  @param start  授权的开门的起始时间  (长度8位) 有效期开始 2000年一月一日0点0分0秒。单位秒。{ 0x00, 0x00, 0x00, 0x01 } 转成10进制的1秒。2000年一月一日0点0分1秒。
 *  @param stop   授权的开门结束时间  (长度8位) 有效期结束 全是0xff是最大的有效期
 *  @param floor  授权的可以开的楼层  (长度16位) 默认ffffffffffffffff
 *   [b blemac:@"cfb28664" rfid:@"00000001" blepwd:@"6c69755f1762" cell:@"0001" addr:@"0001" start:@"00000000" stop:@"ffffffff" floor:@"ffffffffffffffff"];
* ios不能读取蓝牙的mac地址,蓝牙模块广播的名字后8位就是蓝牙的后8位mac地址 */ - (void)blemac:(nsstring *)mac rfid:(nsstring *)rfid blepwd:(nsstring *)blepwd cell:(nsstring *)cell addr:(nsstring *)addr start:(nsstring *)start stop:(nsstring *)stop floor:(nsstring *)floor; /** * 传入数据后,延迟5s(因蓝牙需要与硬件交互)调用此方法,可以得到开门结果 * * @return 返回结果对应的字符串 * @return -1:蓝牙中心管理者未初始化 * @return 0:手机蓝牙状态未打开 * @return 1:未匹配到与所传入蓝牙mac地址对应的设备 * @return 2:开门数据错误 * @return 3:开门成功 * @return 4:所传入的数据长度不对 * @return 5:连接蓝牙失败 */ -(nsstring *)resultofopen; @end