当前位置: 首页 > 知识库问答 >
问题:

无法从Java SDK为结构中的BYFN执行调用事务

缪茂勋
2023-03-14

我一直在尝试从Hyperledger Fabric v1中的BYFN网络的Java SDK调用和查询事务。4.4到目前为止,我已经启动了这个网络(在两个组织中有两个对等方,一个订购方,并安装了链码mycc)。网络成功启动,脚本和测试完成(根据执行结束,byfn.sh脚本运行后a和b的值分别为90和210)

现在我有了我的Java SDK,通过它,查询建议响应可以正常工作(返回90和210),但在移动(执行调用)请求后,然后查询返回的值仍然是90,没有变化,我不确定我在这里做错了什么。

我的代码:

public class sdksample {

    // Main program to simply call the client, Am i making some mistake here ?? persistency ?
    public static void main(String[] args) throws Exception {
        // create fabric-ca client
        BlockChainHFClient.getInstance().setupCryptoMaterialsForClient();
        BlockChainHFClient.getInstance().initChannel();

        // get HFC client instance
        BlockChainHFClient client = BlockChainHFClient.getInstance();
        System.out.println(client);

    }
}

HFClient

import static java.lang.String.format;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.Reader;
import java.io.StringReader;
import java.io.UnsupportedEncodingException;
import java.lang.reflect.InvocationTargetException;
import java.security.NoSuchAlgorithmException;
import java.security.NoSuchProviderException;
import java.security.PrivateKey;
import java.security.Security;
import java.security.spec.InvalidKeySpecException;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import java.util.Properties;
import java.util.Set;
import java.util.concurrent.TimeUnit;

import org.apache.commons.codec.binary.Hex;
import org.apache.commons.io.IOUtils;
import org.bouncycastle.asn1.pkcs.PrivateKeyInfo;
import org.bouncycastle.jce.provider.BouncyCastleProvider;
import org.bouncycastle.openssl.PEMParser;
import org.bouncycastle.openssl.jcajce.JcaPEMKeyConverter;
import org.hyperledger.fabric.protos.ledger.rwset.kvrwset.KvRwset;
import org.hyperledger.fabric.sdk.BlockInfo;
import org.hyperledger.fabric.sdk.BlockInfo.EnvelopeType;
import org.hyperledger.fabric.sdk.ChaincodeID;
import org.hyperledger.fabric.sdk.Channel;
import org.hyperledger.fabric.sdk.Enrollment;
import org.hyperledger.fabric.sdk.HFClient;
import org.hyperledger.fabric.sdk.Orderer;
import org.hyperledger.fabric.sdk.Peer;
import org.hyperledger.fabric.sdk.ProposalResponse;
import org.hyperledger.fabric.sdk.QueryByChaincodeRequest;
import org.hyperledger.fabric.sdk.SDKUtils;
import org.hyperledger.fabric.sdk.TransactionProposalRequest;
import org.hyperledger.fabric.sdk.TxReadWriteSetInfo;
import org.hyperledger.fabric.sdk.User;
import org.hyperledger.fabric.sdk.exception.BaseException;
import org.hyperledger.fabric.sdk.exception.CryptoException;
import org.hyperledger.fabric.sdk.exception.InvalidArgumentException;
import org.hyperledger.fabric.sdk.exception.InvalidProtocolBufferRuntimeException;
import org.hyperledger.fabric.sdk.exception.ProposalException;
import org.hyperledger.fabric.sdk.exception.TransactionException;
import org.hyperledger.fabric.sdk.security.CryptoSuite;

import com.google.protobuf.InvalidProtocolBufferException;

public class BlockChainHFClient {

    private static BlockChainHFClient instance;

    /**
     * Client instance constructor
     */
    private BlockChainHFClient() {
    }

    /**
     * Returns an instance of the Fabric client
     * 
     * @return instance
     */
    public static synchronized BlockChainHFClient getInstance() {
        if (instance == null) {
            instance = new BlockChainHFClient();
        }
        return instance;
    }

