JSP+Servlet培训班作业管理系统[16]–校长角色之课程浏览功能实现

简介: 本文目录1. 本章任务2. 为校长添加菜单3. 跳转课程浏览页时携带课程数据4. 添加course.jsp页面5. 存在的问题6. 联表查询用户姓名6.1 修改Course类6.2 修改CourseDao6.3 修改courseView.jsp7. 总结

1. 本章任务

校长角色除了要完成人员管理之外,我们还希望校长可以查看所有课程信息。


注意课程是由教师发布的,校长只能查看,但是不能新增、修改、删除。


其实该功能与人员浏览几乎一模一样,我们以记流水账的形式再描述下,加深大家的开发印象。


2. 为校长添加菜单

public class Constants {

// 用于保存角色及对应的菜单信息

public static HashMap<String, String[][]> roleMenuMap = new HashMap<String, String[][]>();

// 使用static代码块对roleMenuMap进行初始化

static {

 // 校长拥有的菜单

 roleMenuMap.put("master", new String[][] { { "人员管理", "userManage.jsp" }, { "课程查看", "courseView.jsp" } });

}

}

1

2

3

4

5

6

7

8

9

3. 跳转课程浏览页时携带课程数据

修改RouteServlet.java


   else if (childPage.equals("courseView.jsp")) {

  CourseDao courseDao=new CourseDao();

  request.setAttribute("courses", courseDao.getCourses());

 }

1

2

3

4

4. 添加course.jsp页面

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>

<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%><!-- 使用c:标签需要添加本行代码 -->

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

<html>

<head>

<title>courseView.jsp</title>

<link href="css/content.css" type="text/css" rel="stylesheet" />

</head>

<body>

<div id="content_top">课程浏览</div>

<div id="content_mid">

 <table class="table_theme1">

  <thead>

   <tr>

    <th>课程编号</th>

    <th>课程名称</th>

    <th>授课教师</th>

   </tr>

  </thead>

  <c:forEach items="${course}" var="item">

   <tr>

    <td>${item.courseId}</td>

    <td>${item.courseName}</td>

    <td>${item.courseUser}</td>

   </tr>

  </c:forEach>

 </table>

</div>

</body>

</html>

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

5. 存在的问题

此处存在一个问题,就是courseUser存储的是用户的id,而我们界面上显示的时候,无疑是更想要得到用户的名字。


此处可以给Course类添加一个courseUserName冗余字段,注意该字段不参与insert/update等更新操作,只是查询时冗余出用户姓名而已。


6. 联表查询用户姓名

6.1 修改Course类

/**

* 课程类

*/

public class Course {

private int courseId;

private int courseUser;

private String courseName;


/**

 * 冗余字段,仅用于查询

 */

private String courseUserName;


// 省略get set方法

}


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

6.2 修改CourseDao

修改CourseDao的getCourses方法和makeOneCourse方法,联表查询出用户姓名。


/**

 * 获取全部

 */

public List<Course> getCourses() {

 Connection conn = null;

 PreparedStatement ps = null;

 ResultSet rs = null;

 List<Course> courses = new ArrayList<Course>();

 try {

  conn = DbUtils.getConnection();

  String sql = "select c.*,u.user_name from course c left join user u on c.course_user=u.user_id";

  ps = conn.prepareStatement(sql);

  rs = ps.executeQuery();

  while (rs.next()) {

   courses.add(makeOneCourse(rs));

  }

 } catch (SQLException e) {

 } finally {

  DbUtils.releaseConnection(rs, ps, conn);

 }

 return courses;

}


/**

 * 获取一个

 */

public Course makeOneCourse(ResultSet rs) throws SQLException {

 Course course = new Course();

 course.setCourseId(rs.getInt("course_id"));

 course.setCourseName(rs.getString("course_name"));

 course.setCourseUser(rs.getInt("course_user"));

 course.setCourseUserName(rs.getString("user_name"));

 return course;

}

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

6.3 修改courseView.jsp

用户名部分显示姓名:


   <table class="table_theme1">

  <thead>

   <tr>

    <th>课程编号</th>

    <th>课程名称</th>

    <th>授课教师</th>

   </tr>

  </thead>

  <c:forEach items="${courses}" var="item">

   <tr>

    <td>${item.courseId}</td>

    <td>${item.courseName}</td>

    <td>${item.courseUserName}</td>

   </tr>

  </c:forEach>

 </table>

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

7. 总结

处理联表查询的方式有很多,本章采取了一种比较简单方法,可能不够正规,或者性能不够好。


但是管他的呢,我们这个入门课程,采用这样的技术就够了。


看下效果如下,大功告成也!!

image.png

