Java 构建具有动态内容的Vaadin web应用程序

Java 构建具有动态内容的Vaadin web应用程序,java,vaadin,vaadin8,Java,Vaadin,Vaadin8,我正试图通过Vaadin(vaadinframework8)创建一个web应用程序 我读了好几页文档,但仍然存在有关Vaadin应用程序结构的大问题。我的问题是,我缺乏它背后的理论,我将尝试通过第一次代码尝试暴露我的问题。我真的很感激任何能帮助我理解瓦丁是如何工作的 我想创建一个网站,用户可以注册,登录和注销 网站GUI的结构是一个主页,其中有一个按钮或类似的东西,用于在用户未登录时进行登录,如果用户已登录,而不是登录按钮,则应显示一个注销按钮 首先,我有一个扩展UI的类;在该类中,我设置了se

我正试图通过Vaadin(vaadinframework8)创建一个web应用程序

我读了好几页文档,但仍然存在有关Vaadin应用程序结构的大问题。我的问题是,我缺乏它背后的理论,我将尝试通过第一次代码尝试暴露我的问题。我真的很感激任何能帮助我理解瓦丁是如何工作的

我想创建一个网站,用户可以注册,登录和注销

网站GUI的结构是一个主页,其中有一个按钮或类似的东西,用于在用户未登录时进行登录,如果用户已登录,而不是登录按钮,则应显示一个注销按钮

首先,我有一个扩展UI的类;在该类中,我设置了servlet和
init()
方法

init()
方法中,我开始创建一个
VerticalLayout()
,然后创建一个
MenuBar
和一个
Panel
(称为contentPanel)。然后,我创建一个
导航器
。我遇到的第一个问题是,我理解导航器是在不同页面之间浏览的一种可能性;导航器的构造函数需要一个
SingleComponentContainer
,所以现在我不知道如何在不同的网页之间导航。例如,在构造函数中,我使用面板:
newnavigator(这是contentPanel)然后我添加不同的
视图
,这些视图将显示在面板中。最后,我导航到
欢迎
页面

MyUI类:

public class MyUI extends UI {

    /**
     * Class that checks if the user is in the database 
     * and the psw inserted is correct
     */
    public static Authentication AUTH;
    public static User user = null;

    @WebServlet(value = "/*", asyncSupported= true)
    @VaadinServletConfiguration(productionMode = false, ui = MyUI.class)
    public static class MyUIServlet extends VaadinServlet {
    }

    @Override
    protected void init(VaadinRequest request) {

        AUTH = new Authentication();

        VaadinSession.getCurrent().setAttribute("user", user);

        final VerticalLayout layout = new VerticalLayout();
        layout.setMargin(true);
        setContent(layout);

        Panel contentPanel = new Panel("Main Panel");
        contentPanel.setSizeFull();

        new Navigator(this, contentPanel);
        getNavigator().addView(LoginPage.NAME, LoginPage.class);
        getNavigator().setErrorView(LoginPage.class);
        getNavigator().addView(LogoutPage.NAME, LogoutPage.class);
        getNavigator().addView(WelcomePage.NAME, WelcomePage.class);

        MenuBar.Command welcome = new Command() {
            @Override
                public void menuSelected(MenuItem selectedItem) {
                    getNavigator().navigateTo(WelcomePage.NAME);
                }
        };

        MenuBar.Command login = new Command() {
            @Override
            public void menuSelected(MenuItem selectedItem) {
                getNavigator().navigateTo(LoginPage.NAME);
            }
        };

        MenuBar.Command logout = new Command() {
            @Override
            public void menuSelected(MenuItem selectedItem) {
                getNavigator().navigateTo(LogoutPage.NAME);
            }
        };

        MenuBar mainMenu = new MenuBar();
        mainMenu.addItem("Welcome", VaadinIcons.ARROW_CIRCLE_LEFT, welcome);
        mainMenu.addItem("Login", VaadinIcons.ENTER, login);
        mainMenu.addItem("Logout", VaadinIcons.EXIT, logout);

        layout.addComponent(mainMenu);
        layout.addComponent(contentPanel);

        getNavigator().navigateTo(WelcomePage.NAME);

    }

}
登录页面类别:

public class LoginPage extends VerticalLayout implements View {

    private static final long serialVersionUID = 1L;
    public static final String NAME = "loginpage";