    /**
     * Fabric client object
     */
    final HFClient hfClient = HFClient.createNewInstance();
    /**
     * Crypto config folder location . keep crypto-config folder in user/home
     */
    final String CRYPTO_CONFIG_HOME_DIR = System.getProperty("user.home");
    /**
     * Grpcs URL
     */
    final String GRPCS = "grpcs://";
    /**
     * Dot for utility
     */
    final String DOT = ".";
    /**
     * MSP ID Root
     */
    final String ROOT_MSP_ID = "Org1MSP";
    /**
     * Admin user
     */
    final String PEER_ADMIN = "PeerAdmin";
    /**
     * Channel object
     */
    Channel channel;

    /**
     * Channel initialize timeout values
     */
    final Long ChannelBuilderOptionkeepAliveMinutes = 15L;
    final Long ChannelBuilderOptionkeepAliveSeconds = 15L;

    /**
     * Get channel instance
     * 
     * @return channel
     */
    public Channel getChannel() {
        return channel;
    }

    /**
     * Get HF client
     * 
     * @return HF client
     */
    public HFClient getClient() {
        return hfClient;
    }

    /**
     * Set up User contexts by using Crypto materials - Private key and cert files
     * 
     * @throws CryptoException
     * @throws InvalidArgumentException
     * @throws IllegalAccessException
     * @throws InstantiationException
     * @throws ClassNotFoundException
     * @throws NoSuchMethodException
     * @throws InvocationTargetException
     */
    public void setupCryptoMaterialsForClient()
            throws CryptoException, InvalidArgumentException, IllegalAccessException, InstantiationException,
            ClassNotFoundException, NoSuchMethodException, InvocationTargetException {
        hfClient.setCryptoSuite(CryptoSuite.Factory.getCryptoSuite());
        hfClient.setUserContext(new User() {
            public String getName() {
                return PEER_ADMIN;
            }

            public Set<String> getRoles() {
                return null;
            }

            public String getAccount() {
                return null;
            }

            public String getAffiliation() {
                return null;
            }

            public Enrollment getEnrollment() {
                return new Enrollment() {
                    public PrivateKey getKey() {
                        PrivateKey privateKey = null;
                        File privateKeyFile = findFileSk(
                                "D:\\Hyperledger Fabric_Research_Blockchain\\Fabric1.4.4\\fabric-samples\\first-network\\crypto-config\\peerOrganizations\\org1.example.com\\users\\Admin@org1.example.com\\msp\\keystore");
                        try {
                            privateKey = getPrivateKeyFromBytes(
                                    IOUtils.toByteArray(new FileInputStream(privateKeyFile)));
                        } catch (IOException e) {
                            e.printStackTrace();
                        } catch (NoSuchProviderException e) {
                            // TODO Auto-generated catch block
                            e.printStackTrace();
                        } catch (NoSuchAlgorithmException e) {
                            // TODO Auto-generated catch block
                            e.printStackTrace();
                        } catch (InvalidKeySpecException e) {
                            // TODO Auto-generated catch block
                            e.printStackTrace();
                        }

                        return privateKey;
                    }

                    public String getCert() {

                        String certificate = null;
                        try {
                            File certificateFile = new File(
                                    "D:\\Hyperledger Fabric_Research_Blockchain\\Fabric1.4.4\\fabric-samples\\first-network\\crypto-config\\peerOrganizations\\org1.example.com\\users\\Admin@org1.example.com\\msp\\signcerts\\Admin@org1.example.com-cert.pem");
                            certificate = new String(IOUtils.toByteArray(new FileInputStream(certificateFile)),
                                    "UTF-8");
                        } catch (UnsupportedEncodingException e) {
                            e.printStackTrace();
                        } catch (FileNotFoundException e) {
                            e.printStackTrace();
                        } catch (IOException e) {
                            e.printStackTrace();
                        }
                        return certificate;
                    }
                };
            }

            public String getMspId() {
                return ROOT_MSP_ID;
            }
        });
    }

