【问题标题】:Pure Javascript fetch() method to java Servlet, how do i get and pass data?纯 Javascript fetch() 方法到 java Servlet,我如何获取和传递数据?
【发布时间】:2023-03-13 22:52:01
【问题描述】:

我在尝试从 Servlet 获取数据时遇到问题。 当我通过以下方式调用 servlet 时:

function urlFetchRequest(str, body = null, RequestType = 'GET'){
    try
    {
        asyncRequest = new XMLHttpRequest();
        asyncRequest.addEventListener("readystatechange", stateChange, false);
        asyncRequest.open(RequestType, str, true);    //   /Test is url to Servlet!
        asyncRequest.send(body);
    }
    catch(exception)
    {
        alert("Request failed");
    }
}

我从 Servlet 中取回我需要的信息,并且可以通过以下方式使用它:

jsonRes = JSON.parse(asyncRequest.responseText)

这是工作。我的问题是当我需要将数据传递给 servlet 时。所以我尝试用 fetch() 来做,因为我已经读过我可以将 JSON 对象用于 servlet(同样,我不能使用任何 javascript 库,如 jquery)并且我不能使用 servlet 返回的数据。它变得“未定义”。

我使用的 javascript 范围:

 function newFetch(url, options){
    fetch(url, options).then(async (res) => {
        if(res.ok){
            jsonRes = res.
            if(theSurvey === null) {
                surveyLength = Object.keys(jsonRes).length;
                theSurvey = jsonRes;
            }
        }
    });
}

我从这里调用它:

returnedObject.SurveyLoader = async () => {
    //urlFetchRequest("/SurveyServlet");
    //await SurveyResults();
    newFetch("/SurveyServlet", {
        method: "GET",
        headers: headers,
    })
}

我的 servlet 是:

@WebServlet(name = "SurveyServlet", urlPatterns = {"/SurveyServlet"} )
public class SurveyServlet extends HttpServlet {
    public static final Logger LOGGER = Logger.getLogger("SurveyServlet");
    private BufferedReader m_reader;
    private String m_line;
    public String convertWithStream(Map<String, String> map) {
        String mapAsString = map.keySet().stream()
                .map(key -> '\"' + key + '\"' +  ":" + '\"' + map.get(key) + '\"')
                .collect(Collectors.joining(", ", "{", "}"));
        return mapAsString;
    }

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

    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        Map<String, String> SurveyObj = new LinkedHashMap<>();
        m_reader = new BufferedReader(new FileReader(getServletContext().getRealPath("/poll.txt")));
        m_line = m_reader.readLine();
        SurveyObj.put(Integer.toString(0), m_line);

        int id = 1;
        while((m_line = m_reader.readLine())!=null) {
            SurveyObj.put(Integer.toString(id), m_line);
            ++id;
        }
        String str = convertWithStream(SurveyObj);
        response.setContentType("application/json");
        response.setCharacterEncoding("UTF-8");


        //request.setAttribute("ArraySize", id);
       // getServletContext().getRequestDispatcher("ResultServlet").forward(request,response);
        PrintWriter out = response.getWriter();
        out.write(str);
        out.flush();
        out.close();

    }
}

我的问题是关于 fetch 方法。我知道它从 REST API 获取对象。如何使用它从 servlet 传递和获取数据?如何使用发送到 servlet 的数据? 如果不可能,如何使用 XMLHttpRequest 将数据传递给 servlet? (不使用 $)

谢谢。

【问题讨论】:

  • @Pakira 嗨,谢谢。如果我知道如何在 servlet 上使用它,它可能会有所帮助。如何访问并将其更改为 servlet 响应?

标签: javascript java servlets


【解决方案1】:

它并没有完全回答我的问题,但大部分是: 我成功地找到了一种将 JSON 对象发送到我的 ajax 客户端的方法。

我在客户端使用了这个(url 是我的 servlet 名称,选项仅包含标题(内容类型等):

 function newFetch(url, options){
    fetch(url, options).then(res => res.json()
    ).then((resp) => {
        jsonRes = resp;
        if (theSurvey === null) {
            surveyLength = Object.keys(jsonRes).length;
            theSurvey = jsonRes;
            SurveyResults();
        }
    });

}

在 servlet 中,我使用 javax 库来使用 JSON 对象方法,这样:

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    Map<String, String> SurveyObj = new LinkedHashMap<>();
    m_reader = new BufferedReader(new FileReader(getServletContext().getRealPath("/poll.txt")));
    m_line = m_reader.readLine();
    SurveyObj.put(Integer.toString(0), m_line);

    int id = 1;
    while((m_line = m_reader.readLine())!=null) {
        SurveyObj.put(Integer.toString(id), m_line);
        ++id;
    }
    JsonObjectBuilder builder = Json.createObjectBuilder();
    SurveyObj.forEach(builder::add);
    JsonObject obj = builder.build();
   // String str = convertWithStream(SurveyObj);
    response.setContentType("application/json");
    response.setCharacterEncoding("UTF-8");
    try (OutputStream out = response.getOutputStream()) {
        JsonWriter jsonW = Json.createWriter(out);
        jsonW.write(obj);
        jsonW.close();
    }
}

我希望它会在未来对某人有所帮助。无论如何,我仍然面临将 JSON 对象发送到 servlet 并通过我的请求访问它的问题。如果有人可以提供帮助 - 这将是完美的。如果我能找到答案,我会编辑帖子。

谢谢。

编辑:经过大量搜索和尝试,我找到了将数据传递给 servlet 的最佳方法: 1. 在你的 servlet 中添加这个注解:@MultipartConfig 2.在你的客户端,使用“FormData”,就可以在请求体中通过fetch发送:

    let formData = new FormData();
    formData.append("size", surveyLength.toString());
    newFetch('ServletResults', {
        method: "POST",
        //headers: headers,
        body: formData

并且因为@MultipartConfig的注解,servlet知道如何通过“request.getParameter”访问参数

我希望这对将来的某人有所帮助。谢谢大家。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2018-01-04
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-11-01
    • 1970-01-01
    • 1970-01-01
    • 2016-05-30
    相关资源
    最近更新 更多