专栏首页Python程序员杂谈JQuery通过JSON和Servlet进行交互

JQuery通过JSON和Servlet进行交互

今天接着看Hibernate的视频,中间休息的时候随手点了几个网页,看到JSON这个东西,心里琢磨这个东西以前见过,没用过,这是个啥玩意。

JSON是一种数据交换格式,如同常用的xml,不过在javascript领域中,这个东西可以xml好操作多了。

找了一下相应的例子,有一个ASP.net和前台通过Jquery交互的例子,参考着写了一个同Servlet交互的例子。把代码得瑟出来,以供不时之需。

前提:要把jquery的js文件放到WebRoot的下面的js文件夹下。

Index.jsp页面:

<%@ page language="java" import="java.util.*" pageEncoding="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>
<script type="text/javascript" src="js/jquery.js"></script>
<script type="text/javascript">
function getData(){
    $("#list").html("");//清空列表中的数据
    //发送ajax请求
    $.getJSON(
        "servlet/ServletJson",//产生JSON数据的服务端页面
        {name:"胡阳",age:23},//向服务器发出的查询字符串(此参数可选)
         //对返回的JSON数据进行处理,本例以列表的形式呈现
        function(json){
            //循环取json中的数据,并呈现在列表中
            $.each(json,function(i){
                $("#list").append("<li>name:"+json[i].name+"&nbsp; Age:"+json[i].age+"</li>")
            })
        }
    )
    }
</script>
</head>
<body>
<input id="Button1" type="button" value="获取数据" onclick="getData()" />
    <ul id="list"></ul>
</body>
</html>

配置web.xml文件:

<?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">
<servlet>
    <servlet-name>ServletJson</servlet-name>
    <servlet-class>com.json.servlet.ServletJson</servlet-class>
</servlet>

<servlet-mapping>
    <servlet-name>ServletJson</servlet-name>
    <url-pattern>/servlet/ServletJson</url-pattern>
</servlet-mapping>

<welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
</welcome-file-list>
</web-app>

服务器端的Servlet编写:

package com.json.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;

public class ServletJson extends HttpServlet {

    public void doPost(HttpServletRequest request, HttpServletResponse response)
    throws ServletException, IOException {

        System.out.println(request.getParameter("name"));
        response.setContentType("text/plain;charset=utf-8");
        request.setCharacterEncoding("utf-8");
        PrintWriter out = response.getWriter();
        String data = "[{name:\"胡阳\",age:24},{name:\"胡阳\",age:23}]";//构建的json数据
        out.println(data);
     }

     public void doGet(HttpServletRequest request, HttpServletResponse response)
       throws ServletException, IOException {
        doPost(request, response);
     }
}

这样就可通过JQuery在web端直接和服务器端通过JSON进行数据交换了。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • JSP Servlet简单实现

    Jsp和Servlet个人感觉使用起来没有太大区别的,查了一下,说是jsp是Servlet的简化。这说明其本质是一样的,这里简单实现一下jsp和Servlet交...

    the5fire
  • Struts2之Validation的简单使用实例

    本来不打算写这些细枝末节的东西了,因为在文档中都有现成的实例,写了也只能自己用来参考,不过这个Validation文档中给的不全,从网上查之后才知道用法。 首先...

    the5fire
  • DjangoAdmin和它的小伙伴

    look http://localhost:8000/admin/book/book/54/

    the5fire
  • 当Java遇见了Html--Servlet篇

    一、什么是servlet servlet是在服务器上运行的小程序。一个servlet就是一个 java类,并且通过“请求-响应”编程模型来访问的这个驻留在服务器...

    方志朋
  • Servlet总结一

    爱撒谎的男孩
  • JavaEE基础(02):Servlet核心API用法详解

    知了一笑
  • SpringBoot有啥高科技?是怎么做到XML零配置的?

    前言:刚毕业我就接触到了SpringBoot,当初感觉必成大器,第一印象就是内置了所有环境,打完包丢哪里都能跑起来,简化了tomcat Xml配置的一系列部署操...

    王念博客
  • [Java拾遗三]JavaWeb基础之Servlet

    一枝花算不算浪漫
  • 熟悉servlet的页面跳转

    ydymz
  • SpringBoot有啥高科技?是怎么做到XML零配置的?

    前言:刚毕业我就接触到了SpringBoot,当初感觉必成大器,第一印象就是内置了所有环境,打完包丢哪里都能跑起来,简化了tomcat Xml配置的一系列部署操...

    会呼吸的Coder

扫码关注云+社区

领取腾讯云代金券