    public void initChannel() throws Exception {
        Properties peerProperties = new Properties();
        peerProperties.setProperty("pemFile",
                "D:\\Hyperledger Fabric_Research_Blockchain\\Fabric1.4.4\\fabric-samples\\first-network\\crypto-config\\peerOrganizations\\org1.example.com\\peers\\peer0.org1.example.com\\tls\\server.crt");
        peerProperties.setProperty("trustServerCertificate", "true"); // testing environment only NOT FOR PRODUCTION!
        peerProperties.setProperty("hostnameOverride", "peer0.org1.example.com");
        peerProperties.setProperty("sslProvider", "openSSL");
        peerProperties.setProperty("negotiationType", "TLS");
        peerProperties.put("grpc.NettyChannelBuilderOption.maxInboundMessageSize", 9000000);
        Peer peer = hfClient.newPeer("peer0.org1.example.com", "grpc://localhost:7051");


        Properties ordererProperties = new Properties();
        ordererProperties.setProperty("pemFile",
                "D:\\Hyperledger Fabric_Research_Blockchain\\Fabric1.4.4\\fabric-samples\\first-network\\crypto-config\\ordererOrganizations\\example.com\\orderers\\orderer.example.com\\tls\\server.crt");
        ordererProperties.setProperty("trustServerCertificate", "true"); // testing environment only NOT FOR PRODUCTION!
        ordererProperties.setProperty("hostnameOverride", "orderer.example.com");
        ordererProperties.setProperty("sslProvider", "openSSL");
        ordererProperties.setProperty("negotiationType", "TLS");
        ordererProperties.put("grpc.NettyChannelBuilderOption.keepAliveTime", new Object[] { 5L, TimeUnit.MINUTES });
        ordererProperties.put("grpc.NettyChannelBuilderOption.keepAliveTimeout", new Object[] { 8L, TimeUnit.SECONDS });
        Orderer orderer = hfClient.newOrderer("orderer.example.com", "grpc://localhost:7050");


        Channel channel = hfClient.newChannel("mychannel");
        channel.addPeer(peer);
        channel.addOrderer(orderer);
        channel.initialize();



        moveUnits(hfClient);
        queryBlockChain(hfClient);

    }

    private String printableString(String string) {
        int maxLogStringLength = 10000;
        if (string == null || string.length() == 0) {
            return string;
        }

        String ret = string.replaceAll("[^\\p{Print}]", "\n");

        ret = ret.substring(0, Math.min(ret.length(), maxLogStringLength))
                + (ret.length() > maxLogStringLength ? "..." : "");

        return ret;
    }

    void queryBlockChain(HFClient client) throws ProposalException, InvalidArgumentException {
        // get channel instance from client
        Channel channel = client.getChannel("mychannel");
        // create chaincode request
        QueryByChaincodeRequest qpr = client.newQueryProposalRequest();
        // build cc id providing the chaincode name. Version is omitted here.
        ChaincodeID cid = ChaincodeID.newBuilder().setName("mycc").build();
        qpr.setChaincodeID(cid);
        // CC function to be called
        qpr.setFcn("query");
        qpr.setArgs(new String[] { "a" });
        Collection<ProposalResponse> res = channel.queryByChaincode(qpr);
        // display response
        for (ProposalResponse pres : res) {
            String stringResponse = new String(pres.getChaincodeActionResponsePayload());
            System.out.println(stringResponse);
        }
    }

     void moveUnits(HFClient client)
                throws Exception {
            Channel channel = client.getChannel("mychannel");
            TransactionProposalRequest req = client.newTransactionProposalRequest();
            ChaincodeID cid = ChaincodeID.newBuilder().setName("mycc").setVersion("1.0").build();
            req.setChaincodeID(cid);
            req.setFcn("invoke");
            req.setArgs(new String[] {"a","b","50"});
            Collection<ProposalResponse> resps = channel.sendTransactionProposal(req);

                channel.sendTransaction(resps);

        } 

