繁体   English   中英

如何连接OSGI捆绑软件(通过捆绑软件发送实体)?

[英]How to connect OSGI bundles (Send entity though bundles)?

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

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捆绑包从REST方法获取用户实体。
  2. 将所有用户字段(名称,姓氏,用户名)放入ActiveMQ队列中(因为UserValidator包不知道用户实体是什么)。
  3. UserValidator捆绑包从队列中获取用户的字段并进行验证。
  4. UserValidator捆绑软件将验证结果(true / false)放入队列。
  5. UserService捆绑包从队列中获取验证结果,并将User发送到DAO。

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

通过实体传递实体的最佳方法是什么?我该怎么做?

您当前通过new初始化UserValidator的简单方法在技术上是可以的,即使它们位于不同的捆绑软件中。 如果只在这个地方需要您的验证器并且很简单,我什至会将其放在同一包中。

其他选项可以使束分离。 使用消息传递可以避免同步呼叫。 它也可以用于将数据发送到远程计算机。 但是,JMS消息传递非常重要。 您需要经纪人并依赖API。 在您的情况下,您还直接需要验证的结果。 因此,您可以使用JMS模拟同步调用。 所以我宁愿避免这种情况。

使用OSGi服务可以使您与服务的实现脱钩。 在这种情况下,为UserValidator创建接口是有意义的。 我还将这个接口放在一个单独的包中。 然后,您需要在实现验证程序的捆绑软件中注册服务,并将服务绑定在使用验证程序的捆绑软件中。 OSGi服务的重量很轻,默认情况下是同步的。 因此,我认为它们非常适合您的问题。 对于注册和绑定服务,请勿直接使用OSGi API。 而是使用带注释的声明式服务。 它们消除了处理OSGi服务的大部分复杂性。

顺便说一句。 我不确定您如何进行REST。 我建议看看Aries JAX-RS白板。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM