首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用Infura在Java Android中运行IPFS节点

使用Infura在Java Android中运行IPFS节点
EN

Stack Overflow用户
提问于 2020-04-24 05:36:57
回答 1查看 458关注 0票数 2

我正在尝试从Java Android应用程序连接到Infura节点。我按照这些文档连接到一个infura节点。

https://kauri.io/managing-storage-in-a-java-application-with-ipfs/3e8494f4f56f48c4bb77f1f925c6d926/a

https://github.com/ipfs-shipyard/java-ipfs-http-client/issues/115

代码:

代码语言:javascript
复制
package com.example.javahttp;

import androidx.appcompat.app.AppCompatActivity;

import android.os.AsyncTask;
import android.os.Bundle;

import io.ipfs.api.IPFS;

public class MainActivity extends AppCompatActivity {
    IPFS ipfs ;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        new MyTask().execute();
    }
    private class MyTask extends AsyncTask<Void , Void, Void > {

        @Override
        protected Void doInBackground(Void... voids) {
            IPFS ipfs = new IPFS("/dnsaddr/ipfs.infura.io/tcp/5001/https");

            try{
                System.out.println("connected");
                System.out.println("id: "+ ipfs.id());
            }catch(Exception e){
                System.out.println("not connected"+e);
            }


            return null;
        }


    }


}

我得到了这个错误。

代码语言:javascript
复制
java.lang.RuntimeException: IOException contacting IPFS daemon.
    Trailer: null ipfs method not allowed

有什么建议请提出来。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-04-24 05:59:42

我不明白为什么会有这样的错误,但是当我使用一个普通的java类来连接它的时候。这是可能的,你可以在这里参考我的存储库blockchain with java,看看你是否有所有相关的依赖项,并且你已经正确地做了,因为我不熟悉安卓,但我熟悉web3j。

您可以使用以下代码与infura节点连接,并将文件解析到该节点。

代码语言:javascript
复制
import io.ipfs.api.IPFS;
import io.ipfs.api.MerkleNode;
import io.ipfs.api.NamedStreamable;

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;

public class App {

    public static void main(String[] args) throws IOException {
        IPFS ipfs = new IPFS("/dnsaddr/ipfs.infura.io/tcp/5001/https");
        try {
            NamedStreamable.InputStreamWrapper is = new NamedStreamable.InputStreamWrapper(new FileInputStream());
            MerkleNode response = ipfs.add(is).get(0);

        } catch (IOException ex) {
            throw new RuntimeException("Error whilst communicating with the IPFS node", ex);
        }
    }

}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61397421

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档