【项目实战】如何在项目中基于 Spring Boot Starter 开发简单的 SDK

什么是SDK

通常在分布式项目中,类和方法是不能跨模块使用的。为了方便开发者的调用,我们需要开发一个简单易用的SDK,使开发者只需关注调用哪些接口、传递哪些参数,就像调用自己编写的代码一样简单。实际上,RPC(远程过程调用)就是为了实现这一目的而设计的。RPC就是追求简单化调用的理想情况。类似的例子是小程序开发或者调用第三方 API,如腾讯云的 API,它们都提供了相应的 SDK。

为什么使用SDK

在此分布式项目中SDK客户端封装了对各API接口的调用方法,通过引入 Starter 的方式直接使用客户端,为用户生成一个可以使用的客户端对象,实现跨模块的对象创建和方法调用,降低了使用成本。

项目实战

SDK结构

1)编写 SDK 版本号:

2)为了使客户端不用手动创建而可直接使用,这里 Starter 采用配置类的形式

//告诉Spring这是一个配置类
@Configuration
//读取application.yml配置类,并且给配置类加上前缀"myapi.client"
@ConfigurationProperties("myapi.client")
//Lombok注解,用于生成get、set方法
@Data
//用于自动扫描组件,自动注入Bean
@ComponentScan
public class YuApiClientConfig {

    private String accessKey;

    private String secretKey;

    @Bean
    public MyApiClient myApiClient(){
        return new MyApiClient(accessKey,secretKey);
    }
}

3)resource文件下新建META-INF和spring.factories

 

4)在spring.factories文件下写入配置内容(配置类根路径)

# spring boot starter
org.springframework.boot.autoconfigure.EnableAutoConfiguration=com.example.myapiclientsdk.YuApiClientConfig

 5)上传jar包到Maven中央仓库,具体教程可见【教程】如何上传依赖到maven中央仓库并且引入至pom文件-CSDN博客

 

6)引入依赖

7)注入客户端对象,调用其方法:

添加配置类:

注入对象:

调用 API 接口方法:

User user = userService.getLoginUser(request);
        String accessKey = user.getAccessKey();
        String secretKey = user.getSecretKey();
        MyApiClient myApiClient1 = new MyApiClient(accessKey,secretKey);
        Gson gson = new Gson();
        com.example.myapiclientsdk.model.User currentUser = gson.fromJson(userrequestParams, com.example.myapiclientsdk.model.User.class);
        String userNameByPost = myApiClient1.getUserNameByPost(currentUser);
        return ResultUtils.success(userNameByPost);

这样一来,用户就可以通过引入依赖像使用本地方法一样调用SDK中的接口了。

Fabric Java SDK 是为 Hyperledger Fabric 区块链平台开发Java SDK,它提供了访问 Fabric 网络的所有必要接口,包括身份验证、链码调用、交易提交等。Spring Boot 是一个基于 Spring 框架的快速开发应用程序的工具,它提供了诸多便利的特性,如自动配置、快速开发等。 在使用 Fabric Java SDK 开发 Spring Boot 项目时,我们可以采用以下步骤: 1. 配置 Maven 依赖 在 pom.xml 文件添加以下依赖: ```xml <dependency> <groupId>org.hyperledger.fabric-sdk-java</groupId> <artifactId>fabric-sdk-java</artifactId> <version>2.2.0</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> ``` 2. 配置 Fabric SDKSpring Boot 项目,我们可以使用 @Configuration 注解配置 Fabric SDK。在配置,我们需要指定以下参数: - Fabric 网络的 CA 证书 - Fabric 网络的 MSP 证书 - Fabric 网络的连接配置文件 ```java @Configuration public class FabricConfig { private static final String CONNECTION_PROFILE_PATH = "connection-profile.yaml"; private static final String MSP_PATH = "/msp"; private static final String CA_ORG1_URL = "http://localhost:7054"; private static final String CHANNEL_NAME = "mychannel"; @Bean public NetworkConfig getNetworkConfig() throws Exception { Path connectionProfilePath = Paths.get(CONNECTION_PROFILE_PATH); return NetworkConfig.fromYamlFile(connectionProfilePath.toFile()); } @Bean public User getUser(NetworkConfig networkConfig) throws Exception { UserContext userContext = new UserContext(); userContext.setName("user1"); userContext.setAffiliation("org1"); userContext.setMspId("Org1MSP"); Path mspPath = Paths.get(networkConfig.getOrganizationInfo("Org1").getMspId(), MSP_PATH); userContext.setEnrollment(new Enrollment() { @Override public PrivateKey getKey() { try { return loadPrivateKey(mspPath); } catch (Exception e) { throw new RuntimeException(e); } } @Override public String getCert() { try { return new String(loadCert(mspPath), "UTF-8"); } catch (Exception e) { throw new RuntimeException(e); } } }); return userContext; } @Bean public FabricGateway getGateway(NetworkConfig networkConfig, User user) throws Exception { Gateway.Builder builder = Gateway.createBuilder(); builder.identity(user); builder.networkConfig(networkConfig); return builder.connect().get(); } @Bean public Contract getContract(FabricGateway gateway) throws Exception { return gateway.getNetwork(CHANNEL_NAME).getContract("mychaincode"); } private byte[] loadCert(Path mspPath) throws Exception { Path certPath = mspPath.resolve(Paths.get("signcerts", "cert.pem")); return Files.readAllBytes(certPath); } private PrivateKey loadPrivateKey(Path mspPath) throws Exception { Path keyPath = mspPath.resolve(Paths.get("keystore", "priv.key")); byte[] keyBytes = Files.readAllBytes(keyPath); return getPrivateKeyFromBytes(keyBytes); } private PrivateKey getPrivateKeyFromBytes(byte[] keyBytes) throws Exception { PKCS8EncodedKeySpec spec = new PKCS8EncodedKeySpec(keyBytes); KeyFactory factory = KeyFactory.getInstance("EC"); return factory.generatePrivate(spec); } } ``` 3. 实现接口方法 在接口方法,我们可以使用 Fabric SDK 提供的 API 实现对链码的调用、交易的提交等操作。 ```java @RestController public class MyController { private static final String CHAINCODE_NAME = "mychaincode"; private static final String FUNCTION_NAME = "invoke"; private static final String KEY = "key1"; private static final String VALUE = "value1"; @Autowired private Contract contract; @PostMapping("/set") public String setValue() throws Exception { contract.submitTransaction(FUNCTION_NAME, KEY, VALUE); return "success"; } @GetMapping("/get") public String getValue() throws Exception { byte[] result = contract.evaluateTransaction(FUNCTION_NAME, KEY); return new String(result, "UTF-8"); } } ``` 以上就是使用 Fabric Java SDK 开发 Spring Boot 项目的流程。通过这种方式,我们可以方便地实现对 Fabric 网络的访问,并快速开发出符合需求的应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值