LatteCoin是一个使用Java开发的、基于SpringBoot框架的、基于国密算法与群签名的可溯源区块链模拟系统,该系统为授权链类型。 LatteCoin为你提供了区块链的仿真环境,你可以用这个项目去测试自己密码学方案的可行性与效率。
本项目基于Spring Boot开发,并使用thymeleaf进行了web前端的展示,便于操作。后端数据库采用Spring JPA方式进行操作,并使用了多线程来进行挖矿模拟操作。
本项目特别使用了群签名算法来进行平衡用户的匿名性以及可溯源性 本项目简单模拟了区块链中常见的行为:挖矿、交易,并添加了交易链溯源的功能 本系统中集成了国密算法SM2、SM3来进行用户公私钥生成、签名以及加密
该系统的群签名方案来自论文Simple-Yet-Efficient Construction and Revocation of Group Signatures 出处:Ho, Tzu-Hsin, Yen, et al. Simple-Yet-Efficient Construction and Revocation of Group Signatures.[J]. International Journal of Foundations of Computer Science, 2015.
系统中群签名算法的实现使用了JPBC库:JPBC,所使用到的jar包在项目的libs目录下。
- 请保证后台mysql数据库开启,并创建chain_admin用户、lattechain数据库。sql语句如下:
- 创建空密码用户:
create USER 'chain_admin';
- 创建数据库:
create database lattechain;
- 授权:
grant ALL on lattechain.* to chain_admin@'%';
,无需建立数据表,本项目使用了Spring JPA,会自动根据对象创建数据表。
- jar包运行方法:
java -jar latteCoin.jar
- 访问本地9999端口即可进行操作
感谢在华为西研所实习时,前辈们对我耐心的悉心指导,是他们让我具备了开发这个项目的能力; 感谢实验室师兄将我带进了区块链大门,毕业设计期间也对我进行了非常详细的指导。