繁体   English   中英

将数据从 servlet javaEE 发送到角度组件

[英]sending data from a servlet javaEE to an angular component

我是 javaEE 的初学者,我在 FrontEnd 中使用 angular,在 BackEnd 中使用 javaEE。我想将数据从 servlet 发送到 angular 组件,我想知道是否有可能我应该在我的 servlet 中包含什么指令,在这个例子中我想将用户列表(utilisateurs)发送到角度组件进行处理,这是我的 servlet 代码。 ps1:我在 angular 中使用模块 HttpClient。 ps2:我不使用 Spring 框架。

测试.java

package com.coors.servlets;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.octest.beans.Utilisateur;
import com.octest.dao.DaoFactory;
import com.octest.dao.UtilisateurDao;
import com.octest.dao.UtilisateurDaoImpl;

import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

@WebServlet("/test")
public class Test extends HttpServlet {
private static final long serialVersionUID = 1L;
private UtilisateurDao utilisateurDao;
private DaoFactory daoFactory; 

public Test() {
    super();
}

@Override
public void init() throws ServletException {
    daoFactory=DaoFactory.getInstance();
    utilisateurDao=daoFactory.getUtilisateurDao();
}

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    this.utilisateurDao.lister();//I  get the list of users

    //here what instruction ?????????????????????????????????????????
}

public void doPost( HttpServletRequest request, HttpServletResponse response ) throws ServletException, IOException {
}

}

假设我将这个 URL 称为http://localhost:8080/StackOverflow/test ,其中 test 是来自我的 servlet 的 urlPattern。 所以当我在浏览器中发送这个 URL 时,会触发 doGet 方法。 在 doGet 我可以这样做:

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    List<String> myList = new ArrayList<>();
    myList.add("User 1");
    myList.add("User 2");
    request.setAttribute("users", myList);
    request.getRequestDispatcher("second.jsp").forward(request, response);
}

我创建了一个列表,并在传递给名为 second.jsp 的现有页面的用户属性中设置内容。

如果您使用 Maven,请将其包含在您的依赖项中,以便您可以在 second.jsp 中使用 jstl 来查看内容。

https://mvnrepository.com/artifact/jstl/jstl/1.2

使用jstl,您可以使用${users} 访问属性“users”中的内容。

更多 jstl在这里

<%@ taglib uri = "http://java.sun.com/jsp/jstl/core" prefix = "c" %>
<!DOCTYPE html>  
<html lang="en">  
<head>  
<meta charset="utf 8">
<title>Aloha</title>     
</head>  
<body ng-app="app">
<h1 ng-controller="HelloWorldCtrl">{{message}}</h1>
<script src="https://code.angularjs.org/1.6.9/angular.js"></script>
<script>  
angular.module("app", []).controller("HelloWorldCtrl", function($scope) {  
$scope.message="Hello JSP DATA: ${users}" 
} )
</script> 


通过这种方式,您可以将数据发送到页面并使用 ${yourparametername} 访问您的 Angular 应用程序。

结果:

在此处输入图片说明

如果您想使用来自 servlet 的响应,它可能看起来像这样编码用户而不是 & 或 = 符号来正确构建 URL:

    String urlUsers= "";
    for(String u : angularList) {
        urlUsers +=                      "users="+URLEncoder.encode(u,StandardCharsets.UTF_8.name())+"&";
    }
    urlUsers = urlUsers.substring(0,urlUsers.length()-1);

    response.sendRedirect("angular.jsp?"+urlUsers);

angular.jsp 页面中的 URL 将是:

http://localhost:8080/test/angular.jsp?users=User+1&users=User+2

现在它使用 Angular 从 URL 获取值。

暂无
暂无

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

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