个人使用的是以太坊平台,solidity编写的智能合约,solidity版本号为0.4.17
部署智能合约暴露出的问题
项目在部署智能合约时,会将智能合约的API和Bytecode暴露出来,可以通过API获取到项目核心函数代码,因此存在一定的安全隐患。
如何解决
如果将核心函数所在的智能合约封装进另一个智能合约中,这个智能合约只有核心智能合约的构造函数,没有核心函数,就可以顺利解决这个问题,这个思想也是工厂模式。
工厂模式
工厂模式(Factory Pattern)是 Java 中最常用的设计模式之一。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。
在工厂模式中,我们在创建对象时不会对客户端暴露创建逻辑,并且是通过使用一个共同的接口来指向新创建的对象
代码思路
将核心智能合约的构造函数封装进factory工厂中,我们只需要调用factory的deploy()函数,并传递相应的参数,调用核心智能合约的构造函数,存入map映射;声明getAddr()即可获取到当前部署智能合约的地址
//使用智能合约部署智能合约
contract FundingFactory{
//工厂
//存储已经部署的智能合约的地址</