Jquery ajax请求Struts2 action 返回xml数据

本文介绍如何使用JQuery发起AJAX请求至Struts2 Action,通过两种方式接收并处理服务器返回的XML数据。一种是在Action直接输出XML;另一种是将数据传给JSP页面再返回XML。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Jquery 发送ajax请求,action 或servlet 处理请求,并以xml格式返回数据,交给jquery 处理。

1.jquery 发送请求:

 

var provinceurl="/Struts2/jquery/selectProvince.action";
 $.ajax({
      url:provinceurl,    
       type: 'POST', 
       dataType: 'xml',
       data: {name:"lixueli"},                
       timeout: 1000,                           
       error: function(){                      
       alert('Error loading XML document'); 
       }, 
       success: function(xml){            
        alert(xml);
        $(xml).find("province").each(function(){                            
            var provinceId=$(this).children("provinceid").text();       
            var provinceName=$(this).children("provinceName").text();
            var tempOption = document.createElement("option"); 
       tempOption.value = provinceId;
       tempOption.innerHTML  = provinceName; 
       province.append(tempOption);
        });
      } 
  });

 

 

2.struts2 action 处理请求

  可以有两种方式返回数据

  (1)直接在action中输出

    

 public String selectProvince() throws  IOException {
    response.setContentType("text/xml;charset=utf-8"); //(1)一定要在(2)的前面,不然会乱码
    response.setCharacterEncoding("UTF-8"); //(2)
    response.setHeader("Cache-Control", "no-cache"); 
    PrintWriter out=response.getWriter();         //(3)一定要在(1)(2)的后面
    ProvinceDAO provinceDAO = new ProvinceDAO();
    List<Province> list = provinceDAO.getAllProvince();
   StringBuilder sb=new StringBuilder();
   sb.append("<?xml version='1.0' encoding='UTF-8'?><provinces>");//最外层节点唯一,不然报错
   for(Province p:list)
  {
    sb.append("<province>");
    sb.append("<provinceid>"+p.getProvinceId()+"</provinceid>");
    sb.append("<provinceName>"+p.getProvinceName()+"</provinceName>");
    sb.append("</province>");
  }
  sb.append("</provinces>");
  out.print(sb.toString());
  out.flush();
 out.close();
return null;
}
   

 

这种方法不用返回结果。

<struts>
  <include file="struts-default.xml"/>
  <package name="/jquery" extends="struts-default" namespace="/jquery">
  <action name="selectProvince" class="com.hyts.business.action.xml.JqueryXmlAction" method="selectProvince">
   </action>
 </package>
</struts>

 

 

 (2)把数据输出到页面

 request.setAttribute("provinces", list);//前台页面取得数据

 jsp页面代码:

<?xml version='1.0' encoding='UTF-8'?>//一定放在页面开始位置,否则会报解析错误
<%@ page language="java" contentType="text/xml; charset=UTF-8" pageEncoding="UTF-8"%>
<%@page import="com.hyts.util.*,java.util.*"%>
 <%
    List<Province> provinces = (List<Province>)request.getAttribute("provinces");
 %>
<provinces>
<%
   for(Province p:provinces)
   {
%>
   <province>
     <provinceid><%=p.getProvinceId()%></provinceid>
     <provinceName><%=p.getProvinceName()%></provinceName>
   </province>
<%  
   }
%>
    
</provinces>

 

 

返回到页面的配置

struts.xml配置

<struts>
  <include file="struts-default.xml"/>
  <package name="/jquery" extends="struts-default" namespace="/jquery">
  <action name="selectProvince" class="com.hyts.business.action.xml.JqueryXmlAction" method="selectProvince">
     <result name="success">/jqueryxml/provinces.jsp</result>//数据先传递到页面
  </action>
 </package>
</struts>

 

 

 

内容概要:本文详细介绍了如何使用STM32微控制器精确控制步进电机,涵盖了从原理到代码实现的全过程。首先,解释了步进电机的工作原理,包括定子、转子的构造及其通过脉冲信号控制转动的方式。接着,介绍了STM32的基本原理及其通过GPIO端口输出控制信号,配合驱动器芯片放大信号以驱动电机运转的方法。文中还详细描述了硬件搭建步骤,包括所需硬件的选择与连接方法。随后提供了基础控制代码示例,演示了如何通过定义控制引脚、编写延时函数和控制电机转动函数来实现步进电机的基本控制。最后,探讨了进阶优化技术,如定时器中断控制、S形或梯形加减速曲线、微步控制及DMA传输等,以提升电机运行的平稳性和精度。 适合人群:具有嵌入式系统基础知识,特别是对STM32和步进电机有一定了解的研发人员和技术爱好者。 使用场景及目标:①学习步进电机与STM32的工作原理及二者结合的具体实现方法;②掌握硬件连接技巧,确保各组件间正确通信;③理解并实践基础控制代码,实现步进电机的基本控制;④通过进阶优化技术的应用,提高电机控制性能,实现更精细和平稳的运动控制。 阅读建议:本文不仅提供了详细的理论讲解,还附带了完整的代码示例,建议读者在学习过程中动手实践,结合实际硬件进行调试,以便更好地理解和掌握步进电机的控制原理和技术细节。同时,对于进阶优化部分,可根据自身需求选择性学习,逐步提升对复杂控制系统的理解。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值