• 在Struts2中使用JSON AJAX



    JSON插件提供了一种名为json的ResultType,一旦为某个Action指定了一个类型为json的Result,则该Result无需映射到任何视图资源。因为JSON插件会负责将Action里的状态信息序列化成JSON格式的数据,并将该数据返回给客户端页面的JavaScript。


      简单地说,JSON插件允许我们在JavaScript中异步调用Action,而且Action不再需要使用视图资源来显示该Action里的状态信息,而是由JSON插件负责将Action里的状态信息返回给调用页面——通过这种方式,就可以完成Ajax交互。

      Struts2提供了一种可插拔方式来管理插件,安装Struts2的JSON插件与安装普通插件并没有太大的区别,一样只需要将Struts2插件的JAR文件复制到Web应用的WEB-INF/lib路径下即可。

                                                                                                                                                         --------引用

    JSON插件下载地址:JSON插件下载

    框架结构为:struts2  jquery  JSON

    首先搭建struts2环境

    然后引入jar包  如下图:


    还需引入jquery.js文件

    整个项目结构图如下


    配置struts.xml

    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE struts PUBLIC
        "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
        "http://struts.apache.org/dtds/struts-2.0.dtd">
    
    <struts>
    
        <constant name="struts.enable.DynamicMethodInvocation" value="false" />
        <constant name="struts.devMode" value="false" />
    
        <package name="default" namespace="/" extends="json-default">
            <action name="loginAction" class="com.org.LoginAction">
               <result name="success" type="json"></result>
            </action>
        </package>
    
        <!-- Add packages here -->
    
    </struts>
    

    建立Action类  LoginAction.java
    package com.org;
    
    public class LoginAction {
    	private String username; //用户名
    	private String password; //密码
    	private String realname; //真实姓名
    	private String age;      //年龄
    	private String address;  //地址
    
    
    	public String getRealname() {
    		return realname;
    	}
    
    	public void setRealname(String realname) {
    		this.realname = realname;
    	}
    	public String getAge() {
    		return age;
    	}
    
    	public void setAge(String age) {
    		this.age = age;
    	}
    
    	public String getAddress() {
    		return address;
    	}
    
    	public void setAddress(String address) {
    		this.address = address;
    	}
    
    	public String getUsername() {
    		return username;
    	}
    
    	public void setUsername(String username) {
    		this.username = username;
    	}
    
    	public String getPassword() {
    		return password;
    	}
    
    	public void setPassword(String password) {
    		this.password = password;
    	}
    
    	
    	public String execute() {
    		
    		//我很郁闷  不知道JSON是怎么从这个Action中得到的数据
    		
    		//LoginAction login = new LoginAction();
    		
    		/*login.setUsername(username);
    		login.setPassword(password);
    		login.setRealname(realname);
    		login.setAddress(address);
    		login.setAge(age);*/
    		
    		//JSONObject obj = JSONObject.fromObject(login);
    		return "success";
    	}
    }
    

    前台页面 login.jsp
    <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
    <%@ page contentType="text/html; charset=utf-8"%>  <!-- 乱码 -->
    <%
    	String path = request.getContextPath();
    	String basePath = request.getScheme() + "://"
    			+ request.getServerName() + ":" + request.getServerPort()
    			+ path + "/";
    %>
    
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
    <html>
    	<head>
    		<base href="<%=basePath%>">
    
    		<title>My JSP 'login.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">
    		<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <!-- 还是乱码 -->
    		<!--
    	<link rel="stylesheet" type="text/css" href="styles.css">
    	-->
    	<script type="text/javascript" src="js/jquery-1.7.1.js"></script>
    	<script type="text/javascript" src="js/my.js"></script>
    
    	</head>
    
    	<body>
    	<%
    	   //竟然还是TMD乱码
    	   response.setContentType("text/html;charset=utf-8");
    	   request.setCharacterEncoding("utf-8");
    	%>
    	<div id="msg"></div>  <!-- 用于显示信息 -->
    	<form action="" method="post">
    		用户名:<input type="text" name="username" id="username"><br>
    		密码: <input type="password" name="password" id="password"><br>
    		真实姓名:<input type="text" name="name" id="realname"><br>
    		年龄:<input type="text" name="age" id="age"><br>
    		住址:<input type="text" name="address" id="address"><br>
    		<input type="button" value="提交" id="btn" />
    	</form>
    	</body>
    </html>
    

    my.js
    $(document).ready(function(){
    	$("#btn").click(function(){
    		var url = "loginAction";  //URL路径
    		var username = $("#username").val();
    		var password = $("#password").val();
    		var realname = $("#realname").val();
    		var age = $("#age").val();
    		var address = $("#address").val();
    		//参数
    		var params = {"username":username,"password":password,"realname":realname,"age":age,"address":address};
    		
    		$.ajax({
    			url:url,
    			type:"post",
    			dataType:"json",
    			data:params,
    			success:callBack  //回调函数
    		})
    	})
    	function callBack(result){
    		//为什么不是eval("("+result+")")  也郁闷中
    		var json = eval(result);
    		var str = "username:" + json.username + "<br />"; 
    		str += "password:" + json.password + "<br />";
    		str += "realname:" + json.realname + "<br />";
    		str += "age:" + json.age + "<br />";
    		str += "address:" + json.address + "<br />";
    		
    		$("#msg").html(str);
    	}
    })

    备注:

      在调试的时候 出现了乱码,本人水平有限,解决不了。

     在login.jsp中设置了

    <%@ page contentType="text/html; charset=utf-8"%>

    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">

    <%
    //竟然还是TMD乱码
    response.setContentType("text/html;charset=utf-8");
    request.setCharacterEncoding("utf-8");
    %>

    最后在struts.xml中也配置了

    <constant name="struts.i18n.encoding" value="UTF-8" />

    还是乱码....


    在struts.xml的配置文件中需要注意一点:

    package继承的是json-default 而不是struts-default 这是因为只有在该包下才有JSON类型的Result


    写到此处还是有点不明:

    在my.js 中利用ajax请求地址到loginAction返回是JSON格式数据,不知道它是如何得到Action中的数据的。

    我尝试把所有属性的set,get方法注释掉,发现得不到数据了,也许就是set,get传递数据的。

    不解与不明之处还请指教!

  • 相关阅读:
    ubuntu 14.4 apache2 django
    github上的版本和本地版本冲突的解决方法
    Javascript能做什么 不能做什么。
    django 取model字段的verbose_name值
    Django在admin模块中显示auto_now_add=True或auto_now=True的时间类型列
    合并多个python list以及合并多个 django QuerySet 的方法
    摘抄
    Python 字符串拼接
    学习HTTP
    Django 自定义模板标签和过滤器
  • 原文地址:https://www.cnblogs.com/itmyhome/p/4131593.html
Copyright © 2020-2023  润新知