一、相关的软件下载和环境配置

1、下载并配置JDK。

2、下载eclipse。

3、下载并配置apache-tomcat(服务器)。

4、下载MySQL(数据库)。

5、下载Navicat for MySQL(数据库可视化工具),方便对数据库的操作。

6、下载jdbc用来实现eclipse中的项目与数据库实现连接。

---以上可在网上查询教程

二、实现简单的课程信息管理系统

1、

打开eclipse,点击File—》New—》other—》Dynamic Web Project

(若你的eclipse中找不到或者没有Dynamic Web Project,可上网搜素解决办法)

点击后会出现如下窗口

需要填写Project name,可随意填写(最好是英文的),其他不需填写,填写完毕之后点击Finish

2、

项目建立完之后,eclipse左侧的Project Explorer会出现你建立的项目,如下图

3、

在我的电脑中,打开你下载的jdbc(也就是mysql-connector-java-8.0.13)所在的文件夹,如下图

将mysql-connector-java-8.0.13文件复制

粘贴在eclipse中,你所建立的项目下的 WebContent/WEB-INF/lib 文件夹下,如下图

然后,在你刚刚粘贴的文件上右击,Build Path—》Add to Build Path,如下图

这样就完成了jdbc的导入

4、

在 WebContent 文件夹下,新建如下图中的JSP文件,Login.jsp和signinerror.jsp是用来登陆的,这里不必建立。

4(1)head.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<style type="text/css"> .headdiv{
background-color:#3F51B5;
width:100%;
height:130px;
} .headdiv P{
font-family:YouYuan;
font-size:20px;
color:#E8EAF6;
position:relative;
left:20px;
top:45px;
} </style>
</head>
<body> <div class="headdiv">
<p>ec-web课程信息综合管理平台</p>
</div> </body>
</html>

4(2)left.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<style type="text/css"> .leftMenu{
background-color:#7986CB;
width:250px;
height:600px;
position:relative;
top:0px;
} .menuParent{
background-color:#BBDEFB;
} </style>
</head>
<body> <div class="leftMenu">
<div class="menu"> <div class="menuParent">
<div class="ListTitlePanel">
<div class="ListTitle">
<strong>课程信息管理</strong>
<div class="leftbgbt"></div>
</div>
</div> <div class="menuList">
<div><a target="mainAction" href="USEJSP/add.jsp">课程信息录入</a></div>
<div><a target="mainAction" href="USEJSP/update.jsp">课程信息修改</a></div>
<div><a target="mainAction" href="USEJSP/delete.jsp">删除课程信息</a></div>
<div><a target="mainAction" href="USEJSP/search.jsp">查询课程信息</a></div>
</div>
</div> </div>
</div> <script type="text/javascript"> </script> </body>
</html>

4(3)index.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
</head>
<body>
这是小主页
</body>
</html>

4(4)main.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>课程信息管理系统</title> <style type="text/css"> .headframe{
width:100%;
height:130px;
border:0;
} .leftframe{
float:left;
width:250px;
height:600px;
border:0;
} .mainframe{
float:right;
width:1200px;
height:600px;
border:0;
} </style> </head> <iframe src="head.jsp" class="headframe" scrolling="no"></iframe>
<iframe src="left.jsp" class="leftframe" scrolling="no"></iframe>
<iframe src="index.jsp" name="mainAction" class="mainframe"></iframe> </html>

5、

在WebContent文件夹下建立名为USEJSP的文件夹,在USEJSP文件夹下,建立如下图的JSP文件