    /**
     * Utility method to get private key from bytes using Bouncy Castle Security
     * Provider
     * 
     * @param data
     * @return privateKey
     * @throws IOException
     * @throws NoSuchProviderException
     * @throws NoSuchAlgorithmException
     * @throws InvalidKeySpecException
     */
    private PrivateKey getPrivateKeyFromBytes(byte[] data)
            throws IOException, NoSuchProviderException, NoSuchAlgorithmException, InvalidKeySpecException {
        final Reader pemReader = new StringReader(new String(data));
        Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());
        final PrivateKeyInfo pemPair;
        try (PEMParser pemParser = new PEMParser(pemReader)) {
            pemPair = (PrivateKeyInfo) pemParser.readObject();
        }

        PrivateKey privateKey = new JcaPEMKeyConverter().setProvider(BouncyCastleProvider.PROVIDER_NAME)
                .getPrivateKey(pemPair);

        return privateKey;
    }

    /**
     * Find files ending with _sk
     * 
     * @param directorys
     * @return file
     */
    private File findFileSk(String directorys) {

        File directory = new File(directorys);

        File[] matches = directory.listFiles((dir, name) -> name.endsWith("_sk"));

        if (null == matches) {
            throw new RuntimeException(
                    format("Matches returned null does %s directory exist?", directory.getAbsoluteFile().getName()));
        }

        if (matches.length != 1) {
            throw new RuntimeException(format("Expected in %s only 1 sk file but found %d",
                    directory.getAbsoluteFile().getName(), matches.length));
        }

        return matches[0];
    }
}

似乎没有错误,moveUnits功能似乎正常工作。但是查询返回相同的值。建议?谢谢

共有1个答案

孙化
2023-03-14

工作。显然,我必须向频道添加另一个对等方(peer0.org2.example.com),以满足两个对等方必须验证的认可策略。然后调用成功了!

 类似资料:
  • 我正在PyCharm中开发Django项目,一切正常。我已经在虚拟环境中安装了fabric,并添加了fabfile。加入我的项目。在这个文件中,我放置了一个测试任务定义: 之后,我试图直接从我的PyCharm上执行这个任务。你有什么建议我该怎么做?

  • 失败:生成失败,出现异常。 > 错误:任务“:CompileJava”执行失败。 找不到系统Java编译器。确保您已经安装了JDK(而不仅仅是JRE)并将您的JAVA_HOME系统变量配置为指向相应的目录。

  • 我在Hyperledger结构节点SDK中遇到问题。 网络详情: 该网络由4个组织组成,每个组织部署在不同的库伯内特斯集群上。 每个组织有2个同行加入了一个渠道,比如myChannel。 每个组织有1个CA运行。 订购服务是Raft. CouchDB用作statedb。 来自CLI的调用也正常工作,数据正在所有8个对等体之间同步。 Hypelredger Explorer已经启动并运行了一个组织的

  • 我对事务REST控制器中的一些异常处理感到困惑。 我有一个管理服务,看起来像: 我有一个REST控制器,看起来像: 它使用@Transactional(readOnly = true)注释。 如果存在此注释并且没有找到搜索的项目,则它会给出以下异常: 如果删除注释,则一切正常,响应包含搜索的项。 我假设当没有找到搜索的条目时会抛出一个异常,触发事务回滚消息。 以下是异常处理程序: 有没有办法在日志

  • 问题内容: 我该如何发出一个Ajax请求来从javascript 更新?我当前正在使用加载初始数据,但这会大大延迟初始页面加载。 我正在考虑使用HTML标记事件触发请求并更新数据表。 问题答案: 从 理论上讲 ,应该执行以下操作。 与 但是,由于某些原因不支持此功能。 以下工作有效,但从本质上讲这是一个hack。 如果碰巧使用了PrimeFaces,则可以将其with设置为。 或者,如果您使用的是