Я пытаюсь использовать реагировать на собственные биометрические данные, но после того, как я создал и сохранил открытый ключ (как состояние в приведенном ниже примере кода), он никогда не совпадает с подписью, созданной впоследствии тем же пальцем. Как проверить отпечаток пальца?
код:
registerFingerPrint = () => {
Biometrics.isSensorAvailable()
.then((biometryType) => {
if (biometryType === Biometrics.TouchID) {
Biometrics.createKeys('Confirm fingerprint')
.then((publicKey) => {
console.info("create", publicKey)
this.setState({
create: publicKey
})
})
}
})
}
fingerPrintCheck = () => {
Biometrics.createSignature('Sign in', payload)
.then((signature) => {
if (this.state.create === signature){
console.info("success");
}else {
console.info('failure'); //always returns failure here
}
})
}
render() {
return (
<View style = {styles.container}>
<TouchableHighlight onPress = {()=> this.registerFingerPrint()}>
<Text style = {{ marginBottom: 10}}>
Register
</Text>
</TouchableHighlight>
<TouchableHighlight onPress = {()=> this.fingerPrintCheck()}>
<Text>
Authenticate with Biometrics
</Text>
</TouchableHighlight>
</View>
);
}
}





let epochTimeSeconds = Math.round((new Date()).getTime() / 1000).toString()
let payload = epochTimeSeconds +'some message' ;
Biometrics.createSignature('Sign in Test', payload)
.then((signature) => {
console.info(payload+" signature "+signature)
verifySignatureWithServer(signature, payload)
})
вам нужно проверить проверку на стороне сервера, используя сгенерированную комбинацию подписи и полезной нагрузки.
перейдите на этот сайт и вставьте сгенерированный открытый ключ, подпись, полезную нагрузку и проверьте ее.
https://8gwifi.org/RSAFunctionality?rsasignverifyfunctions=rsasignverifyfunctions&keysize=512