<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Untitled Document</title>
<script type="text/javascript" src="jquery-1.6.1.js">
</script>
<script language="JavaScript">
$(function(){
$("#bt1").click(function(){
var URL = "../jsonObject";
$.getJSON(URL, function(data){
alert("JSON Data 姓名:: " + data.name);
alert("JSON Data 年龄:: " + data.age);
alert("JSON Data 性别:: " + data.sex);
});
});
})
</script>
</head>
<body>
<p align="center">
jquery+ json--取后台一个jsonObject对象
</p>
<table align="center">
<tr>
<td>
<input type="button" value="点击获取" id="bt1">
</td>
<td>
<div id="div1">
</div>
</td>
</tr>
</table>
</body>
</html>
后台代码:
package com.wepull.servlet;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import net.sf.json.JSONObject;
public class JsonObjectServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
doPost(req, resp);
}
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
request.setCharacterEncoding("utf-8");
response.setCharacterEncoding("utf-8");
response.setContentType("text/plain");
String name = request.getParameter("name");
System.out.println("ajax传来的name:"+name);
System.out.println("---");
PrintWriter pw = response.getWriter();
JSONObject jsonObj = new JSONObject();
jsonObj.put("name", "小希子");
jsonObj.put("age", new Integer(21));
jsonObj.put("sex", "男");
System.out.println(jsonObj);
pw.println(jsonObj);
}
}
注意
jquery.getJSON 方法
读取远程数据时发现,有的会提示脚本错误 " 未组织好"
原因 servlet的默认返回类型是"text/xml"或"text/html"
解决方案:设置下返回类型..
.net : Response.ContentType = "text/plain";
java : response.setContentType("text/plain");
附:MIME简介
什么是MIME类型-在把输出结果传送到浏览器上的时候,浏览器必须启动适当的应用程序来处理这个输出文档。这可以通过多种类型MIME(多功能网际邮件扩充协议)来完成。在HTTP中,MIME类型被定义在Content-Type header中。
例如,假设你要传送一个Microsoft Excel文件到客户端。那么这时的MIME类型就是“application/vnd.ms-excel”。在大多数实际情况中,这个文件然后将传送给Execl来处理。
每个MIME类型由两部分组成,前面是数据的大类别,例如声音audio、图象image等,后面定义具体的种类。
常见的MIME类型
多媒体文件格式MIME
最早的HTTP协议中,并没有附加的数据类型信息,所有传送的数据都被客户程序解释为超文本标记语言HTML 文档,而为了支持多媒体数据类型,HTTP协议中就使用了附加在文档之前的MIME数据类型信息来标识数据类型。
MIME意为多目Internet邮件扩展,它设计的最初目的是为了在发送电子邮件时附加多媒体数据,让邮件客户程序能根据其类型进行处理。然而当它被HTTP协议支持之后,它的意义就更为显著了。它使得HTTP传输的不仅是普通的文本,而变得丰富多彩。
每个MIME类型由两部分组成,前面是数据的大类别,例如声音audio、图象image等,后面定义具体的种类。
常见的MIME类型
超文本标记语言文本 .html,.html text/html
普通文本 .txt text/plain
RTF文本 .rtf application/rtf
GIF图形 .gif image/gif
JPEG图形 .ipeg,.jpg image/jpeg
au声音文件 .au audio/basic
MIDI音乐文件 mid,.midi audio/midi,audio/x-midi
RealAudio音乐文件 .ra, .ram audio/x-pn-realaudio
MPEG文件 .mpg,.mpeg video/mpeg
AVI文件 .avi video/x-msvideo
GZIP文件 .gz application/x-gzip
TAR文件 .tar application/x-tar
Internet中有一个专门组织IANA来确认标准的MIME类型,但Internet发展的太快,很多应用程序等不及IANA来确认他们使用的MIME类型为标准类型。因此他们使用在类别中以x-开头的方法标识这个类别还没有成为标准,例如:x-gzip,x-tar等。事实上这些类型运用的很广泛,已经成为了事实标准。只要客户机和服务器共同承认这个MIME类型,即使它是不标准的类型也没有关系,客户程序就能根据MIME类型,采用具体的处理手段来处理数据。而Web服务器和浏览器(包括操作系统)中,缺省都设置了标准的和常见的MIME类型,只有对于不常见的 MIME类型,才需要同时设置服务器和客户浏览器,以进行识别。
由于MIME类型与文档的后缀相关,因此服务器使用文档的后缀来区分不同文件的MIME类型,服务器中必须定义文档后缀和MIME类型之间的对应关系。而客户程序从服务器上接收数据的时候,它只是从服务器接受数据流,并不了解文档的名字,因此服务器必须使用附加信息来告诉客户程序数据的MIME类型。服务器在发送真正的数据之前,就要先发送标志数据的MIME类型的信息,这个信息使用Content-type关键字进行定义,例如对于HTML文档,服务器将首先发送以下两行MIME标识信息,这个标识并不是真正的数据文件的一部分。
Content-type: text/html
注意,第二行为一个空行,这是必须的,使用这个空行的目的是将MIME信息与真正的数据内容分隔开。
分享到:
相关推荐
在实现下拉框级联时,JQuery负责监听用户在第一个下拉框中的选择,然后通过Ajax异步请求向Servlet发送数据,获取相应的级联数据,并更新第二个下拉框的选项。 以下是实现步骤: 1. **创建Servlet**:在Servlet中,...
创建一个Action类来处理AJAX请求,将返回的数据封装成一个JSONObject对象。在`struts.xml`配置文件中,配置该Action的返回类型为`json`,并设置`package`的`extends`属性为`json-default`,确保Action返回的数据格式...
JSON-lib 是一个方便的 Java 库,用于 JSON 与 Java 对象之间的转换,依赖于几个 Apache Commons 库。 总结来说,JQuery AJAX 提供了与服务器异步交互的能力,而 JSON 则是高效的数据交换格式。两者结合使用,可以...
至此,一个基本的jQuery File Upload与Java后台交互的案例已经完成。当然,实际项目中可能还需要考虑更多细节,如文件大小限制、文件类型检查、错误处理等。这个案例提供了一个基础的框架,开发者可以根据自己的需求...
例如,如果JSON数组包含了地理坐标信息,可以创建一个新的数组`points`,并将每个JSON对象的`lon`和`lat`属性添加到数组中,以备后续的地理位置处理。 总结来说,通过jQuery的AJAX功能,前后台间可以方便地传递JSON...
在Servlet中,我们可以使用`JSONObject`或`JSONArray`等库将Java对象转换为Json字符串,然后通过Ajax发送到客户端,客户端再将接收到的Json数据解析成JavaScript对象,进而更新页面。 具体来说,当用户触发一个事件...
jQuery 是一个高效的 JavaScript 库,提供了丰富的功能,简化了 DOM 操作、事件处理以及 AJAX 交互等任务。结合 AJAX 技术,可以在不刷新整个页面的情况下,实现后台数据的异步加载。 2. **详述** - **依赖的库...
在"多层集合的JSON串拼接"这个主题中,我们主要关注的是如何将多个JSON对象或数组合并成一个复杂结构的JSON字符串。这通常涉及到后台Java的处理和前台JavaScript的调用。以下是一些关键知识点: 1. **JSON对象与...
2. 转换Java对象为JSON:如果你有一个Java对象需要转换为JSON,可以使用`JSONObject`的`toString()`方法或`toJSONString()`方法。 ```java public class Person { String name; int age; // getters and ...
JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,它基于JavaScript的一个子集,易于人阅读和编写,同时也易于机器解析和生成。在Web开发中,JSON常用于服务器与客户端之间的数据交互,特别是在AJAX...
在示例的后台代码1中,创建了一个HashMap,将其转换为JSONObject,并发送到前端。前端通过`jQuery.parseJSON`解析返回的JSON字符串,然后访问数据。 对于列表(List)数据,后台代码2展示了如何将ArrayList转换为...
它基于JavaScript的一个子集,采用了一种类似于JavaScript对象字面量的语法结构。在现代Web开发中,JSON被广泛应用于客户端与服务器之间的数据传递。 #### jQuery简介 jQuery是一个快速、简洁的JavaScript库,极大...
这个过程通常涉及到后端开发,其中" SNDT_app后台"可能指的是某种特定的技术栈或服务,而"fourthatu"可能是项目名或者一个特定的工具。下面我们将详细探讨这一转换过程以及相关的技术点。 首先,JSON是一种轻量级的...
例如,`JSON.parse()`可以将一个JSON字符串转化为JavaScript对象,而`JSON.stringify()`则将JavaScript对象转化为JSON字符串。 2. **json.jar**:这是一个Java的库文件,通常包含了一些处理JSON的类和方法。在后端...
Fastjson是一个Java语言编写的高性能功能完备的JSON库。它的核心功能包括: - JSON到Java对象的映射(JSON to Java Objects,简称JO) - Java对象到JSON串的转换(Java Objects to JSON String,简称JS) - JSON...
jQuery是一个流行的JavaScript库,它简化了DOM操作、事件处理和Ajax交互。Ajax(Asynchronous JavaScript and XML)是一种在无需刷新整个页面的情况下更新部分网页内容的技术。通过Ajax,我们可以向服务器发送异步...
一个简单的JSON对象示例如下: ```json { "name": "张三", "age": 30, "isStudent": false, "hobbies": ["阅读", "编程"] } ``` 在后台操作JSON,通常我们使用编程语言提供的JSON库或内置函数。以Java为例,...
JSON-LIB是一个用于处理JSON数据的Java库,支持将Java对象转换为JSON字符串,也可以将JSON字符串转换为Java对象。 **7.2 使用示例** ```java JSONObject jsonObject = new JSONObject(); jsonObject.put("name", ...
在Struts2的Action类中,你需要创建一个Java对象,该对象的属性对应于你要返回的JSON数据。然后,使用注解`@Result(type="json")`声明返回JSON的结果类型。例如: ```java public class YourAction extends ...
在Struts2 Action中,你需要创建一个返回JSON的Action,如下所示: ```java public class TreeNodeAction extends ActionSupport { private List<TreeNode> nodes; // getters and setters public String ...