繁体   English   中英

Servlet对AJAX请求的响应为空

[英]Servlet response to AJAX request is empty

我正在使用javascript向servlet发送一个AJAX请求。 servlet确实在回复,但响应头是null,响应文本也是如此。

当我尝试相同的客户端代码而不是将请求发送到PHP页面时,它工作正常。

这是两个客户端(您可以尝试它们并查看它们的来源):

  • ajax-to-servlet:http: //79.136.61.27/web/ajax-to-servlet.html
  • ajax-to-php:http: //79.136.61.27/web/ajax-to-php.html

将请求发送到servlet时的输出是:

Response will go below

Response:

responseText was null!

Headers:

null response headers!

将请求发送到PHP时的输出是:

Response will go below

Response:

Hi from php

Headers:

Date: Sun, 17 Apr 2011 11:58:57 GMT Server: Apache/2.2.17 (Win32) PHP/5.3.6 X-Powered-By: PHP/5.3.6 Content-Length: 18 Keep-Alive: timeout=5, max=100 Connection: Keep-Alive Content-Type: text/html

这是servlet的代码。 正如您所看到的,我正在尝试设置标题和内容类型,但我的实验似乎都没有任何效果。 奇怪的是,我最近使用servlet做了一个hello world-example这样的例子,它工作得很好,没有弄乱标题和东西。 但现在它不再起作用了。 :(

package simple;

import java.io.IOException;
import java.io.PrintWriter;

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


public class SimpleServlet extends HttpServlet {

    private static final long serialVersionUID = -6713061702557291351L;

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        String out = "<p>Hi from servlet!</p>";

        response.setContentType("text/xml");
        response.setHeader("Cache-Control", "no-cache");
        System.out.println("got request");

        PrintWriter pw = response.getWriter();

        pw.write(out);
        pw.flush();
        boolean error = pw.checkError();
        System.out.println("Error? " + error);  
    }
}

hifromphp.php很简单:

<?php
    echo "<p>Hi from php</p>";
?>

感谢您提前阅读和感谢!

编辑:我意识到这些链接不会永远有效。 因此,出于存档目的,我在这里粘贴ajax-to-servlet.html。 除了请求所在的URL之外,ajax-to-php.html是相同的。 AJAX到中将Html.HTML:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" 
                    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
  <head>
    <title>Send ajax</title>
  </head>
  <body>
    <script type="text/javascript">
            /* <![CDATA[ */
            function getXMLHttp() {
                var xmlHttp = new XMLHttpRequest();

                return xmlHttp;
            }

            function sendAjax() {
                var xmlHttp = getXMLHttp();
                var divResp = document.getElementById("response");
                var divHdrs = document.getElementById("responseHeaders");

                xmlHttp.onreadystatechange = function() {
                    if (xmlHttp.readyState == 4) {
                        var hdrs = xmlHttp.getAllResponseHeaders();
                        var resp = xmlHttp.responseText;

                        divHdrs.innerHTML = "<p>Headers:</p><p>" + (hdrs ? hdrs : "null response headers!<p>");
                        divResp.innerHTML = "<p>Response:</p>" + (resp ? resp : "<p>responseText was null!<p>");
                    }
                }       

                xmlHttp.open("GET", "http://79.136.61.27:8080/SimpleServlet/SimpleServlet", true);
                xmlHttp.send(null);
            }
            /* ]]> */
        </script>
    <p><input type="button" value="Send Ajax" onclick="javascript: sendAjax();"/></p>
    <p>Response will go below</p>
    <div id="response"></div>
    <div id="responseHeaders"></div>
  </body>
</html>

如果你单独调用servlet它可以正常工作。 但是,servlet运行在与ajax请求来源不同的端口上。 这违反了ajax请求的同源策略 ,因此浏览器不会处理ajax响应。 除了在同一端口后面托管servlet之外,还需要返回JSONP或设置HTTP Access-Control标头。

如果要允许每个人使用servlet,请设置以下标头:

response.setHeader("Access-Control-Allow-Origin", "*");

链接响应头中的信息表明您正在运行Apache HTTPD和Apache Tomcat。 很高兴知道您可以使用Tomcat Connector将Apache HTTPD连接到Apache Tomcat,它可能更有用。

暂无
暂无

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

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