gpt4 book ai didi

java - 如何连接 OSGI 包(通过包发送实体)?

转载 作者:行者123 更新时间:2023-12-02 09:53:16 24 4
gpt4 key购买 nike

我有一个 REST 服务,它在一个模块( bundle )中包含三个类User.java -> 实体UserService.java -> REST 服务UserValidation.java -> 实体的特殊 validator 。服务器将实体发送到此 validator 并获取验证结果(true 或 false):

User.java

@XmlRootElement(name = "User")
public class User {
private long id;
private String name;
private String surname;
private String patronymic;

/*Getters and Setters*/
}

UserService.java

public class UserServiceImpl implements UserService {

private UserDAO userDbDao = new UserDatabaseDAO();

@POST
@Path("/users/")
public Response addUser(User user) {
UserValidator userValidator = new UserValidator(user);
if (userValidator.isValid()) {
User newUser = userDbDao.createUser(user);
return Response.ok().type("application/xml").entity(newUser).build();
} else {
return Response.status(Response.Status.BAD_REQUEST).entity(userValidator.getErrorMessage()).build();
}
}
}

UserValidator.java

public class UserValidator {
private static final int MAX_SIZE_NAME = 50;
private static final int MIN_SIZE_NAME = 2;
private User user;

public UserValidator(User user) {
this.user = user;
}

private BadUserResponse badUserResponse = new BadUserResponse();

private boolean isNameValid(String name) {
if (name == null) {
badUserResponse.setNsp("Null in fields name/surname/patronymic");
return false;
}
String tempName = name.trim();
if (tempName.length() < MIN_SIZE_NAME || tempName.length() > MAX_SIZE_NAME) {
badUserResponse.setNsp(String.format("Fields name/surname/patronymic too long or too short (Allowed length from %d to %d)", MIN_SIZE_NAME, MAX_SIZE_NAME));
return false;
}
for (int i = 0; i < tempName.length(); i++) {
if (!Character.isLetter(tempName.charAt(i))) {
badUserResponse.setNsp("Fields name/surname/patronymic contains wrong symbols (Only letters allowed)");
return false;
}
}
return true;
}
public boolean isValid() {
return (isNameValid(user.getName()) &
isNameValid(user.getSurname()) &
isNameValid(user.getPatronymic()));
}

public BadUserResponse getErrorMessage() {
return badUserResponse;
}

BadUserResponse.java

@XmlRootElement(name="baduserresponce")
public class BadUserResponse {
private String nsp;

public String getNsp() {
return nsp;
}

public void setNsp(String nsp) {
this.nsp = nsp;
}
}

但现在,我需要将其分成单独的包。因为,正如您所看到的,它们使用彼此的功能。例如UserService.java刚刚使用了这个UserValidator userValidator = new UserValidator(user);

我需要以某种方式连接这些包(OSGI 服务、ActiveMQ)。

在我看来,它的工作原理是这样的:

  1. UserService bundle 从 REST 方法获取 User 实体。
  2. 将所有用户字段(姓名、父名)放入 ActiveMQ 队列(因为 UserValidator 包不知道用户实体是什么)。
  3. UserValidator bundle 从队列中获取用户的字段并验证它们。
  4. UserValidator bundle 将验证结果(真/假)放入队列。
  5. UserService bundle 从队列中获取验证结果并将 User 发送到 DAO。

但这只是一个概念。我错了吗?

通过 bundle 传递实体的最佳方式是什么?我应该如何执行此操作?

最佳答案

您目前通过 new 简单启动 UserValidator 的方式在技术上是没问题的,即使它们位于不同的包中。如果您的 validator 仅在这个地方需要并且很简单,我什至会将其保留在同一个包中。

其他选项可以有效地解耦您的 bundle 。使用消息传递可以让您避免同步调用。它还可用于将数据发送到远程计算机。不过,JMS 消息传递的重量相当大。您需要一个经纪人并依赖 API。在您的情况下,您还直接需要验证结果。因此,您可以使用 JMS 模拟同步调用。所以我宁愿避免这种情况。

使用 OSGi 服务可以让您与服务的实现解耦。在这种情况下,为 UserValidator 创建一个接口(interface)是有意义的。我还会将此接口(interface)放入一个单独的包中。然后,您需要在实现 validator 的 bundle 中注册服务,并将该服务绑定(bind)在使用 validator 的 bundle 中。 OSGi 服务非常轻量并且默认是同步的。所以我认为它们很适合你的问题。对于注册和绑定(bind)服务,不要直接使用 OSGi API。相反,使用带有注释的声明性服务。它们消除了处理 OSGi 服务的大部分复杂性。

顺便说一句。我不确定你如何休息。我建议看看 Aries JAX-RS Whiteboard。

关于java - 如何连接 OSGI 包(通过包发送实体)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56163911/

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