gpt4 book ai didi

riak - 当 riak-python-client 读取时,riak-java-client 存储的对象最终会变成原始 json?

转载 作者:行者123 更新时间:2023-12-01 07:43:41 27 4
gpt4 key购买 nike

我可能对某些事情感到困惑,但是当我从 Java Riak 客户端存储一个自定义对象,然后尝试使用 Python Riak 客户端读取该对象时,我最终得到一个原始的 json 字符串而不是一个字典。

但是,如果我在 python 中存储一个对象,我可以在获取该对象时输出一个 python 字典。

可以简单地在 python 端使用 json 库来解决这个问题,但我遇到这种差异这一事实让我觉得我做错了什么。

在 Java 方面,这是我的对象:

class DocObject 
{
public String status; // FEEDING | PERSISTED | FAILED | DELETING
public List<String> messages = new ArrayList<String>();
}

class PdfObject extends DocObject
{
public String url;
public String base_url;
}

这就是我在 Riak 中存储该对象的方式:

public void feeding(IDocument doc) throws RiakRetryFailedException {
PdfObject pdfObject = new PdfObject();

pdfObject.url = doc.getElement("url").getValue().toString();
pdfObject.base_url = doc.getElement("base_url").getValue().toString();
pdfObject.status = "FEEDING";

String key = hash(pdfObject.url);

pdfBucket.store(key, pdfObject).execute();
}

这就是我在 Python 中用来获取数据的方法:

# Connect to Riak.
client = riak.RiakClient()

# Choose the bucket to store data in.
bucket = client.bucket('pdfBucket')

doc = bucket.get('7909aa2f84c9e0fded7d1c7bb2526f54')

doc_data = doc.get_data()

print type(doc_data)

上面python的运行结果是:

<type 'str'>

我希望它是 <type 'dict'> ,就像这里的例子是如何工作的: http://basho.github.com/riak-python-client/tutorial.html#getting-single-values-out

我很困惑,为什么从 Java 存储对象时,它存储为 JSON 字符串而不是对象。

如果有人能指出我的方法中可能导致这种差异的问题,我将不胜感激。

谢谢!

最佳答案

看来您在我们的 Python 客户端中发现了 HTTP 协议(protocol)/传输的错误。

您正在使用的版本和 master 中的当前版本都没有正确解码 JSON。今天早上我和另一个开发人员对此进行了调查,这似乎源于一个问题,即 charset 参数从 Riak 返回,内容类型如 Christian 在他的评论中指出的那样(“application/json ; 字符集=UTF-8")

我们已经在 github ( https://github.com/basho/riak-python-client/issues/227 ) 上提出了一个问题,并将对此进行更正。

与此同时,我唯一的建议是自己解码返回的 JSON 字符串,或者使用 1.5.2 客户端(来自 pypy 的最新稳定版本)和 Protocol Buffers 传输:

client = riak.RiakClient(port=8087, transport_class=riak.RiakPbcTransport)

它将解码后的 JSON 作为 dict 返回,正如您所期望的那样。

关于riak - 当 riak-python-client 读取时,riak-java-client 存储的对象最终会变成原始 json?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15489167/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com