5(1)add.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title> <style type="text/css"> .butn{
display:inline-block;
padding: 8px 35px;
background-color:#32CD32;
color:white;
border:none;
text-align:center;
text-decoration:none;
border-radius:5px;
position:absolute;
left:40px;
top:95px;
} </style> </head>
<body> <div class="container">
<section>
<form action="${pageContext.request.contextPath}/AddServlet/AddCurrServlet?method=add" method="post" onsubmit="return check()">
<!---${pageContext.request.contextPath}的目的是找到主工程的名字,/Servlet/Userservlet就是web.xml下面配置的路径,也就是servlet的路径--->
<span class="cname">课程名称</span>
<input type="text" name="cname" class="icname" placeholder=" class-name" id="icname">
<br/> <span class="teacher">任课教师</span>
<input type="text" name="teacher" class="iteacher" placeholder=" teacher" id="iteacher">
<br/> <span class="place">上课地点</span>
<input type="text" name="place" class="iplace" placeholder=" place" id="iplace">
<br/> <input type="submit" value="保&nbsp;存" class="butn">
<br/>
</form>
</section>
</div> <script type="text/javascript">
function check() { var cname = document.getElementById("icname");
var teacher = document.getElementById("iteacher");
var place = document.getElementById("iplace"); var placestr = place.value.substring(0,2); //非空
if(cname.value == '') {
alert('课程名称为空');
cname.focus();
return false;
}
if(teacher.value == '') {
alert('教师为空');
teacher.focus();
return false;
}
if(place.value == '') {
alert('上课地点为空');
place.focus();
return false;
} //教师
if(teacher.value != '王建民' && teacher.value != '王辉' && teacher.value != '刘丹' && teacher.value != '刘立嘉' && teacher.value != '杨子光'){
alert('教师名称错误');
return false;
} //教室
if(!/^基教/.test(placestr) && !/^一教/.test(placestr) && !/^二教/.test(placestr) && !/^三教/.test(placestr)) {
alert('上课地点错误');
return false;
}
return true;
} </script> </body>
</html>

5(2)addnameerror.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title> <style type="text/css"> .butn{
display:inline-block;
padding: 8px 35px;
background-color:#32CD32;
color:white;
border:none;
text-align:center;
text-decoration:none;
border-radius:5px;
position:absolute;
left:40px;
top:95px;
} </style> </head>
<body onload="alt()"> <div class="container">
<section>
<form action="${pageContext.request.contextPath}/AddServlet/AddCurrServlet?method=add" method="post" onsubmit="return check()">
<!---${pageContext.request.contextPath}的目的是找到主工程的名字,/Servlet/Userservlet就是web.xml下面配置的路径,也就是servlet的路径--->
<span class="cname">课程名称</span>
<input type="text" name="cname" class="icname" placeholder=" class-name" id="icname">
<br/> <span class="teacher">任课教师</span>
<input type="text" name="teacher" class="iteacher" placeholder=" teacher" id="iteacher">
<br/> <span class="place">上课地点</span>
<input type="text" name="place" class="iplace" placeholder=" place" id="iplace">
<br/> <input type="submit" value="保&nbsp;存" class="butn">
<br/>
</form>
</section>
</div> <script type="text/javascript">
function check() { var cname = document.getElementById("icname");
var teacher = document.getElementById("iteacher");
var place = document.getElementById("iplace"); var placestr = place.value.substring(0,2); //非空
if(cname.value == '') {
alert('课程名称为空');
cname.focus();
return false;
}
if(teacher.value == '') {
alert('教师为空');
teacher.focus();
return false;
}
if(place.value == '') {
alert('上课地点为空');
place.focus();
return false;
} //教师
if(teacher.value != '王建民' && teacher.value != '王辉' && teacher.value != '刘丹' && teacher.value != '刘立嘉' && teacher.value != '杨子光'){
alert('教师名称错误');
return false;
} //教室
if(!/^基教/.test(placestr) && !/^一教/.test(placestr) && !/^二教/.test(placestr) && !/^三教/.test(placestr)) {
alert('上课地点错误');
return false;
}
return true;
} function alt() {
alert('课程名称重复');
}
</script> </body>
</html>

5(3)delete.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html> <%@page import="java.sql.*"%>
<%@page import="java.sql.Connection"%>
<%@page import="java.sql.Statement"%>
<%@page import="java.sql.ResultSet"%>
<%@page import="java.sql.DriverManager"%>
<%@page import="javax.servlet.http.HttpServletRequest"%>
<html>
<head>
<meta charset="UTF-8">
<title></title> <style type="text/css"> .butn{
display:inline-block;
padding: 8px 35px;
background-color:#32CD32;
color:white;
border:none;
text-align:center;
text-decoration:none;
border-radius:5px;
position:absolute;
left:40px;
top:95px;
} </style> </head>
<body> <div>
<section>
<form action="${pageContext.request.contextPath}/DeleteServlet/DeleteCurrServlet?method=add" method="post" onsubmit="return check()">
<span class="cname">课程名称</span>
<input type="text" name="cname" id="icname" class="icname" placeholder=" class-name">
<br/> <input type="submit" value="删除" class="butn">
<br/>
</form>
</section>
</div> <script type="text/javascript">
function check() { var cname = document.getElementById("icname"); //非空
if(cname.value == '') {
alert('课程名称为空,请重新输入');
cname.focus();
return false;
}
return true;
} </script> </body>
</html>

