细节部分我就不多讲了,因为我也不会,就讲讲我是如何调试出来我的第一个JSON使用的吧
采用的框架有:Struts2 、 JQuery 、 JSON
按着步骤来吧:
1.新建一个Web工程
导入包列表:
目录结构如图:
2.建立实体类User
view plaincopy to clipboardprint?
package com.school.pojo;
public class User {
private String user;
private int age;
public String getUser() {
return user;
}
public void setUser(String user) {
this.user = user;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
package com.school.pojo;
public class User {
private String user;
private int age;
public String getUser() {
return user;
}
public void setUser(String user) {
this.user = user;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
3.建立Action JsonAction
view plaincopy to clipboardprint?
public class JsonAction extends ActionSupport{
private User user;
//用于记录返回结果
private String result;
//省略相应的get和set方法
@SuppressWarnings("static-access")
public String execute() throws Exception {
//将要返回的user实体对象进行json处理
JSONObject jo = JSONObject.fromObject(this.user);
System.out.println(jo);
//调用json对象的toString方法转换为字符串然后赋值给result
this.result = jo.toString();
return this.SUCCESS;
}
}
public class JsonAction extends ActionSupport{
private User user;
//用于记录返回结果
private String result;
//省略相应的get和set方法
@SuppressWarnings("static-access")
public String execute() throws Exception {
//将要返回的user实体对象进行json处理
JSONObject jo = JSONObject.fromObject(this.user);
System.out.println(jo);
//调用json对象的toString方法转换为字符串然后赋值给result
this.result = jo.toString();
return this.SUCCESS;
}
}
4.建立struts.xml文件
view plaincopy to clipboardprint?
<?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.i18n.encoding" value="UTF-8"></constant>
<package name="ttttt" extends="json-default">
<action name="jsonAction" class="action.JsonAction">
<result type="json" >
<!-- 因为要将reslut的值返回给客户端,所以这样设置 -->
<!-- root的值对应要返回的值的属性 -->
<param name="root">
result
</param>
</result>
</action>
</package>
</struts>
<?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.i18n.encoding" value="UTF-8"></constant>
<package name="ttttt" extends="json-default">
<action name="jsonAction" class="action.JsonAction">
<result type="json" >
<!-- 因为要将reslut的值返回给客户端,所以这样设置 -->
<!-- root的值对应要返回的值的属性 -->
<param name="root">
result
</param>
</result>
</action>
</package>
</struts>
5.编写index.jsp文件
view plaincopy to clipboardprint?
<%@ page language="java" pageEncoding="UTF-8"%>
<%@ taglib prefix="s" uri="/struts-tags"%>
<%
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 '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">
<!-- basePath用来获取js文件的绝对路径 -->
<mce:script type="text/javascript" src="<%=basePath%><!--
js/jquery.js">
// --></mce:script>
<mce:script type="text/javascript" src="<%=basePath%><!--
js/index.js">
// --></mce:script>
<s:head theme="ajax" />
</head>
<body>
<div id="result">
</div>
<s:form name="userForm" action="" method="post">
<s:textfield label="用户名" name="user.name" />
<s:textfield label="年龄" name="user.age" />
<button>
提交
</button>
</s:form>
</body>
</html>
<%@ page language="java" pageEncoding="UTF-8"%>
<%@ taglib prefix="s" uri="/struts-tags"%>
<%
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 '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">
<!-- basePath用来获取js文件的绝对路径 -->
<mce:script type="text/javascript" src="<%=basePath%><!--
js/jquery.js">
// --></mce:script>
<mce:script type="text/javascript" src="<%=basePath%><!--
js/index.js">
// --></mce:script>
<s:head theme="ajax" />
</head>
<body>
<div id="result">
</div>
<s:form name="userForm" action="" method="post">
<s:textfield label="用户名" name="user.name" />
<s:textfield label="年龄" name="user.age" />
<button>
提交
</button>
</s:form>
</body>
</html>
6.在WebRoot目录下建立js文件件,将jquery.js文件放到文件夹下,然后再建立文件index.js
view plaincopy to clipboardprint?
$(document).ready(function() {
// 直接把onclick事件写在了JS中
$("button").click(function() {
// 序列化表单的值
var params = $("input").serialize();
$.ajax({
// 后台处理程序
url : "jsonAction.action",
// 数据发送方式
type : "post",
// 接受数据格式
dataType : "json",
// 要传递的数据
data : params,
// 回传函数
success : update_page
});
});
});
function update_page(result) {
var json = eval( "("+result+")" );
var str = "姓名:" + json.name + "<br />"; str += "年龄:"
+ json.age + "<br />";
$("#result").html(str);
}
$(document).ready(function() {
// 直接把onclick事件写在了JS中
$("button").click(function() {
// 序列化表单的值
var params = $("input").serialize();
$.ajax({
// 后台处理程序
url : "jsonAction.action",
// 数据发送方式
type : "post",
// 接受数据格式
dataType : "json",
// 要传递的数据
data : params,
// 回传函数
success : update_page
});
});
});
function update_page(result) {
var json = eval( "("+result+")" );
var str = "姓名:" + json.name + "<br />"; str += "年龄:"
+ json.age + "<br />";
$("#result").html(str);
}
7.运行前效果:
要的是效果,布局就不整了
运行后效果:
网上相关的信息太少了,很多Struts2+JQuery+JSON的教程,点开链接之后都是那几篇文章转了又转,遇到问题真的很想找到有用的信息,或许是我太笨了,找不到,或许就是网上相关的信息就很少。这个实例很简单是不是,但是为了调试出这个程序,我费了一天的时间。
上面的实例成功了,但是问题又出来了
视图类型仅仅设置了json
那么输入校验出错的时候怎么显示?
部分内容转自:http://blog.csdn.net/fengda2870/archive/2009/04/06/4052527.aspx
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/icejadelove/archive/2009/09/30/4621641.aspx
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/icejadelove/archive/2009/09/30/4621641.aspx
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/icejadelove/archive/2009/09/30/4621641.aspx