action响应ajax请求返回JSON类型
我在用ajax向action发送请求时,可以响应请求,但是ajax在获取数据时,获取不了json类型的数据,不知道是哪里出了问题。代码如下:
jsp代码:
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.8.0/jquery.min.js"></script>
<script type="text/javascript">
function change(proCode){
alert("1 "+proCode);
$('#proCode').val(proCode); //让第一个下拉框保持显示选中的值
$('#cityCode').html(""); //把ci内容设为空
var cityValue = $('#cityCode');
cityValue.append('<option value="">选择CITY</option>');
$.ajax({
url: '/GP/address.action?proCode='+proCode, type: 'post', //
data: {},
dataType: 'json',
//async:false,
cache:false,
success: function(opts) {
alert(opts.length);
if (opts!=null && opts.length > 0) {
var html = [];
for (var i = 0; i < opts.length; i++) {
html.push('<option value="'+opts[i].cityCode+'">'+opts[i].cityName+'</option>');
}
cityValue.append(html.join(''));
}
},
error: function(){
alert("error !");
}
});
}
</script>
<body>
<table>
<tr>
<td width="10%"> 省份 </td>
<td width="30%">
<select name="province.proCode" id="proCode" onchange="change(this.value)">
<option value="0">--请选择所在省份--</option>
<s:iterator value="#request.prolist">
<option value="${proCode }">${proName }</option>
</s:iterator>
</select>
</td>
</tr>
<tr>
<td width="10%"> 城市 </td>
<td width="30%">
<select name="city.cityCode" id="cityCode">
<option value="0" >--city--</option>
</select>
</td> </tr>
</table>
</body>
</html>
action代码如下:
package action;
import java.io.PrintWriter;
import java.io.Writer;
import java.util.List;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import net.sf.json.JSONArray;
import org.apache.struts2.ServletActionContext;
import service.odservice.ICityService;
import service.odservice.IProvinceService;
import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionSupport;
import entity.City;
import entity.Province;
public class AddressAction extends ActionSupport {
/**
*
*/
private static final long serialVersionUID = 1L;
private IProvinceService proService;
private ICityService cityService;
private String proCode;
private String opts;
public String getProCode() {
return proCode;
}
public void setProCode(String proCode) {
this.proCode = proCode;
}
public String getOpts() {
return opts;
}
public void setOpts(String opts) {
this.opts = opts;
}
public IProvinceService getProService() {
return proService;
}
public void setProService(IProvinceService proService) {
this.proService = proService;
}
public ICityService getCityService() {
return cityService;
}
public void setCityService(ICityService cityService) {
this.cityService = cityService;
}
public String selectAddress() throws Exception {
if(proCode==null)proCode="";
System.out.println("proCode="+proCode);
List<City> citylist = cityService.findByProCode(proCode);
List<Province> prolist = proService.searchAll();
if(proCode!=null&&proCode!="")
System.out.println(citylist.get(0).getCityName());
HttpServletRequest request = ServletActionContext.getRequest();
request.setAttribute("citylist", citylist);
request.setAttribute("prolist", prolist);
HttpServletResponse response = ServletActionContext.getResponse();
response.setContentType("application/json");
response.setCharacterEncoding("UTF-8");
PrintWriter writer = response.getWriter();
JSONArray array = JSONArray.fromObject(citylist);
opts = array.toString();
writer.print(opts);
return SUCCESS;
}
}