5(4)search.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html> <%@page import="java.sql.*"%>
<%@page import="java.sql.Connection"%>
<%@page import="java.sql.Statement"%>
<%@page import="java.sql.ResultSet"%>
<%@page import="java.sql.DriverManager"%>
<%@page import="javax.servlet.http.HttpServletRequest"%>
<html>
<head>
<meta charset="UTF-8">
<title></title> <style type="text/css"> .butn{
display:inline-block;
padding: 8px 35px;
background-color:#32CD32;
color:white;
border:none;
text-align:center;
text-decoration:none;
border-radius:5px;
position:absolute;
left:40px;
top:95px;
} </style> </head>
<body> <div>
<section>
<form action="${pageContext.request.contextPath}/SearchServlet/SearchCurrServlet?method=add" method="post">
<span class="cname">课程名称</span>
<input type="text" name="cname" id="cname" class="icname" placeholder=" class-name">
<br/> <span class="teacher">任课教师</span>
<input type="text" name="teacher" id="teacher" class="iteacher" placeholder=" teacher">
<br/> <span class="place">上课地点</span>
<input type="text" name="place" id="place" class="iplace" placeholder=" place">
<br/> <input type="submit" value="查询" class="butn">
<br/>
</form>
</section>
</div> </body>
</html>

5(5)update.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html> <%@page import="java.sql.*"%>
<%@page import="java.sql.Connection"%>
<%@page import="java.sql.Statement"%>
<%@page import="java.sql.ResultSet"%>
<%@page import="java.sql.DriverManager"%>
<html>
<head>
<meta charset="UTF-8">
<title></title>
</head>
<body> <form action="${pageContext.request.contextPath}/UpdateServlet/UpdateCurrServlet?method=update" method="post" onsubmit="return check()">
<span class="cname">需要修改的课程名称</span>
<input type="text" name="tempcname" class="itempcname" placeholder=" class-name" id="itempcname">
<br/> <table border="1" bgcolor="#ffffff" align="" cellspacing="1" cellpadding="1">
<caption>输入修改信息</caption>
<tr>
<td align="center" width=16%>新课程名称</td>
<td align="center" width=16%>新任课教师</td>
<td align="center" width=25%>新上课地点</td>
<td align="center" width=16%>操作</td>
</tr> <tr>
<td width=16% align="center"><input type="text" name="cname" class="icname" placeholder=" class-name" id="icname"></td>
<td width=16% align="center"><input type="text" name="teacher" class="iteacher" placeholder=" teacher" id="iteacher"></td>
<td width=25% align="center"><input type="text" name="place" class="iplace" placeholder=" place" id="iplace"></td>
<td width=16% align="center"><input type="submit" value="修&nbsp;改" class="butn"></td>
</tr> </table>
</form> </body> <script type="text/javascript"> function check() { var ctempname = document.getElementById("itempcname");
var cname = document.getElementById("icname");
var teacher = document.getElementById("iteacher");
var place = document.getElementById("iplace"); var placestr = place.value.substring(0,2); //非空
if(ctempname.value == ''){
alert('需修改课程名称为空');
teacher.focus();
return false;
}
if(cname.value == '') {
alert('课程名称为空');
cname.focus();
return false;
}
if(teacher.value == '') {
alert('教师为空');
teacher.focus();
return false;
}
if(place.value == '') {
alert('上课地点为空');
place.focus();
return false;
} //教师
if(teacher.value != '王建民' && teacher.value != '王辉' && teacher.value != '刘丹' && teacher.value != '刘立嘉' && teacher.value != '杨子光'){
alert('教师名称错误');
return false;
} //教室
if(!/^基教/.test(placestr) && !/^一教/.test(placestr) && !/^二教/.test(placestr) && !/^三教/.test(placestr)) {
alert('上课地点错误');
return false;
}
return true;
} </script> </html>

