【JDBC-MVC模式】开发实例
JDBC - 开发实例-MVC模式
1. 在web.xml中配置连接数据库的信息
web.xml:
<context-param>
<param-name>server</param-name> //主机名
<param-value>localhost</param-value>
</context-param>
<context-param>
<param-name>db</param-name> //数据库
<param-value>test</param-value>
</context-param>
<context-param>
<param-name>user</param-name> //用户名
<param-value>root</param-value>
</context-param>
<context-param>
<param-name>password</param-name> //密码
<param-value>1234</param-value>
</context-param>
2. 数据层-创建实体类Student.java
Student.java:
package gh.test.entity;
public class Student{
private int id;
private String name;
private int gender;
private int age;
private String address;
private String tel;
public void setId(int id){ //学号
this.id = id;
}
public int getId(){
return id;
}
public void setName(String name){ //姓名
this.name = name;
}
public String getName(){
return name;
}
public void setGender(int gender){ //性别
this.gender = gender;
}
public int getGender(){
retuen gender;
}
public void setAge(int age){ //年龄
this.age = age;
}
public int getAge(){
return age;
}
public void setAddress(String address){ //地址
this.address = address;
}
public String getAddress(){
return address;
}
public void setTel(String tel){
return tel;
}
}
3. 数据访问层-创建数据库操作类 DB.java & 学生DAO类 StudentDao.java
DB.java:
package gh.test.dao;
import java.sql.DriverManager;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
public class DB{
Connection conn = null;
PreparedStatement ps = null;
ResultSet rs = null;
public Connection getConn
(String server,String db,String user,String password)throws ClassNotFoundException,InstantiationException,IllegalAccessException,SQLException{ //获取对象
String driver = "com.mysql.jdbc.Driver";
String url = "jdbc:mysql://"+server+":3306/"+db+"?user="+user+"&password="+password+"&characterEncoding=utf-8";
Class.forName(driver); //加载驱动
Connection conn = DriverManager.getConnection(url); //创建Connection对象
return conn;
}
public ResultSet executeQuery(String sql,String[] params){ //执行查询操作
try{
ps = conn.prepareStatement(sql);
if(params != null){
for(int i=0;i<params.length;i++){
ps.setString(i+1,params[i]);
}
}
rs = ps.executeQuery();
}
catch(SQLException ex){
ex.printStackTrace();
}
return rs;
}
public int executeUpdate(String sql,String[] params){ //执行更新操作
int n = 0;
try{
ps = conn.prepareStatement(sql);
if(params != null){
for(int i=0;i<params.length;i++){
ps.setString(i+1,params[i]);
}
n = ps.executeUpdate();
}
}catch(SQLException ex){
ex.printStackTrace();
}
return n;
}
public void closeAll(){
if(rs != null){
try{
rs.close();
}catch(SQLException ex){
ex.printStackTrace();
}
}
if(ps != null){
try{
ps.close();
}catch(SQLException ex){
ex.printStackTrace();
}
}
if(conn != null){
try{
conn.close();
}catch(SQLException ex){
ex.printStackTrace();
}
}
}
}
StudentDao.java:
package gh.test.dao;
import gh.test.entity.Student;
public class StudentDao extends DB{
public int addStudent(Student student){
String name = student.getName();
String gender = student.getGender()+"";
String age = student.getAge()+"";
String address = student.getAddress();
String tel = student.getTel();
String[] params = new String[]{name,gender,age,address,tel};
String sql = "insert into studentInfo values(?,?,?,?,?)";
int result = super.executeUpdate(sql,params);
return result;
}
}
4. 视图显示层&逻辑处理-addStudent.html & AddStudentServlet.java
addStudent.html:
<html>
<head>
<meta http-equiv="Content-Type" content="text/html;charset=utf-8">
<title>添加学生信息</title>
</head>
<body>
<form name="form1" action="AddStudentServlet" method="post">
<table>
<tr>
<th colspan="2">学生信息</th>
</tr>
<tr>
<td>姓名:</td>
<td><input type="text" name="name"/></td>
</tr>
<tr>
<td>性别:</td>
<td>
<input type="radio" name="gender" value="0" check="checked"/>男
<input type="radio" name="gender" value="1"/>女
</td>
</tr>
<tr>
<td>年龄:</td>
<td>
<select name="age">
<option value="18" select="selected">18</option>
<option value="19">19</option>
<option value="20">20</option>
<option value="21">21</option>
<option value="22">22</option>
</select>
</td>
</tr>
<tr>
<td>地址:</td>
<td><input type="text" name="address"/></td>
</tr>
<tr>
<td>电话:</td>
<td><input type="text" name="tel"/></td>
</tr>
<tr>
<td colspan="2" align="center">
<input type="submit" name="tj" value="提交" onclick="check();"/>
<input type="reset" name="cz" value="重置"/>
</td>
</tr>
</table>
</form>
<script language="javascript">
function check(){
if(document.form1.name.value == ""){
alert("请输入姓名!");
document.form1.name.focus();
return false;
}
if(document.form1.age.value == ""){
alert("请输入年龄!");
document.form1.age.focus();
return false;
}
if(document.form1.address.value == ""){
alert("请输入地址!");
document.form1.address.focus();
return false;
}
if(document.form1.tel.value == ""){
alert("请输入电话号码!");
document.form1.tel.focus();
return false;
}
return true;
}
</script>
</body>
</html>
AddStudentServlet.java:
package gh.test.servlet;
import java.io.IOException;
import java.io.PrintWriter;
import java.sql.SQLException;
import javax.servlet.ServletContent;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import gh.test.entity.Student;
import gh.test.dao.StudentDao;
public class AddStudentServlet extends HttpServlet{
private static final long serialVersionUID = 1L;
public AddStudentServlet(){
super();
}
public void doGet(HttpServletRequest request,HttpServletResponse response)throws ServletException,IOException{
doPost(request,response);
}
public void doPost(HttpServletRequest request,HttpServletResponse response)throws ServletException,IOException{
request.setCharacterEncoding("utf-8");
response.setContentType("text/html;charset=utf-8");
PrintWriter out = response.getWriter();
String name = request.getParameter("name");
int gender = Integer.parseInt(request.getParameter("gender"));
int age = Integer.parseInt(request.getParameter("age"));
String address = request.getParameter("address");
String tel = request.getParameter("tel");
Student student = new Student();
student.setName(name);
student.setGender(gender);
student.setAge(age);
student.setAddress(address);
student.setTel(tel);
ServletContext ctx = this.getServletContext();
String server = ctx.getInitParameter("server");
String db = ctx.getInitParameter("db");
String user = ctx.getInitParameter("user");
String password = ctx.getInitParameter("password");
StudentDao studentDao = new StudentDao();
try{
studentDao.getConn(server,db,user,password);
if(studentDao.addStudent(student) == 1){
out.print("添加新同学信息成功!<br>");
}
else{
out.print("添加失败!<br>");
}
out.print("<a href='addStudent.html'>返回</a>");
}catch(ClassNotFoundException ex){
ex.printStackTrace();
}catch(Exception ex){
ex.printStackTrace();
}
}
}
【JDBC-MVC模式】开发实例的更多相关文章
- 【Web开发】Mean web开发 01-Express实现MVC模式开发
简介 Mean是JavaScript的全栈开发框架.更多介绍 用Express实现MVC模式开发是Mean Web全栈开发中的一部分. Express 是一个基于 Node.js 平台的极简.灵活的 ...
- JavaFX桌面应用-MVC模式开发,“真香”
使用mvc模块开发JavaFX桌面应用在JavaFX系列文章第一篇 JavaFX桌面应用开发-HelloWorld 已经提到过,这里单独整理使用mvc模式开发开发的流程. ~ JavaFX桌面应用开发 ...
- Extjs MVC模式开发,循序渐进(一)
本文讲述extjs mvc的Helloworld,tabPanel,event,页面布局layout等内容. 本页包含:MVC模式案例(一)~MVC模式案例(六),从搭建extjs mvc到点击按钮生 ...
- 【转】利用MVC模式开发Java应用程序[组图]
Java是一种面向对象的语言,是实现面向对象编程的强大工具.我们在实际编程中,应该运用并发挥其最大效能.但是,要利用面向对象编程思想,自己独立开 发出好的Java应用程序,非凡是大.中型程序,并不是一 ...
- Angular——MVC模式开发实战
创建项目 创建工作目录 使用bower下载需要插件 git init.add.commit之后得到分支master,再创建developer分支,然后再此分支上进行具体功能开发 MVC架构 之前小项目 ...
- .net使用mvc模式开发web应用 模型与视图间的数据处理
http://www.cnblogs.com/JeffreyZhao/archive/2009/02/27/mvc-use-strong-type-everywhere.html#3427764 本文 ...
- 使用MVC模式开发一简单的销售额查询系统
与上一篇比较,只改变了index.jsp文件中form的提交路径 <form action="ShowServlet" method="post"> ...
- 基于MVC模式开发的后台框架
1.ThinkCMF 2.NFine快速开发平台 3.力软快速开发框架 如有好的开发框架希望可以一起交流
- mvc模式开发
- MVC模式在游戏开发的应用
原地址: http://www.cocoachina.com/gamedev/2012/1129/5212.html MVC是三个单词的缩写,分别为:模型(Model).视图(View)和控制Cont ...
随机推荐
- 【CodeForces - 546C】Soldier and Cards (vector或队列)
Soldier and Cards 老样子,直接上国语吧 Descriptions: 两个人打牌,从自己的手牌中抽出最上面的一张比较大小,大的一方可以拿对方的手牌以及自己打掉的手牌重新作为自己的牌, ...
- 黑客攻防技术宝典web实战篇:攻击会话管理习题
猫宁!!! 参考链接:http://www.ituring.com.cn/book/885 随书答案. 1. 登录一个应用程序后,服务器建立以下 cookie:Set-cookie: sessid=a ...
- LuoguP2602 [ZJOI2010]数字计数【数位dp】By cellur925
题目传送门 题目大意:给定两个正整数a和b,求在[a,b]中的所有整数中,每个数码(digit)各出现了多少次. 继续数位dp=w=. 这一次我们不需要记录$pre$啦!(撒花). 因为这次我们需要的 ...
- deque双向队列
对于双向队列,与队列queue以及vector容器的区别就在于,名字不同,也就是它是双向的,可以从头开始操作,也可以从末尾开始操作. 双向队列的常用方法跟队列queue差不多: 头文件: #inclu ...
- CGI、ASP、PHP、JSP、 ASP.NET网站开发语言比较
一.主流网站开发语言的简介及优缺点. 现在主流的网站开发语言主要包括cgi.asp.php.asp.net.jsp等. HTML:当然这是网页最基本的语言,每一个服务器语言都需要它的支持. (一) ...
- 跟我一起玩Win32开发(14):用对话框作为主窗口
前面我们在编写Win32应用程序的思路都是: 1.设计窗口类.2.注册窗口类.3.创建窗口.…… 然而,当我们接触控件以后, 会发现一个问题,我们在窗口上放置控件实在不好弄,而资源中的对话框具有图形编 ...
- 搜狐前端css常用命名
- 记一次有关spark动态资源分配和消息总线的爬坑经历
问题: 线上的spark thriftserver运行一段时间以后,ui的executor页面上显示大量的active task,但是从job页面看,并没有任务在跑.此外,由于在yarn mode下, ...
- 大型Java Web项目的架构和部署问题
一位ID是jackson1225的网友在javaeye询问了一个大型Web系统的架构和部署选型问题,希望能提高现有的基于Java的Web应用的服务能力.由于架构模式和部署调优一直是Java社区的热门话 ...
- C# 获取本机IP(优化项目实际使用版)
好一段时间没来更新博客了,因为密码实在记不住,烦死了,密码干脆直接用那个找回密码链接的一部分. 吐槽完说正事了,关于C# 获取本机IP的,最开始用的是下面的,但是因为获取IP的有点多,而且难判断,忽 ...