问题描述
我很难弄清楚如何使用neomerx / json-api库建立关系。我尝试生成以符合给我的规格的响应如下:
{
"data": {
"id": 12345,"type": "group","relationships": {
"members": [
{
"data": {
"id": 12345,"type": "team"
},"meta": {
"roleId": 1
}
},{
"data": {
"id": 23456,"meta": {
"roleId": 2
}
}
]
}
}
}
但是我发现很难找到有关如何编码的信息,以便响应具有这种格式。当生成最终用于表示模型的资源数组时,我将这样做:
$oTeamModel = TeamMemberModel::getInstance($oResource);
$aRelationships[] = $oTeamModel;
在:: getRelationships()方法中,返回值为
return ['members' => [
BaseSchema::RELATIONSHIP_DATA => $aRelationships,BaseSchema::RELATIONSHIP_LINKS_SELF => false,BaseSchema::RELATIONSHIP_LINKS_RELATED => false,BaseSchema::RELATIONSHIP_META => [
['roleId' => 1],['roleId' => 2],['roleId' => 3],['roleId' => 4]
]
]];
(此外,关系元的元素旨在与$ aRelationships的关联元素相对应)
好吧,到目前为止一切都很好-大概我认为。但是,我的回复看起来像这样:
{
"data": {
"type": "group","id": "12345","relationships": {
"members": {
"data": [
{
"type": "acct","id": "10"
},{
"type": "acct","id": "12"
},"id": "14"
},"id": "16"
}
],"meta": [
{
"roleId": 1
},{
"roleId": 2
},{
"roleId": 3
},{
"roleId": 4
}
]
}
}
}
}
我做错什么了吗?还是没有办法如上所述生成响应?这种结构是否总是这样?
"relationships": {
"members": {
"data": [
],"meta": [
]
}
}
其中 data 和 meta 是成员的子代,而不是
"relationships": {
"members": [
{
"data": {
},"meta": {
}
},{
"data": {
},"meta": {
}
}
]
}
它们是每个成员元素的子项/属性。
我已经阅读了neomerx github wiki上的可用文档,但并未真正讨论关系元。我已经阅读了jsonapi规范,并且在#document-resource-object-relationships 部分中确实指出确实需要该字段的 data 键/属性。因此,实际上,最初给我的规范 应该看起来像这样:
"relationships": {
"members": {
"data": [
{
"data": {
},"meta": {
}
},{
"data": {
},"meta": {
}
}
]
}
}
同样,我给出了规格。但是即使如此,我的代码正在产生的现实似乎也无法代表我被指示要返回的东西。
回到我最初的问题:是否有一种方法可以使关系数组的每个元素都包含元信息,而不是包含关系数组?是否有可能使 data 和 meta 成为特定关系的子对象(按照我给的规范)?还是不符合json-api?
感谢您提供的任何帮助!
Christoph
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)