6、

下面,生成web.xml文件(用来配置跳转路径)

在你的项目上右击,java EE Tool—》Generate Deployment Descriptor Stub

这样,在WebContent/WEB-INF文件夹下就生成了.xml文件,如下图

6(1)Web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" version="3.0">
<display-name>curriculum_information_management_web</display-name>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
<welcome-file>index.htm</welcome-file>
<welcome-file>index.jsp</welcome-file>
<welcome-file>default.html</welcome-file>
<welcome-file>default.htm</welcome-file>
<welcome-file>default.jsp</welcome-file>
</welcome-file-list> <servlet>
<servlet-name>Userservlet</servlet-name> <!--servlet的别名,随便取 --> <!--servlet的包路径,后面再加上.servlet类名 ,这里的类名必须是包下面的servlet类名,目的是让找到该servlet的路径 --> <servlet-class>com.Servlet.Userservlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>Userservlet</servlet-name> <!--servlet的别名,和上面保持一致就行 --> <!--jsp跳转到servlet的路径名,自己取,用来从jsp界面跳转到servlet的路径,程序会根据路径找到servlet的位置 --> <url-pattern>/Servlet/Userservlet</url-pattern><!-- -->
</servlet-mapping> <servlet>
<servlet-name>AddCurrServlet</servlet-name>
<servlet-class>com.Servlet.AddCurrServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>AddCurrServlet</servlet-name>
<url-pattern>/AddServlet/AddCurrServlet</url-pattern><!-- -->
</servlet-mapping> <servlet>
<servlet-name>SearchCurrServlet</servlet-name>
<servlet-class>com.Servlet.SearchCurrServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>SearchCurrServlet</servlet-name>
<url-pattern>/SearchServlet/SearchCurrServlet</url-pattern><!-- -->
</servlet-mapping> <servlet>
<servlet-name>DeleteCurrServlet</servlet-name>
<servlet-class>com.Servlet.DeleteCurrServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>DeleteCurrServlet</servlet-name>
<url-pattern>/DeleteServlet/DeleteCurrServlet</url-pattern><!-- -->
</servlet-mapping> <servlet>
<servlet-name>UpdateCurrServlet</servlet-name>
<servlet-class>com.Servlet.UpdateCurrServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>UpdateCurrServlet</servlet-name>
<url-pattern>/UpdateServlet/UpdateCurrServlet</url-pattern><!-- -->
</servlet-mapping> </web-app>

7、

在项目下的 Java Resources/src 建立包,如下图

然后,在各包下建立类,如图

7(1)com.Bean

建立CurrBean.java文件

package com.Bean;

public class CurrBean {
private String name;
private String teacher;
private String place; public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getTeacher() {
return teacher;
}
public void setTeacher(String teacher) {
this.teacher = teacher;
}
public String getPlace() {
return place;
}
public void setPlace(String place) {
this.place = place;
}
}

7(2)com.Dao(该包中的类是用来登录操作的,在这里只是写出来,不用实现)

建立Userdao.java文件

package com.Dao;

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.Statement; import com.DBUtil.*; public class Userdao {
public int login(String username,String password)
{
Connection conn = DBUtil.getConn();//这里就是从DBUtil类里面得到连接
Statement state =null;
ResultSet rs = null;
int flag=0;
try
{
String sql = "select * from admin";//SQL语句
state = conn.createStatement();
rs=state.executeQuery(sql);
while(rs.next())
{
if(rs.getString("password").equals(password)&&rs.getString("username").equals(username))
{
flag=1;
}
}
}
catch(Exception e)
{
e.printStackTrace();
}
finally
{
DBUtil.close(rs, state, conn);
}
return flag;
} }

7(3)com.DBUtil

建立CurrDBUtil.java文件(链接数据库)

