Struts中异步传送XML和JSON类型的数据

Linux大全评论734 views阅读模式

昨天和今天学习了XML和JSON型在struts2中的用法,当然,这需要与ajax结合起来使用,在项目中可以用到用户注册验证用户唯一性、无需刷新页面即可刷新部分数据等操作。

虽然就目前来说,JSON要比XML流行,但是可以预见的是,未来一段时间内,还是会有不少的企业依然会用到XML文件,故这里同时讲解了XML文件的生成和在JS中的解析。

我想熟悉Web的人大多数应该都会使用AJAX来与服务器进行异步的交互数据而不影响前台用户的使用,改善了用户体验。

关于用于生成XML和JSON格式数据的原理,我没有详细研究,后面随着学习的深入,我想我会进一步进行研究学习的。

下面开始说明原理:

前台页面通过ajax发请求到后台,根据请求数据创建要返回到前台的对象,然后将对象组装成XML或则JSON格式的数据,送回到前台,在JS中对返回的数据进行解析并显示到页面上。

这两个东西是一起进行学习的,所以对XML和JSON数据格式的学习,放到了同一个工程内。

第一步,新建web工程struts2-ajax,首先加入对应的jar包,总体工程结构及jar包如下:

第二步,配置web.xml文件,指定struts2的filter,配置文件信息如下:

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5"
 xmlns="http://java.sun.com/xml/ns/javaee"
 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
 http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>
  <filter>
  <filter-name>struts2</filter-name>
  <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
  </filter>
  <filter-mapping>
  <filter-name>struts2</filter-name>
  <url-pattern>*.action</url-pattern>
  </filter-mapping>
</web-app>
第三步,写界面,我这里为了省事期间,就直接在index.jsp中进行修改,代码如下:

index.jsp:

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
 

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title>My JSP 'index.jsp' starting page</title>
 <meta http-equiv="pragma" content="no-cache">
 <meta http-equiv="cache-control" content="no-cache">
 <meta http-equiv="expires" content="0">   
 <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
 <meta http-equiv="description" content="This is my page">
 <script type="text/javascript" src="scripts/jquery-1.4.4.js"></script>
 <script type="text/javascript">
  function getInfo(){
  $.post("getXMLAction.action",
  {
  name: $("#name").val()
  },function(returnedData, status)
  {
  alert(returnedData + "," + status);
  var name = $(returnedData).find("name").text();
  var age = $(returnedData).find("age").text();
  var height = $(returnedData).find("height").text();
  var address = $(returnedData).find("address").text();
  var html = "<table width='60%' border='1'>" +
  "<tr><td>name</td>" +
  "<td>age</td>" +
  "<td>height</td>" +
  "<td>address</td></tr><tr><td>" + name + "</td><td>" + age + "</td><td>" + height + "</td><td>" + address + "</td></tr></table>";
  $("body table:eq(0)").remove();
  $("body").append(html);
  }); 
  }
  function getJsonInfo() {
  $.post("getJSONAction.action", {name:$("#name").val()}, function(returnedData, status) {
    alert(returnedData);
    var html = "<table width='60%' border='1'>" +
  "<tr><td>name</td>" +
  "<td>age</td>" +
  "<td>height</td>" +
  "<td>address</td></tr><tr><td>" + returnedData.name + "</td><td>" + returnedData.age + "</td><td>" + returnedData.height + "</td><td>" + returnedData.address + "</td></tr></table>";
  $("body table:eq(0)").remove();
  $("body").append(html);
  });
  }
 
 </script>
  </head>
 
  <body>
  <select id="name">

 <option value="zhangsan">zhangsan</option>
 <option value="lisi">lisi</option>

企鹅博客
  • 本文由 发表于 2020年10月7日 10:18:16
  • 转载请务必保留本文链接:https://www.qieseo.com/178486.html

发表评论