相关文章
|
5天前
|
自然语言处理 前端开发 Java
Servlet与JSP:Java Web开发的基石技术详解
【6月更文挑战第23天】Java Web的Servlet与JSP是动态网页的核心。Servlet是服务器端的Java应用,处理HTTP请求并响应;JSP则是结合HTML与Java代码的页面,用于动态内容生成。Servlet通过生命周期方法如`init()`、`service()`和`destroy()`工作,而JSP在执行时编译成Servlet。两者在MVC架构中分工,Servlet处理逻辑,JSP展示数据。尽管有Spring MVC等框架,Servlet和JSP仍是理解Web开发基础的关键。
|
5天前
|
存储 Java 关系型数据库
基于Servlet和JSP的Java Web应用开发指南
【6月更文挑战第23天】构建Java Web应用,Servlet与JSP携手打造在线图书管理系统,涵盖需求分析、设计、编码到测试。通过实例展示了Servlet如何处理用户登录(如`LoginServlet`),JSP负责页面展示(如`login.jsp`和`bookList.jsp`)。应用基于MySQL数据库,包含用户和图书表。登录失败显示错误信息,成功后展示图书列表。部署到Tomcat服务器测试功能。此基础教程为深入Java Web开发奠定了基础。
|
5天前
|
缓存 小程序 前端开发
Java服务器端技术探秘:Servlet与JSP的核心原理
【6月更文挑战第23天】Java Web开发中的Servlet和JSP详解:Servlet是服务器端的Java小程序,处理HTTP请求并响应。生命周期含初始化、服务和销毁。创建Servlet示例代码展示了`doGet()`方法的覆盖。JSP则侧重视图,动态HTML生成,通过JSP脚本元素、声明和表达式嵌入Java代码。Servlet常作为控制器,JSP处理视图,遵循MVC模式。优化策略涉及缓存、分页和安全措施。这些技术是Java服务器端开发的基础。
|
5天前
|
缓存 安全 Java
Java服务器端技术:Servlet与JSP的集成与扩展
【6月更文挑战第23天】Java Web开发中,Servlet和JSP是构建动态Web应用的基础。Servlet处理逻辑,JSP专注展示。示例展示了Servlet如何通过`request.setAttribute`传递数据给JSP渲染。JSP自定义标签提升页面功能,如创建`WelcomeTag`显示欢迎消息。Servlet过滤器,如`CacheControlFilter`,用于预处理数据或调整响应头。这些集成和扩展技术增强了应用效率、安全性和可维护性,是Java服务器端开发的关键。
|
5天前
|
前端开发 安全 Java
Java服务器端开发实战:利用Servlet和JSP构建动态网站
【6月更文挑战第23天】**Servlet和JSP在Java Web开发中扮演关键角色。Servlet处理业务逻辑,管理会话,JSP则结合HTML生成动态页面。两者协同工作,形成动态网站的核心。通过Servlet的doGet()方法响应请求,JSP利用嵌入式Java代码创建动态内容。实战中,Servlet处理数据后转发给JSP展示,共同构建高效、稳定的网站。虽然新技术涌现,Servlet与JSP仍为Java Web开发的基石,提供灵活且成熟的解决方案。**
|
5天前
|
缓存 负载均衡 安全
Servlet与JSP在Java Web应用中的性能调优策略
【6月更文挑战第23天】在Java Web中,Servlet和JSP调优至关重要,以应对高并发和复杂业务带来的性能挑战。优化包括Servlet复用、线程安全、数据库连接池,以及JSP的编译优化、使用JSTL、页面缓存和静态内容分离。全局优化涉及负载均衡、异步处理和缓存策略。通过这些实践,开发者能提升应用响应速度和吞吐量,确保高负载下的稳定运行。
|
5天前
|
搜索推荐 Java 数据库连接
探索Java Web开发:Servlet与JSP的协同工作原理
【6月更文挑战第23天】Java Web开发中,Servlet和JSP协同打造动态网站。Servlet是服务器端的Java程序,处理HTTP请求并执行复杂逻辑;JSP则结合HTML和Java,生成动态内容。Servlet通过`doGet()`等方法响应请求,JSP在首次请求时编译成Servlet。两者常搭配使用,Servlet处理业务,JSP专注展示,通过`RequestDispatcher`转发实现数据渲染。这种组合是Java Web应用的基础,即使新技术涌现,其价值仍然重要,为开发者提供了强大的工具集。
|
5天前
|
缓存 安全 小程序
从基础到进阶:掌握Java中的Servlet和JSP开发
【6月更文挑战第23天】Java Web开发中的Servlet和JSP是关键技术,用于构建动态网站。Servlet是服务器端小程序,处理HTTP请求,生命周期包括初始化、服务和销毁。基础Servlet示例展示了如何响应GET请求并返回HTML。随着复杂性增加,JSP以嵌入式Java代码简化页面创建,最佳实践提倡将业务逻辑(Servlet)与视图(JSP)分离,遵循MVC模式。安全性和性能优化,如输入验证、HTTPS、会话管理和缓存,是成功应用的关键。本文提供了一个全面的学习指南,适合各级开发者提升技能。
|
5天前
|
存储 缓存 安全
Servlet与JSP在Java服务器端开发中的实践与优化
【6月更文挑战第23天】本文探讨了Java中Servlet与JSP在在线书店系统开发中的应用,强调了它们在动态网站构建和Web效率中的作用。通过实例,展示了Servlet如何作为控制器处理用户登录,JSP则利用EL表达式呈现数据。此外,文章提及了性能优化如分页和缓存,以及安全措施如防止SQL注入和XSS攻击,强调了全面掌握和应用这些技术的重要性,以创建高效、安全的Web应用。
|
5天前
|
前端开发 小程序 Java
深入解析Java Servlet与JSP:构建高效服务器端应用
【6月更文挑战第23天】Java Servlet和JSP是Web开发的关键技术,用于构建高效服务器端应用。Servlet处理HTTP请求,执行业务逻辑,而JSP专注于动态HTML生成。两者结合,借助MVC架构,实现逻辑与视图分离,提高代码可读性和性能。尽管有新框架出现,Servlet和JSP仍是许多项目的基础。