[英]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.