package com.DBUtil;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement; public class CurrDBUtil {
public static String db_url="jdbc:mysql://localhost:3306/curriculum?useSSL=true&serverTimezone=UTC";
//这是连接数据库,userdome是数据库的名称,userUnicode=true&characterEncoding=UTF-8是将字符集设置为utf-8,避免乱码。
public static String db_user="root";//数据的用户名
public static String db_password="lty";//数据库的密码
public static Connection getConn()//获取连接,返回Connection类型,必须设置为static这样才能在其他类中使用
{
Connection conn=null;
try
{
Class.forName("com.mysql.jdbc.Driver");//加载驱动
conn=DriverManager.getConnection(db_url,db_user,db_password);//连接数据库
}
catch(Exception e)
{
e.printStackTrace();
}
return conn;
}
public static void close(Statement state,Connection conn)//关闭函数
{
if(state!=null)//只有状态和连接时,先关闭状态
{
try
{
state.close();
}
catch(SQLException e)
{
e.printStackTrace();
}
}
if(conn!=null)
{
try
{
conn.close();
}
catch(SQLException e)
{
e.printStackTrace();
}
}
}
public static void close(ResultSet rs,Statement state,Connection conn)
{
if(rs!=null)//有结果集,状态和连接时,先关闭结果集,在关闭状态,在关闭连接
{
try
{
rs.close();
}
catch(SQLException e)
{
e.printStackTrace();
}
}
if(state!=null) {
try
{
state.close();
}
catch(SQLException e)
{
e.printStackTrace();
}
}
if(conn!=null)
{
try
{
conn.close();
}
catch(SQLException e)
{
e.printStackTrace();
}
}
} }

建立DBUtil.java文件(用来链接登录数据库,不必实现)

package com.DBUtil;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement; public class DBUtil {
public static String db_url="jdbc:mysql://localhost:3306/userdome?useSSL=true&serverTimezone=UTC";
//这是连接数据库,userdome是数据库的名称,userUnicode=true&characterEncoding=UTF-8是将字符集设置为utf-8,避免乱码。
public static String db_user="root";//数据的用户名
public static String db_password="lty100609";//数据库的密码
public static Connection getConn()//获取连接,返回Connection类型,必须设置为static这样才能在其他类中使用
{
Connection conn=null;
try
{
Class.forName("com.mysql.jdbc.Driver");//加载驱动
conn=DriverManager.getConnection(db_url,db_user,db_password);//连接数据库
}
catch(Exception e)
{
e.printStackTrace();
}
return conn;
}
public static void close(Statement state,Connection conn)//关闭函数
{
if(state!=null)//只有状态和连接时,先关闭状态
{
try
{
state.close();
}
catch(SQLException e)
{
e.printStackTrace();
}
}
if(conn!=null)
{
try
{
conn.close();
}
catch(SQLException e)
{
e.printStackTrace();
}
}
}
public static void close(ResultSet rs,Statement state,Connection conn)
{
if(rs!=null)//有结果集,状态和连接时,先关闭结果集,在关闭状态,在关闭连接
{
try
{
rs.close();
}
catch(SQLException e)
{
e.printStackTrace();
}
}
if(state!=null) {
try
{
state.close();
}
catch(SQLException e)
{
e.printStackTrace();
}
}
if(conn!=null)
{
try
{
conn.close();
}
catch(SQLException e)
{
e.printStackTrace();
}
}
} }

7(4)com.Servlet

AddCurrServlet.java  实现课程的增加

package com.Servlet;