    public LoginPage(){

        Panel panel = new Panel("Login");
        panel.setSizeUndefined();
        addComponent(panel);

        FormLayout content = new FormLayout();
        TextField username = new TextField("Username");
        content.addComponent(username);
        PasswordField password = new PasswordField("Password");
        content.addComponent(password);

        Button send = new Button("Enter");

        send.addClickListener(new Button.ClickListener() {
            private static final long serialVersionUID = 1L;

            public void buttonClick(ClickEvent event) {

                //The authenticate method will returns
                //true if the credentials are correct
                //false otherwise
                if(MyUI.AUTH.authenticate(username.getValue(), password.getValue())){

                    //In AUTH there is a User field called "user"
                    //User is a class that represents an user (so it has mail, psw, name etc)
                    VaadinSession.getCurrent().setAttribute("user", MyUI.AUTH.getUser());

                }else{
                    Notification.show("Invalid credentials", Notification.Type.ERROR_MESSAGE);
                    }

                }
            });

        content.addComponent(send);
        content.setSizeUndefined();
        content.setMargin(true);
        panel.setContent(content);
        setComponentAlignment(panel, Alignment.MIDDLE_CENTER);

    }

}
注销类具有与登录类相同的结构;有一种注销方法:

private void doLogout() {

    MyUI.AUTH.setUser(null);
    VaadinSession.getCurrent().setAttribute("user", MyUI.AUTH.getUser());
    getSession().close();

}
另一个问题是:如何根据用户状态(是否登录?)在布局中动态添加组件

下一个问题是:我不明白如何有效地注销

我将添加完整的代码以方便任何测试

public class LogoutPage extends VerticalLayout implements View {

    private static final long serialVersionUID = 1L;
    public static final String NAME = "logoutpage";

    public LogoutPage(){

        Panel panel = new Panel("Logout");
        panel.setSizeUndefined();
        addComponent(panel);

        Button logout = new Button("Logout");
        logout.addClickListener(e -> doLogout());
        addComponent(logout);

    }

    private void doLogout() {

        MyUI.AUTH.setUser(null);
        VaadinSession.getCurrent().setAttribute("user", MyUI.AUTH.getUser());
        getSession().close();

    }

}

______________________________________________________________________________

public class WelcomePage extends VerticalLayout implements View {

    private static final long serialVersionUID = 1L;
    public static final String NAME = "welcomepage";

    public WelcomePage() {
        setMargin(true);
        setSpacing(true);
        Label welcome = new Label("Welcome");
        welcome.addStyleName("h1");
        addComponent(welcome);

    }

    @Override
        public void enter(ViewChangeEvent event) {
    }

}

______________________________________________________________________________

public class Authentication {

    private static User user = null;
    //those fields should be in user; this is just a test
    private String userID = "ID";
    private String psw = "psw";

    public Authentication() {
    }

    public void setUser(User user) {
        Authentication.user = user;
    }

    public User getUser(){
        return Authentication.user;
    }

    public Boolean authenticate(String userID, String psw){

        if(userID == this.userID && psw == this.psw) {
            user = new User();
            return true;
        }

        return false;

    }

}

我看到许多用户在为vaadin概念而挣扎

简而言之,它不是一个基于页面的框架,在这个框架中,您可以通过每次鼠标单击切换到一个新页面

相反,它更像是一个Swing应用程序,您只有一个gui实例,您可以在其中添加表单/按钮,修改它们,并根据用户交互删除它们。这就是我们所知道的

导航器主要用于允许用户使用webbrowser的后退/前进按钮导航到“上一页”页面或书签特定页面

提供有关此概念的更详细信息

要回答您的问题: -使用单页/浏览 -未登录时,显示模式登录弹出窗口 -当用户正确输入authentification时,删除弹出窗口并在垂直布局中显示主要内容 -当用户注销时,从垂直布局中删除内容


对于您的简单用例,无需使用Navigator或Views,我最初遇到了相同的问题,这让我对Spring产生了兴趣,最终对Vaadin4Spring产生了兴趣。即使您对使用Spring不感兴趣,也要检查一下。它将为您提供有关视图导航的一些见解,并且通过添加Vaadin4Spring侧栏,可以轻松控制对视图和菜单的访问。我相信权限很快就会成为您关注的焦点,这可能会很复杂

更新:有了瓦丁流,情况发生了根本性的变化。替代Vaadin 8 Navigator的in-Flow使用可书签的URL,为Vaadin单页应用程序提供网站感觉。