实验1:UML与面向对象程序设计原则

实验1:UML与面向对象程序设计原则

本次实验属于模仿型实验,通过本次实验学生将掌握以下内容:

1、掌握面向对象程序设计中类与类之间的关系以及对应的UML类图;

2、理解面向对象程序设计原则。

 
   

 


[实验任务一]:UML复习

阅读教材第一章复习UML,回答下述问题:

面向对象程序设计中类与类的关系都有哪几种?分别用类图实例说明。

1.继承关系    

继承指的是一个类(称为子类、子接口)继承另外的一个类(称为父类、父接口)的功能,并可以增加它自己的新功能的能力。在UML类图设计中,继承用一条带空心三角箭头的实线表示,从子类指向父类,或者子接口指向父接口。

 

2.实现关系     

实现指的是一个class类实现interface接口(可以是多个)的功能,实现是类与接口之间最常见的关系。用一条带空心三角箭头的虚线表示。

 

3.依赖关系     

依赖就是一个类A使用到了另一个类B,而这种使用关系是具有偶然性的、临时性的、非常弱的,但是类B的变化会影响到类A。表现在代码层面:类B作为参数被类A在某个method方法中使用。在UML类图设计中,依赖关系用由类A指向类B的带箭头虚线表示。用由类A指向类B的带箭头虚线表示。

 

4.关联关系  

关联体现的是两个类之间语义级别的一种强依赖关系,这种关系比依赖更强、不存在依赖关系的偶然性、关系也不是临时性的,一般是长期性的,而且双方的关系一般是平等的。关联可以是单向、双向的。表现在代码层面:被关联类B以类的属性形式出现在关联类A中,也可能是关联类A引用了一个类型为被关联类B的全局变量。在UML类图设计中,关联关系用由关联类A指向被关联类B的带箭头实线表示,在关联的两端可以标注关联双方的角色和多重性标记。

 

5.聚合关系     

聚合是关联关系的一种特例,它体现的是整体与部分的关系,即has-a的关系。此时整体与部分之间是可分离的,它们可以具有各自的生命周期,部分可以属于多个整体对象,也可以为多个整体对象共享。表现在代码层面:和关联关系是一致的,只能从语义级别来区分。在UML类图设计中,聚合关系以空心菱形加实线箭头表示。

 

6.组合关系     

组合也是关联关系的一种特例,它体现的是一种contains-a的关系,这种关系比聚合更强,也称为强聚合。它同样体现整体与部分间的关系,但此时整体与部分是不可分的,整体的生命周期结束也就意味着部分的生命周期结束。表现在代码层面,和关联关系是一致的,只能从语义级别来区分。在UML类图设计中,组合关系以实心菱形加实线箭头表示。

 

[实验任务二]:单一职责原则

登录模块在实际项目开发中很常见,请按照教材28页利用单一职责原则重构后的类图实现这一模块。

实验要求:

1.提交源代码和对应的数据库文件(注意将此模块保存,以备以后使用);

2.注意编程规范。

1)DAO.java

package login_;

import java.sql.Connection;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

public class DAO {

public user login(Connection con,user user) throws Exception{

 user resultUser=null;

String sql="select * from t_user where userName=? and password=?";

PreparedStatement pstmt=con.prepareStatement(sql);

pstmt.setString(1, user.getUserName());

pstmt.setString(2, user.getPassword());

    ResultSet rs=pstmt.executeQuery();

    if(rs.next()){

    resultUser=new user();

    resultUser.setUserName(rs.getString("userName"));

    resultUser.setPassword(rs.getString("password"));

    }

    return resultUser;

}

    //注册功能

    public boolean register(Connection con,user user) throws Exception{

        boolean flag=false;

        PreparedStatement pstmt = null;

        String sql="INSERT INTO t_user(userName,password)VALUES(?,?)";

        pstmt = con.prepareStatement(sql);

        pstmt.setString(1, user.getUserName());

        pstmt.setString(2, user.getPassword());

        if (pstmt.executeUpdate() > 0) {

                flag = true;

        }

        return flag;

        }

}

 

 