import java.io.IOException;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement; import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import com.Bean.CurrBean;
import com.DBUtil.*; public class AddCurrServlet extends HttpServlet { private static final long serialVersionUID = 1L; protected void doPost(HttpServletRequest req,HttpServletResponse resp)throws ServletException,IOException{
resp.setContentType("add.jsp");
req.setCharacterEncoding("UTF-8"); String name;
String teacher;
String place; name = req.getParameter("cname");
teacher = req.getParameter("teacher");
place = req.getParameter("place"); CurrBean currbean = new CurrBean(); currbean.setName(name);
currbean.setTeacher(teacher);
currbean.setPlace(place); AddCurrInterface addCurrInterface = new AddCurrInterface();
@SuppressWarnings("unused")
int temp = 0; try {
temp = addCurrInterface.addUser(currbean);
if(temp == 1) {
resp.sendRedirect(req.getContextPath()+"/index.jsp");
}else if(temp == 2) {
resp.sendRedirect(req.getContextPath()+"/USEJSP/addnameerror.jsp");
} } catch (SQLException e) {
e.printStackTrace();
}
}
} class AddCurrInterface extends HttpServlet{ private static final long serialVersionUID = 1L; public int addUser(CurrBean cb) throws SQLException { String name;
String teacher;
String place; name = cb.getName();
teacher = cb.getTeacher();
place = cb.getPlace(); //连接数据库
Connection conn = CurrDBUtil.getConn();
PreparedStatement pstmt = null; Statement stmt = conn.createStatement();
String selectsql = "select * from curr_info";
ResultSet rs = stmt.executeQuery(selectsql);
int tt = 0; while(rs.next()) {
if(rs.getString("name").equals(name)) {
tt = 2;
}
} if(tt == 0) {
String sql = "insert into curr_info (name,teacher,place) values (?,?,?)";//数据库指令
pstmt = conn.prepareStatement(sql);//发送sql语句
//下面是插入到具体的地方
pstmt.setString(1, name);
pstmt.setString(2, teacher);
pstmt.setString(3, place);
pstmt.executeUpdate(); System.out.println("添加成功!"); return 1;
}else if(tt == 2) {
return 2;
} return 0; } }

DeleteCurrServlet.java  实现课程的删除

package com.Servlet;

import java.io.BufferedWriter;
import java.io.IOException;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement; import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import com.DBUtil.CurrDBUtil; public class DeleteCurrServlet extends HttpServlet { private static final long serialVersionUID = 1L; protected void doPost(HttpServletRequest req,HttpServletResponse resp)throws ServletException,IOException{
resp.setContentType("delete.jsp");
req.setCharacterEncoding("UTF-8"); String name;
@SuppressWarnings("unused")
int ii = 0; name = req.getParameter("cname"); //连接数据库
Connection conn = CurrDBUtil.getConn();
try {
Statement stmt = conn.createStatement(); String selectsql = "select * from curr_info";
ResultSet rs = stmt.executeQuery(selectsql); while(rs.next()) {
if(rs.getString("name").equals(name)) {
ii = rs.getInt("id");
//Get output stream and writers
OutputStream out=resp.getOutputStream();
PrintWriter pw=new PrintWriter(new BufferedWriter(new OutputStreamWriter(out)));
//Print HTML
pw.println("<HTML><HEAD><TITLE>输出HTML标签</HEAD></TITLE><BODY>");
pw.println("<table border=\"1\" bgcolor=\"#ffffff\" align=\"\" cellspacing=\"1\" cellpadding=\"1\">");
pw.println("<tr>\r\n" +
"<td align=\"center\" width=16%>课程名称</td>\r\n" +
"<td align=\"center\" width=16%>任课教师</td>\r\n" +
"<td align=\"center\" width=35%>上课地点</td>\r\n" +
"</tr>");
pw.println("<tr>\r\n" +
"<td width=16% align=\"center\">"+rs.getString("name")+"</td>\r\n" +
"<td width=16% align=\"center\">"+rs.getString("teacher")+"</td>\r\n" +
"<td width=35% align=\"center\">"+rs.getString("place")+"</td>\r\n" +
"</tr>");
pw.println("该课程已删除!");
pw.println("</BODY></HTML>");
pw.flush();
pw.close();
}
} String delesql="delete from curr_info where name='"+name+"' ";//生成一条sql语句
stmt.executeUpdate(delesql);//执行sql语句 } catch (SQLException e) {
e.printStackTrace();
} }
}

SearchCurrServlet.java  实现课程的查询

package com.Servlet;

