为什么jquery ajax 返回的是整个页面的html

有点不解的是,有的地方这么使用就好好的,有的时候呢用就返回整个页面,参数设置都一样啊?神奇。

前台js:
function test() {
$.ajax({
type: 'POST',
url: 'isNumStr.aspx/GoldenRuleVerify',
async: false,
dataType: 'html',
data: { "isGoldenRuleVerify": 1 },
success: function (msg) {
alert(msg);
}
});
}

后台:
[WebMethod]
public static string GoldenRuleVerify(int isGoldenRuleVerify)
{
StringBuilder resultStr = new StringBuilder();
resultStr.Append("<option>21212<option>");
return resultStr.ToString();
}

返回的却是这样的:

大的方向确实是路径问题,通常项目中公司会对前端请求的路径做一个后缀名称的验证。如:正常的接口=》queryMeetingList.ajax 但在请求时我们公司要改成queryMeetingList.webApp才行。具体每个公司怎么处理都不同。不过大的方向可以说是路径问题。
温馨提示:答案为网友推荐,仅供参考
第1个回答  2018-03-30

解决方法是关闭response的writer。

下面是ajax代码

$j.ajax({
type : "POST",
url : "/asi/jsonCarrier.jsp",
data : {"artistId":"${artistID}"},  //这里从session里拿出了artistID变量,用的是el表达式
datatype : "text",
timeout: 10000,
success : function(data) {
if (data!="" && data!=null){
var dataArr = data;
var jsonData = dataArr.statistics;
var priceData = [];
var volumeData = [];
var summaryData = [];
$j.each(jsonData, function(i, dataItem) {
priceData[i] = [ i, dataItem.beta ];
volumeData[i] = [ i, dataItem.volume ];
summaryData[i] = [ i, dataItem.volatility ];

});
$j("#artistName").html(dataArr.meta.artist_forename+" "+dataArr.meta.artist_surname);
displayGraph(jsonData, priceData, volumeData, summaryData);
}
},
error : function(XMLHttpRequest, textStatus, errorThrown){
alert(textStatus);
}
})

下面是 jsonCarrier.jsp里的java代码

<%
String artistId = request.getParameter("artistId");
String jsonData = DBSightXmlUtil.getXmlFromServer("http://aaa.com/json/asi-artist-"+ artistId + "-y.json");

response.setContentType("application/json");
response.getWriter().flush();
response.getWriter().write(jsonData);
response.getWriter().close();  //这里就是关键

%>

本回答被网友采纳
第2个回答  2016-12-07
有可能是ajax的url写错了,我今天也是这个问题,路径改完后就没事了
第3个回答  2015-11-13
检查下 后端 是否有输出 比如var_dump(); 之类的

ajax 请求的接口部分 不能有输出动作
第4个回答  2018-02-03
也是返回html页面代码
原来是是自己吧ajax里面的url写成uel了 哈哈哈哈 所以就是找不到文件
改成url就好了 哈哈哈哈 不行还要 加强 啊