(2)DBUtil.java

package login_;

import java.sql.Connection;

import java.sql.DriverManager;

public class DBUtil {

    private String dbUrl="jdbc:mysql://localhost:3306/login";

    private String dbUserName="root";

    private String dbPassword="root";

    private String jdbcName="com.mysql.jdbc.Driver";

    public Connection getCon() throws Exception{

        Class.forName(jdbcName);

        Connection con=DriverManager.getConnection(dbUrl,dbUserName,dbPassword);

        return con;

    }

    public void closeCon(Connection con) throws Exception{

        if(con!=null){

            con.close();

        }

    }

    public static void main(String[] args) {

        DBUtil dbUtil=new DBUtil();

        try {

            dbUtil.getCon();

            System.out.println("数据库连接成功");

        } catch (Exception e) {

            // TODO Auto-generated catch block

            e.printStackTrace();

        }

    }

}

 

 

(3)LoginServlet.java

package login_;

import java.io.IOException;

import java.sql.Connection;

import javax.servlet.ServletException;

import javax.servlet.annotation.WebServlet;

import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

@WebServlet("/LoginServlet")

public class LoginServlet extends HttpServlet{

    @Override

    protected void doGet(HttpServletRequest req,HttpServletResponse resp)throws

    ServletException,IOException{

        this.doPost(req, resp);

    }

    @Override

    protected void doPost(HttpServletRequest req,HttpServletResponse resp)throws

    ServletException,IOException{

        String userName=req.getParameter("userName");

        String password=req.getParameter("passeord")

          BUtil db=new DBUtil();

        user user=new user(userName,password);

        DAO dao=new DAO();

        try {

            Connection con=db.getCon();

           

            if(dao.login(con, user)!=null){

                resp.sendRedirect("ok.jsp");

            }else {

                resp.sendRedirect("register.jsp");

            }

        }

        catch(Exception e) {

            e.printStackTrace();

        }

    }

}

 

 

(4)RegisterServlet.java

package login_;

import java.io.IOException;

import java.sql.Connection;

import javax.servlet.ServletException;

import javax.servlet.annotation.WebServlet;

import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

@WebServlet("/RegisterServlet")

public class RegisterServlet extends HttpServlet{

    @Override

    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

        this.doPost(req, resp);

    }

    @Override

    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

        String userName=req.getParameter("userName");

      String password=req.getParameter("password");

        DBUtil db= new DBUtil();

        user user=new user(userName,password);

        DAO dao=new DAO();

        try {

            //数据库链接

            Connection con=db.getCon();

            if(dao.register(con,user)) {

                resp.sendRedirect("login.jsp");

            }else {

                resp.sendRedirect("register.jsp");

            }

        } catch (Exception e) {

            e.printStackTrace();

}

    }

}

 

 

(5)user.java

package login_;

publicclass user {

    private String userName;

    private String password;

    public user() {}

    public user(String userName,String password) {

        this.userName=userName;

        this.password=password;

    }

    public String getUserName() {

        returnuserName;

    }

    publicvoid setUserName(String userName) {

        this.userName=userName;

    }

    public String getPassword() {

        returnpassword;

    }

    publicvoid setPassword(String password) {

        this.password=password;

    }

}

 

 

(6)login.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"

    pageEncoding="UTF-8"%>

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

<title>登录界面</title>

</head>

<body>

    <form action="LoginServlet" method="post">

    <h3>登录界面</h3>

        账号:<input type="text" name='userName'/><br/>

        密码:<input type="password" name='password'/><br/>

        <input type="submit" value="登录"/>

    </form>

</body>

</html>

 

 

(7)register.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"

    pageEncoding="UTF-8"%>

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

<title>会员注册</title>

</head>

<body>

    <form action="RegisterServlet" method="post">

        账号:<input type="text" name='userName'/><br/>

        密码:<input type="password" name='password'/><br/>

        <input type="submit" value="注册"/>

    </form>

</body>

 

</html>

 

posted @ 2022-10-15 19:16  萧贾jzm  阅读(92)  评论(0编辑  收藏  举报
//歌单id