簡體   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