import java.io.BufferedWriter;
import java.io.IOException;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement; import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import com.DBUtil.CurrDBUtil; public class SearchCurrServlet extends HttpServlet { private static final long serialVersionUID = 1L; protected void doPost(HttpServletRequest req,HttpServletResponse resp)throws ServletException,IOException{
resp.setContentType("search.jsp");
req.setCharacterEncoding("UTF-8"); String name;
String teacher;
String place; name = req.getParameter("cname");
teacher = req.getParameter("teacher");
place = req.getParameter("place"); int temp = 0;
//连接数据库
Connection conn = CurrDBUtil.getConn();
try {
Statement stmt = conn.createStatement();
String selectsql = "select * from curr_info";
ResultSet rs = stmt.executeQuery(selectsql); //Get output stream and writers
OutputStream out=resp.getOutputStream();
PrintWriter pw=new PrintWriter(new BufferedWriter(new OutputStreamWriter(out)));
//Print HTML pw.println("<HTML><HEAD><TITLE>输出HTML标签</HEAD></TITLE><BODY>");
pw.println("<table border=\"1\" bgcolor=\"#ffffff\" align=\"\" cellspacing=\"1\" cellpadding=\"1\">");
pw.println("<tr>\r\n" +
"<td align=\"center\" width=16%>课程名称</td>\r\n" +
"<td align=\"center\" width=16%>任课教师</td>\r\n" +
"<td align=\"center\" width=35%>上课地点</td>\r\n" +
"</tr>");
while(rs.next()) {
if(rs.getString("name").equals(name) || rs.getString("teacher").equals(teacher) || rs.getString("place").equals(place)) {
pw.println("<tr>\r\n" +
"<td width=16% align=\"center\">"+rs.getString("name")+"</td>\r\n" +
"<td width=16% align=\"center\">"+rs.getString("teacher")+"</td>\r\n" +
"<td width=35% align=\"center\">"+rs.getString("place")+"</td>\r\n" +
"</tr>");
temp++;
}
/*
else {
//Get output stream and writers
OutputStream out=resp.getOutputStream();
PrintWriter pw=new PrintWriter(new BufferedWriter(new OutputStreamWriter(out)));
//Print HTML
pw.println("<HTML><HEAD><TITLE>输出HTML标签</HEAD></TITLE><BODY>");
pw.println("查询错误!");
pw.println("</BODY></HTML>");
pw.flush();
pw.close();
}
*/
}
if(temp == 0) {
pw.println("查询错误!");
} pw.println("</BODY></HTML>");
pw.flush();
pw.close(); } catch (SQLException e) {
e.printStackTrace();
} }
}

UpdateCurrServlet.java  实现课程的修改

package com.Servlet;

import java.io.IOException;
import java.sql.Connection;
import java.sql.SQLException;
import java.sql.Statement; import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import com.DBUtil.CurrDBUtil; public class UpdateCurrServlet extends HttpServlet { private static final long serialVersionUID = 1L; protected void doPost(HttpServletRequest req,HttpServletResponse resp)throws ServletException,IOException{
resp.setContentType("update.jsp");
req.setCharacterEncoding("UTF-8"); String tempname;
String name;
String teacher;
String place; tempname = req.getParameter("tempcname");
name = req.getParameter("cname");
teacher = req.getParameter("teacher");
place = req.getParameter("place"); //连接数据库
Connection conn = CurrDBUtil.getConn();
try {
Statement stmt = conn.createStatement();
String updatesql = "update curr_info set name='"+name+"',teacher='"+teacher+"',place='"+place+"' where name='"+tempname+"'";
stmt.executeUpdate(updatesql);//执行sql语句
resp.sendRedirect(req.getContextPath()+"/index.jsp");
} catch (SQLException e) {
e.printStackTrace();
}
}
}

从零开始,编写简单的课程信息管理系统(使用jsp+servlet+javabean架构)的更多相关文章

  1. 石家庄铁道大学课程信息管理系统(javaWeb+servlet+Mysql)

    实现网页版的课程管理系统,具有增删改查的功能. 1.首先连接数据库,具体数据库的使用及如何连接eclipse,参考     https://blog.csdn.net/lrici/article/de ...

  2. Java之从头开始编写简单课程信息管理系统

    编写简单的课程管理系统对于新手并不友好,想要出色的完成并不容易以下是我的一些经验和方法 详情可参考以下链接: https://www.cnblogs.com/dream0-0/p/10090828.h ...

  3. javaweb课程信息管理系统

    1.DBUtil包连接数据库 2.Bin包设计成员函数及方法 3.Dao包设计sql语句 4.servlet包增删改查方法 5.service连接servlet 6.设计jsp增删改查页面 7.连接各 ...

  4. 【python免费代码】设计一个简单的学生信息管理系统

    文章目录 前言 一.理解 二.部分截图展示 三.代码 四.总结 前言 设计一个简单的学生信息管理系统,实现以下功能(bug) : 录入学生信息,信息以文件方式存储 以学生学号或者学生姓名为条件查询该学 ...

  5. PHP实现简单的学生信息管理系统(web版)

    (∩_∩) 1.概述 学了php的一些基础,包括HTML,php,pdo,mysql操作等,一直都没有将它们有机结合.最近写了一个简单的网页版学生信息管理系统,前台用HTML,脚本用到了JavaScr ...

  6. 课程信息管理系统(javabean + Servlet + jsp)

    此项目做的事一个课程管理系统,需要通过web做一个可以实现课程的增删改查的功能. 需要用到数据库,Servlet和jsp等(第一次使用Servlet和数据库连接,所以代码都比较低级,页面也比较粗糙,还 ...

  7. C++ 简单的学生信息管理系统

    // // main.cpp // 2013-7-17作业1 // // Created by 丁小未 on 13-7-17. // Copyright (c) 2013年 dingxiaowei. ...

  8. python 写简单的职员信息管理系统

    职员信息管理系统要求依次从键盘录入每位员工的信息,包括姓名.员工id.身份证号要求:1.身份证号十八位,要求除了第18位可以为x,其余都只能为数字2.id须由5位数字组成3.否则提示用户重新输入不符合 ...

  9. JavaWeb 简单实现客户信息管理系统

    项目介绍 本项目使用Jsp+Servlet+MySQL实现 功能介绍 查询客户信息:查询数据库中所有客户信息,分页展示 添加客户信息:创建新客户并添加到数据库中 搜索客户信息:根据用户的输入查询客户信 ...

随机推荐

  1. 小记---------手动执行脚本正常执行,使用crontab定时执行时 不执行

    可能出现的原因就是因为crontab不会从用户的/etc/profile文件中读取环境变量,所以就出现 使用定时crontab执行时 无法执行 抛错 所以在使用crontab 定时执行脚本时  在脚本 ...

  2. 初步学习jquery学习笔记(二)

    jQuery事件 jquery是为事件处理而设计的 什么是事件? 页面对不同访问者的相应叫做事件. 事件处理程序指的是html中发生某些事件所调用的方法 实例: 在元素上移动鼠标 选取单选按钮 点击元 ...

  3. noip2011day2-观光公交

    题目描述 风景迷人的小城 \(Y\) 市,拥有 $n $个美丽的景点. 由于慕名而来的游客越来越多,\(Y\) 市特 意安排了一辆观光公交车,为游客提供更便捷的交通服务. 观光公交车在第 \(0\) ...

  4. ubuntu 个人常用命令

    重启命令 :     1.reboot     2.shutdown -r now 立刻重启    3.shutdown -r 10 过10分钟自动重启    4.shutdown -r 20:35 ...

  5. 04: CI(持续集成)/CD(持续交付/持续部署)

    1.1 持续集成.持续交付 介绍   参考博客:https://www.cnblogs.com/cay83/p/8856231.html 1.传统交付 1. 传统软件的开发与交付的周期都很漫长,从需求 ...

  6. [wpf]wpf full screen.

    void window_KeyDown(object sender,KeyEventArgs e) { if(e.Key == Key.F11) { Window.ResizeMode = Resiz ...

  7. Go基础学习

    Go基础学习 go的基础语法 fmt.Println("hello world!") //go采用行分隔符 关键字 下面列举了 Go 代码中会使用到的 25 个关键字或保留字: b ...

  8. 在docker容器下利用数据卷实现在删除了mysql容器或者镜像的情况下恢复数据

    当把mysql容器销毁,在新建一个容器,进行之前的数据恢复. 因为之前建立了数据卷,那么现在就可以利用这个数据卷进行数据恢复. 使用docker volume create volume_name命令 ...

  9. Vue示例教程

    <!DOCTYPE html> <html lang="en" xmlns:v-bind="http://www.w3.org/1999/xhtml&q ...

  10. 状态码是canceled

    timeout : 1000 给ajax配置如上属性 $.ajax({ type:"post", url:"pro/savePro", timeout : 10 ...