javascript - AJAX 请求中的 Null 或空 JSON 对象

标签 javascript java json ajax servlets

最终删除了我之前发布的与此相关的另一个问题,因为它已经过时并且还有另一件事需要解决。下面的答案非常清楚,比其他答案更清楚,我相信这会对其他有类似困惑的人有所帮助。

本质上我想在 Java 中使用来自客户端 JS 的字符串。下面的 JS 警报工作正常,但是我的 Servlet 中的 JSON 对象为 null 或为空。我实际上只需要传递一个字符串到我的 servlet,这样我就可以运行 SQL 查询,但我遇到了很多麻烦。

谢谢!

html 文件

       <div class="jumbotron" id="jumboframe">
            <h1>Enter your URL below</h1>
            <input class="txtUrl" type="text" id="txtUrl" value="...." onfocus="if(this.value == '....') { this.value = ''; }"/>
            <p><a class="btn btn-lg submitButton" href="testpage.html" onclick="getURL()" role="button">Start searching!</a></p>
        </div>

        <script>
            function getURL() {
                var urlString = document.getElementById("txtUrl").value;
                var params = {url: urlString};


            $.ajax({
                    type: "POST",
                    url: "testpage.html",
                    contentType: "application/json",
                    dataType: "text", // "JSON" here doesn't call alerts below
                    data: {
                        'url': urlString
                    },

                    success: function(data) {
                        alert("did it!");
                        alert(JSON.stringify(params));
                        alert(JSON.stringify(data));
                    }
                });
            }
        </script>

Java servlet

public class JavaServlet extends HttpServlet {

private static final long serialVersionUID = 1L;

public void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException {

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

    PrintWriter out = response.getWriter();

    StringBuilder builder = new StringBuilder();
    BufferedReader reader = request.getReader();
    String line;
    while ((line = reader.readLine()) != null) {
        builder.append(line);
    }

    out.println(builder.toString());
    String url = request.getParameter("url");
    Map<String, String[]> map = request.getParameterMap();  // empty {}
    out.println(map.toString());  // null
    out.println(url);  // null

web.xml

  <servlet>
      <servlet-name>JavaServlet</servlet-name>
      <servlet-class>path.to.my.JavaServlet</servlet-class>
  </servlet>
  <servlet-mapping>
    <servlet-name>JavaServlet</servlet-name>
    <url-pattern>/testpage.html</url-pattern>
  </servlet-mapping>

再次感谢

最佳答案

如果你想从请求数据中获取 Json,那么你应该将其作为 String 传递,然后,你的 html 可能如下所示(我已将 servlet 路径更改为 JavaServlet.do)

<div class="jumbotron" id="jumboframe">
            <h1>Enter your URL below</h1>
            <input class="txtUrl" type="text" id="txtUrl" value="...." onfocus="if(this.value == '....') { this.value = ''; }"/>
            <p><a class="btn btn-lg submitButton" href="#" onclick="getURL()" role="button">Start searching!</a></p>
        </div>

        <script>
            function getURL() {
                var urlString = document.getElementById("txtUrl").value;
                var params = {url: urlString};

                var jsonDataStr = JSON.stringify(params); // Here you get the json String
            $.ajax({
                    type: "POST",
                    url: "JavaServlet.do",
                    contentType: "application/json",
                    dataType: "text", // "JSON" here doesn't call alerts below * Because the servlet thrown an error, you should handle it *
                    data: jsonDataStr,
                    success: function(data) {
                        alert("Your URL is " + data); // **get the response text**
                        alert("Handle it");
                    },
                    error: function(data) { // Handle the error
                        alert(data.error().getResponseHeader());
                    }
                });
            }
        </script>

现在,JavaServlet 将收到一个 Json 作为字符串,您必须解析它(使用 Gson 等第三方库)。

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

    PrintWriter out = response.getWriter();

    StringBuilder builder = new StringBuilder();
    BufferedReader reader = request.getReader();
    String line;
    while ((line = reader.readLine()) != null) {
        builder.append(line);
    }

    String jsonString = builder.toString(); // get the json from client
    UrlDto urlDto = new Gson().fromJson(UrlDto.class,jsonString); // parse you json to Java object
    String yourUrl = urlDto.getUrl();
    out.print(yourUrl); // **Set the response text**
    out.close();        

WEB.XML 和 UrlDto

class UrlDto {
    private String url;
    // G&S ...
}

    <servlet>
        <servlet-name>JavaServlet</servlet-name>
        <servlet-class>servlet.JavaServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>JavaServlet</servlet-name>
        <url-pattern>/JavaServlet.do</url-pattern>
    </servlet-mapping>

希望对你有帮助

关于javascript - AJAX 请求中的 Null 或空 JSON 对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36973939/

相关文章:

javascript - 基于滚动高度的淡入/淡出

java - 文件上传在 Jetty 下工作,但在 Tomcat 下不工作

json - 折叠 JSON 字符串的正确语法是什么?

java - 如何将 XML 文件转换为 json

java - 在 groovy 中读取 Excel 文件的最简单方法?

c# - JSON 值无法转换为 System.Int32

javascript - Angular2/Ionic - 查找数组中的重复项并组织它们

javascript - 解析 SDK saveAll promise 链接

javascript - JS OOP 内置对象数组

java - 为什么我们使用抽象