我尝试使用多态性来实现实体类。
这是我的BaseEntity
@Getter
@Setter
@Accessors(chain = true)
@MappedSuperclass
@NoArgsConstructor
@AllArgsConstructor
@EntityListeners(AuditingEntityListener.class)
public class BaseEntity {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@Size(max = 55, message = "name length more then 55")
private String name;
@Size(max = 255, message = "remark length more than 255")
private String remark;
}
还有我的实体
@Data
@NoArgsConstructor
@Table(name = "sys_user")
@Entity(name = "sys_user")
@Accessors(chain = true)
@ToString(callSuper = true)
@EqualsAndHashCode(callSuper = true)
public class SysUser extends BaseEntity implements Serializable {
@NonNull
private String username;
@NonNull
private String password;
}
在我的控制器中
@Controller
@GraphQLApi
@RequiredArgsConstructor
public class SysUserController implements BaseController {
private final SysUserRepository sysUserRepository;
@GraphQLQuery
public List<SysUser> sysUsers() {
return sysUserRepository.findAll();
}
}
我的GraphQL配置
@Configuration
@RequiredArgsConstructor
public class GraphQLConfig {
private final @NotNull List<BaseController> controllerLists;
@Bean
public GraphQLSchema graphqlSchema() {
GraphQLSchemaGenerator generator = new GraphQLSchemaGenerator();
generator.withOperationsFromSingletons(controllerLists.toArray());
return generator.generate();
}
}
现在,我尝试获得
{
sysUsers {
username
}
}
结果正确
{
"data": {
"sysUsers": [
{
"username": "Hello"
}
]
}
}
但是我尝试获取父类字段:
{
sysUsers {
name
}
}
我会得到一个错误
{
"errors": [
{
"message": "Validation error of type FieldUndefined: Field 'name' in type 'SysUser' is undefined @ 'sysUsers/name'",
"locations": [
{
"line": 3,
"column": 5
}
]
}
]
}
我使用io.leangen.graphql:graphql-spqr-spring-boot-starter:0.0.4
如何解决此问题?
谢谢!
答案 0 :(得分:0)
仅当继承的字段位于已配置的程序包中时,才会显示这些字段。这样,您就不会意外地暴露框架字段,JDK字段(如hashCode
等)。如果未配置任何基本包,则SPQR将保留在直接暴露的类所在的包中。
要配置基本软件包,请添加以下内容:
graphql.spqr.base-packages=your.root.package,your.other.root.package
到您的application.properties
文件。
注意:这些rules will get relaxed in the next release of SPQR,默认情况下会公开所有非JDK字段,因为当前行为似乎使太多人感到困惑。
答案 1 :(得分:0)
我建议您根据graphql模式中定义的类型添加自动生成的类。 它将使您更清楚地了解暴露给用户的内容,并避免将来发生此类错误。 这是插件: