JavaWeb项目第三次总结_成绩查询的实现
查询图书的功能实现
如何知道浏览器往服务器传入的参数
1、在编写好查询页面后,使用火狐浏览器的friebug (全部—>POST—>参数)
2、编写GradeListServlet,重写doGet()和doPOST()方法
服务器处理页面请求的过程
1、重写doPOST()方法。
处理过程
1、连接数据库 2、创建JSONObject对象 3、格式化数据 4、将处理后的数据以{key,value}放入到JSONObject对象中 5、响应客户端的请求
- 获取页面请求的参数 使用方法:request.getParameter(“page/rows”);
- 创建PageBean类 将获取来的参数传入到PageBean类进行初始化。
PageBean
package com.it.model;public class PageBean {private int page;//第几页private int rows;//每页的记录数private int start;//起始页public PageBean(int page, int rows) {super();this.page = page;this.rows = rows;}public int getPage() {return page;}public void setPage(int page) {this.page = page;}public int getRows() {return rows;}public void setRows(int rows) {this.rows = rows;}public int getStart() {return (page-1)*rows;}
}
创建从数据库查询出来的数据转化成JSON格式的数据
JSON将数据转化成了字符串类型的数据
转化对象后是键值对的形式 {name:value}
JSON格式转化的工具类
package com.it.util;import java.sql.ResultSet;
import java.sql.ResultSetMetaData;import net.sf.json.JSONArray;
import net.sf.json.JSONObject;/** Json 工具包 用来处理JSon格式* 用来转化格式* JSONArray格式是 键值对形式的*/
public class JsonUtil {/*** 将数据库内的数据集转化成JSON格式的数据 输出到浏览器页面* @param rs 数据库查询返回的集合* @return * @throws Exception*/public static JSONArray formatRsToJsonArray(ResultSet rs)throws Exception{ResultSetMetaData md=rs.getMetaData();//获取纵向集合int num = md.getColumnCount();//获取ResultSetMetaData 有多少行JSONArray array=new JSONArray();//JSONArray 里的每一个对象是 JSONObjectwhile(rs.next()){ //横向的遍历JSONObject mapOfColValues=new JSONObject(); //JSONArray 里的每一个对象叫JSONObjectfor(int i=1;i<=num;i++){mapOfColValues.put(md.getColumnName(i), rs.getObject(i));//给对象赋值}array.add(mapOfColValues);}return array;//添加到JSONArray数组}
}
GradeListServlet
package com.it.web;import java.io.IOException;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;import net.sf.json.JSONArray;
import net.sf.json.JSONObject;import com.it.dao.GradeDao;
import com.it.model.PageBean;
import com.it.util.Dbutil;
import com.it.util.JsonUtil;
import com.it.util.ResponseUtil;public class GradeListServlet extends HttpServlet {Dbutil dbUtil=new Dbutil();GradeDao gradeDao=new GradeDao();@Overrideprotected void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {this.doPost(request, response);}@Overrideprotected void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {String page = request.getParameter("page");//页面请求 pageString rows = request.getParameter("rows");//每页的记录数PageBean pageBean=new PageBean(Integer.parseInt(page),Integer.parseInt(rows));Connection con=null;try{con=dbUtil.getCon();JSONObject result=new JSONObject(); //创建JSONObject对象用来存放JSONArray 数组JSONArray jsonArray = JsonUtil.formatRsToJsonArray(gradeDao.gradeList(con, pageBean));//将返回的结果集转化成JSON格式的数据// ResultSet rs=gradeDao.gradeList(con, pageBean);
// gradeDao.print(con, rs);int total=gradeDao.gradeCount(con);//返回统计的总行数result.put("rows", jsonArray);result.put("total", total);ResponseUtil.write(response, result);}catch(Exception e){e.printStackTrace();}finally{try {dbUtil.closeCon(con);} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}}}}
## 数据库处理层GradeDao类 ##
package com.it.dao;import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;import com.it.model.Grade;
import com.it.model.PageBean;public class GradeDao {public ResultSet gradeList(Connection con,PageBean pageBean)throws Exception{StringBuffer sb=new StringBuffer("select * from t_grade");if(pageBean!=null){sb.append(" limit "+pageBean.getStart()+","+pageBean.getRows());}PreparedStatement pstmt = con.prepareStatement(sb.toString());return pstmt.executeQuery();}public int gradeCount(Connection con)throws Exception{String sql="select count(*) as total from t_grade";// as total 是起的别名PreparedStatement psmt = con.prepareStatement(sql);ResultSet rs = psmt.executeQuery();if(rs.next()){return rs.getInt("total");}else{return 0;}}public void print(Connection con,ResultSet rs)throws Exception{while(rs.next()){Grade grade=new Grade();grade.setId(rs.getInt("id"));grade.setGradeName(rs.getString("gradeName"));grade.setGradeDesc(rs.getString("gradeDesc"));System.out.println(grade);}}
}
响应页面的工具类
package com.it.util;import java.io.PrintWriter;import javax.servlet.http.HttpServletResponse;import net.sf.json.JSONObject;public class ResponseUtil {public static void write(HttpServletResponse response,JSONObject jsonObject)throws Exception{response.setContentType("text/html;charaset=UTF-8");response.setCharacterEncoding("UTF-8");//解决无法输出中文的问题PrintWriter out = response.getWriter();out.println(jsonObject.toString());out.flush();out.close();}}
相关文章:

cisco路由交换系统测试命令
路由交换系统测试命令通用测试命令:ping X.X.X.X :标准ping命令,用于测试设备间的物理连通性ping :扩展ping命令,也用于设备间的物理连通性,扩展ping命令还支持灵活定义ping命令的参数,比…

jquery下拉菜单
自己写的一个菜单(因为是初学 不知道能不能算无限级)jquery $(document).ready(function(){ $("ul li").hover(function(){ $(this).find("ul:first").show();//鼠标滑过查找li下面的第一个ul然后显示;},function(){ …

MongoDB update修改器: 针对Fields的$修改器 $inc $set $unset
MongoDB update修改器: $inc $set $unset $push $pull $pop 针对Fields的$修改器 $set: { $set: { key: value } } $set:{"gender":"男"} 解释: $set 是update时的关键字,表示我要设置gender属性的值为"男" 如果该条Documents没有gen…

都是些什么人!
都是些什么人!转载于:https://www.cnblogs.com/liyugeng/p/7877615.html

IO流(二)转换流、序列化、commons-IO框架
转换流 介于字符流和字节流之间的流 字节流与字节流相互转换 OutputStreamWriter 输出流,按照指定的字符集编码,把字符流转化成字节数据 编码:把字符数据转换成字节数据; 解码:把字节数据转换成字符数据 二进制数据—&…

Http之Get/Post请求区别
今天在网上看了一些关于http 协议中get 和Post的文章。在此做一个总结,当是做一个笔记吧。 一、什么是HTTP-GET和HTTP-POST HTTP-GET和HTTP-POST是使用HTTP的标准协议动词,用于编码和传送变量名/变量值对参数,并且使用相关的请求语义。每个HT…

[vb+mo] visual baisc 6.0 基于mapobjects 2.4 开发的数字化校园电子地图
程序的源代码下载地址: https://docs.google.com/ 请安装VB6.0企业版(不是企业版运行会报错,因为缺少相应的控件)和ESRI MO2.4 程序的质量一般,因为时间仓促,主要是毕业设计时间仓促.希望大家多多改进.有什么问题可以发邮件欢迎交流. 程序的主窗口代码: 通用变量定义Private l…

vsftp部署
1.安装该软件需要使用最高用户(root)进行安装,否则不能进行。 2.首先用命令检查VSFTP是否已经安装。chkconfig --list | grep vsftpd 3.安装vsftp。yum install –y vsftpd 4.启动vsftp。service vsftpd start 5.添加一个ftp用户。useradd f…

线程、线程匿名内部类、解决线程不安全的方式
线程 线程:正在运行的程序,是程序的执行路径;多线性 进程:是应用程序的载体,程序运行在虚拟机中。一个应用软件对应一个进程。 一个进程包含多个线程,一个线程对应一个进程。 好处:提高软件的运…

工作流编程循序渐进(9:使用本地服务在宿主和工作流之间通信)
工作流编程循序渐进(9:使用本地服务在宿主和工作流之间通信) 作者 朱先忠 [摘要]在本篇中,首先详细分析本地服务有关概念,探讨本地服务在工作流运行时、工作流实例及工作流宿主间的地位及作用…

使用Properties连接数据库
使用Properties连接数据库 要注意的是: 1.通过配置文件来连接数据库时,连接信息要以 mysql.XXX开头,否则会提示异常。 java.sql.SQLException: Access denied for user localhost (using password: YES)生成配置文件的实现代码 1、创建写入配置信息工…
两边横线,中间标题
<!DOCTYPE html> <html> <head> <title>两边横线,中间标题</title> <meta http-equiv"Content-Type" content"text/html; charsetutf-8" /> <style type"text/css"> <!--ul { mar…

交换机基础配置
请同学们下载附件中的实验并完成。转载于:https://blog.51cto.com/coffee0546/204093

python高级-模块(14)
一、python中的模块 有过C语言编程经验的朋友都知道在C语言中如果要引用sqrt函数,必须用语句#include <math.h>引入math.h这个头文件,否则是无法正常进行调用的。 那么在Python中,如果要引用一些其他的函数,该怎么处理呢&am…

RabbitMQ学习系列二:.net 环境下 C#代码使用 RabbitMQ 消息队列
上一篇已经讲了Rabbitmq如何在Windows平台安装,不懂请移步:RabbitMQ学习系列一:windows下安装RabbitMQ服务 一、理论: .net环境下,C#代码调用RabbitMQ消息队列,本文用easynetq开源的.net Rabbitmq api来实…

一步步学会使用ASP.NET 4 WEB应用程序中使用URL Routing(翻译)
创建路由 路由就是将URL路径映射到具体的物理文件。若要将路由添加到网站中,请使用 RouteCollection.MapPageRoute 方法将它们添加到RouteTable类的静态Routes属性。 将用于添加路由的方法添加到 Global.asax 文件中 如果网站还没有 Global.asax 文件,…

Properties持久的属性集
Properties 属性集合继承了Hashtable 属性包括属性名和属性值(键值对keyvalue) 作用 可以存储多个键值,与map相似可以把键值对存储到文件中可以把文件中的键值对读取到Properties对象中 构造方法: Properties() 创建一个无默认…

让你二十年后仍是人才
1.不管坐什么位置,都要保持学习的习惯出社会工作十年到十五年左右,会有一种「上下卡住」的闭塞感与无力感。因为,这个阶段的上班族虽然拥有一定的资历与经验,工作也得心应手,但上面有比自己更资深的前辈压着࿰…

Django ORM操作
Django ORM操作 一般操作 看专业的官网文档,做专业的程序员! 必知必会13条 <1> all(): 查询所有结果<2> get(**kwargs): 返回与所给筛选条件相匹配的对象,返回结果有且只有一个,如果符合筛选…

ChineseCalendar类[转]
///<summary>///Title: ChineseCalendar类 ///Description: 中文日期工具类 ///author 万灵杰[作者] ///version 1.0.0.0 ///date 2009年7月30日 ///modify ///date ///</summary>publicclassChineseCalendar { privatestaticrea…

程序员的自我救赎---13.1:职场招聘与面试心得
《前言》 《目录》 (一) Winner2.0 框架基础分析 (二)PLSQL报表系统 (三)SSO单点登录 (四) 短信中心 (五)钱包系统 (六)GPU支付中心 &…

网络编程 UDP通信的过程 TCP通信过程 多线程文件上传
网络概述 协议 在网络之间传出数据时需要按照指定的标准来传输,标准中规定了数据的格式、大小、传输的方式、传输速率。形成统一规范—>按照规范开发的代码—>协议(应用层、传输层、网络层、链路层) InetAddress类 用来分装网络地址…

set debug mode for flex builder
1. 要具备debug功能,我们必须要首先安装Flash Player Debug 版本。windows版本2. 安装好debug版本后,我们还需要添加日志的配置文件mm.cfg。该配置文件存放的目录如下:Macintosh OS X MacH D:Library:Application Support:macromedia:mm.cfgM…

XML 解析XML文档 XML约束
XML 什么是XML Extensible Markup Language(可扩展的标记语言)他是一个语言,有自己的语法,和Java以及其他的编程无关“标记” 在文件中包含类似于张三 ,这种用尖括号括起来的叫标记,使用来标记数据的。标…

Host Only、NAT和Bridge三种网络连接
Host Only、NAT和Bridge三种网络连接 在安装好了Linux镜像之后,如何连接物理机和虚拟机呢?这就需要网络连接,网络连接有三种:HostOnly、NAT、Bridge,它们都可用于Guest虚拟机和Host物理机之间的网络通信。 一、三者的不…

OSPF 提升 一 ----基础
ospf ccnp内容 一 link-state protocols IGP 开放式的最短路径优先协议 公有协议支持中到大型的网络 spf算法 链路状态协议1.传送的LSA link status advertisement 链路状态通告 包换拓扑信息具体包括:网段的前缀 掩码 连接的路由器的…

C#实现网页截图功能
//需要添加System.Drawing及System.Windows.Forms引用 using System; using System.Drawing; using System.Drawing.Drawing2D; using System.Drawing.Imaging; using System.Windows.Forms; namespace 网页截图 { class Program { [S…

微软发布全新多核心操作系统原型:Barrelfish
Windows 7完成之后,很多人开始把目光投向微软的下一代服务器和客户端操作系统Windows 8,不过今天微软放出了一套全新操作系统的原型,开发代号“Barrelfish”。该系统由微软剑桥研究院和苏黎世理工学院联合全新开发,专为现在和未来…

Docker应用:Kubernetes(容器集群)
Docker应用:Kubernetes(容器集群) 原文:Docker应用:Kubernetes(容器集群)阅读目录: Docker应用:Hello WorldDocker应用:Docker-compose(容器编排)…
通道应用——抠头发
通道应用——抠头发 原图: 效果图: 步骤:1、打开原图的“通道面板”,选择颜色对比分明的绿色通道,并新建一个绿色通道副本;2、选择“图像”-“调整”-“色阶”,调节色阶使得头发颜色更分明些&am…