公司使用的考勤机是中控的指纹考勤机,但是中控的型号乱七八糟,通过程序读出来的型号和实际标的型号不一致。
另外,提供的开发包的C#版本的Demo中调用
axCZKEM1.ReadAllUserID(iMachineNumber);
后调用
axCZKEM1.SSR_GetAllUserInfo(iMachineNumber, out sdwEnrollNumber, out sName, out sPassword, out iPrivilege, out bEnabled)
来获取所有用户信息时,返回的sName(雇员姓名)每次总是在后面多几个字节,虽然显示到Demo中的ListView中时,windows自动屏蔽了乱码,但是程序处理时依然会出现乱码。
用下面的方法可以解决此问题,并能从sName中解析出正确的雇员姓名。
//处理名字中多余的字符 //utf8编码后的字节数组长度,名字中汉字的个数=(byte[]长度-10)/6+2 //提取汉字=字节数组的0开始,到名字中汉字的个数*3 if (null != sName) { byte[] nameBytes = System.Text.Encoding.UTF8.GetBytes(sName); if (nameBytes.Length >= 10) { int nameLength = (nameBytes.Length - 10) / 6 + 2; sName = System.Text.Encoding.UTF8.GetString(nameBytes, 0, 3 * nameLength); } /* switch (nameBytes.Length) { case 22: sName = System.Text.Encoding.UTF8.GetString(nameBytes, 0, 12); break; case 16: sName = System.Text.Encoding.UTF8.GetString(nameBytes, 0, 9); break; case 10: sName = System.Text.Encoding.UTF8.GetString(nameBytes, 0, 6); break; default: sName = getChinese(sName); break; } */ } else { sName = "null"; }
顺便吐槽下中控的考勤机的SDK:
无法获取指定时间内的考勤数据,必须每次都全量下载。
顺便赞一下Demo的质量:
编程风格很严谨,代码注释很详细。赞!