我有一个REST服务,该服务在一个模块中包含三个类(捆绑) User.java->实体 UserService.java-> REST服务 UserValidation.java->实体的特殊验证器。服务器将实体发送到此验证器,并获取验证结果(对或错):
User.java
name: flutterwebdemo
description: An app built using Flutter for web
environment:
# You must be using Flutter >=1.5.0 or Dart >=2.3.0
sdk: '>=2.3.0-dev.0.1 <3.0.0'
dependencies:
flutter_web: any
flutter_web_ui: any
dev_dependencies:
build_runner: ^1.4.0
build_web_compilers: ^2.0.0
pedantic: ^1.0.0
dependency_overrides:
flutter_web:
git:
url: https://github.com/flutter/flutter_web
path: packages/flutter_web
flutter_web_ui:
git:
url: https://github.com/flutter/flutter_web
path: packages/flutter_web_ui
UserService.java
@XmlRootElement(name = "User")
public class User {
private long id;
private String name;
private String surname;
private String patronymic;
/*Getters and Setters*/
}
UserValidator.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();
}
}
}
BadUserResponse.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;
}
但是现在,我需要将其拆分为单独的捆绑包。如您所见,因为它们彼此使用功能。例如 UserService.java
刚刚使用了这个@XmlRootElement(name="baduserresponce")
public class BadUserResponse {
private String nsp;
public String getNsp() {
return nsp;
}
public void setNsp(String nsp) {
this.nsp = nsp;
}
}
我需要以某种方式连接这些捆绑软件(OSGI服务,ActiveMQ)。
我认为它的工作原理如下:
但这只是一个概念。我错了吗?
通过捆绑包传递实体的最佳方法是什么?
答案 0 :(得分:1)
您当前通过new初始化UserValidator的方式从技术上讲还可以,即使它们位于不同的捆绑软件中。如果仅在这个地方只需要您的验证器,并且很简单,我什至会将其放在同一包中。
其他选项可以使束分离。使用消息传递可以避免同步呼叫。它也可以用于将数据发送到远程计算机。但是,JMS消息传递非常重要。您需要经纪人并依赖API。在您的情况下,您还直接需要验证的结果。因此,您可以使用JMS模拟同步调用。所以我宁愿避免这种情况。
使用OSGi服务可以使您与服务的实现脱钩。在这种情况下,为UserValidator创建接口是有意义的。我还将这个接口放在一个单独的包中。然后,您需要在实现验证程序的捆绑软件中注册服务,并将服务绑定在使用验证程序的捆绑软件中。 OSGi服务的重量很轻,默认情况下是同步的。因此,我认为它们非常适合您的问题。 对于注册和绑定服务,请勿直接使用OSGi API。而是使用带注释的声明式服务。它们消除了处理OSGi服务的大部分复杂性。
顺便说一句。我不确定您如何进行REST。我建议看看Aries JAX-RS白板。