项目中要使用安全键盘,又囊中羞涩无法购买厂商的方案;
创新互联建站长期为近千家客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为黄浦企业提供专业的成都网站设计、成都网站建设,黄浦网站改版等技术服务。拥有十载丰富建站经验和众多成功案例,为您定制开发。研究了一下,主要涉及到自定义键盘,输入jni加密存储,全程在java内存中不出现明文密码,以及一些禁回写,禁截屏的操作。
主要参考了“https://blog.csdn.net/xiaoyi2412/article/details/89157025”这篇文章。
但文章中给的项目年代相对久远,并且加密方式md5也不满足需求,所以自己重新创建了一个项目开始修改;
一.做了如下修改:
1.使用CMake进行jni的编译;
2. 分离出aar工程,方便集成使用;
3.增加DES/ECB/PKCS7Padding的加密方式,理论上引入的算法库可以支持的加密方式都可以做,只是目前项目中使用的是这种;
4.在加密库选择上,main分支选择在c层使用jni回调java层的bouncycastle库;openssl分支选择在c层直接使用openssl的crypto加密库进行加密;
5.删除了一些无用的图片资源
二.修改后发布的项目地址如下:
https://github.com/hyy12345678/SKeyboard
main分支在c层通过jni回调java层算法库进行加密,理论上明文在jni回调时还是会出现在java内存中。
openssl分支在c++层使用openssl的加密库算法,实现真正意义的在java内存中不出现密码明文。
你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧
售后响应及时
7×24小时客服热线数据备份
更安全、更高效、更稳定价格公道精准
项目经理精准报价不弄虚作假合作无风险
重合同讲信誉,无效全额退款