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

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

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

 

[实验任务一]:UML复习

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

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

4种:泛化,关联,依赖,实现

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

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

实验要求:

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

2.注意编程规范。

DBUtil

package org.example;

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

import java.sql.SQLException;

import java.sql.Statement;

public class DBUtil {

public static String db_url = "jdbc:mysql://localhost:3306/first?serverTimezone=GMT%2B8&useSSL=false";

public static String db_user = "root";

public static String db_pass = "wwsa20030207";

public static Connection getConn () {

Connection conn = null;

try {

Class.forName("com.mysql.cj.jdbc.Driver");

conn = DriverManager.getConnection(db_url, db_user, db_pass);

} catch (Exception e) {

e.printStackTrace();

}

return conn;

}//end getConn

 

    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();

}

}

}

public static void main(String[] args) throws SQLException {

Connection conn = getConn();

PreparedStatement pstmt = null;

ResultSet rs = null;

String sql ="select * from user";

pstmt = conn.prepareStatement(sql);

rs = pstmt.executeQuery();

if(rs.next()){

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

}else{

System.out.println("连接失败");

}

}

}

LoginForm

package org.example;

import java.awt.*;

import java.awt.event.*;

import javax.swing.*;

public class LoginForm extends JFrame {

private static final long serialVersionUID = 1L;

private  UserDao dao = new UserDao();

//设置按钮组件

 

    private  JButton jb=new JButton("登录");    //添加一个登录按钮

    private JButton button=new JButton("重置");    //添加一个确定按钮

    //设置文本框组件

    private JTextField username = new JTextField();//用户名框

    private JPasswordField password = new JPasswordField();//密码框:为加密的***

 

    JLabel user_name=new JLabel("账号:");//设置左侧用户名文字

    JLabel pass_word=new JLabel("密码:");//设置左侧密码文字

 

    public void init()

{

/* 组件绝对位置  */

        user_name.setBounds(50, 70, 300, 25);

pass_word.setBounds(50, 130, 200, 25);

username.setBounds(110, 70, 300, 25);//设置用户名框的宽,高,x值,y

        password.setBounds(110, 130, 300, 25);//设置密码框的宽,高,x值,y

 

        button.setBounds(315, 225, 90, 20);//设置确定按钮的宽,高,x值,y

        jb.setBounds(95, 225, 90, 20);//设置确定按钮的宽,高,x值,y

 

 

        /* 组件透明化*/

        user_name.setOpaque(false);

pass_word.setOpaque(false);

//监听事件

        jb.addActionListener(new ActionListener(){        //为确定按钮添加监听事件

 

            @SuppressWarnings("deprecation")

public void actionPerformed(ActionEvent arg0) {

validate(username.getText().trim(),password.getText().trim());

}

});

//重置按钮

        button.addActionListener(new ActionListener(){        //为重置按钮添加监听事件

            //同时清空namepassword的数据

            public void actionPerformed(ActionEvent arg0) {

// TODO 自动生成方法存根

                username.setText("");

password.setText("");

}

});

}

public void display()

{

JFrame f =new JFrame();

f.setTitle("登录页面");

//窗口退出行为

        f.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

//设置窗口大小不可变

        f.setResizable(false);

//设置窗口打开居中

        f.setLocationRelativeTo(null);

//窗口大小

        f.setSize(500, 300);

init();

//添加组件

        Container contentPanel= new Container();//添加一个contentPanel容器

        contentPanel.setLayout(null);//设置添加的contentPanel容器为流布局管理器

        contentPanel.add(user_name);

contentPanel.add(pass_word);

contentPanel.add(username);

contentPanel.add(password);

contentPanel.add(jb);

contentPanel.add(button);

f.add(contentPanel);

//展示窗口

        f.setVisible(true);

}

public  void  validate(String username,String password)

{

if(username.trim().length()==0||password.trim().length()==0){

JOptionPane.showMessageDialog(null, "用户名,密码不允许为空");

return;

}

if(dao.findUser(username, password))

{

JOptionPane.showMessageDialog(null, "登录成功!");

}else {

JOptionPane.showMessageDialog(null, "用户名或密码错误");

}

}

}

MainClass

package org.example;

public class MainClass {

public static void main(String[] args)

{

LoginForm loginForm=new LoginForm() ;    //调用

        loginForm.display();

}

}

UserDao

package org.example;

import java.sql.Connection;

import java.sql.ResultSet;

import java.sql.SQLException;

import java.sql.Statement;

public class UserDao {

public boolean findUser(String username, String password) {

//准备SQL语句

        String sql = "select * from user where username ='" + username + "'";

Connection conn= DBUtil.getConn();

//创建语句传输对象

        Statement state = null;

ResultSet rs= null;

int flag=0;

String c_password=null;

try {

state = conn.createStatement();

rs = state.executeQuery(sql);

while(rs.next()) {

++flag;

c_password=rs.getString("password");

}    if (flag == 0) {

return false;

}

if (!password.equals(c_password)) {   //判断密码

                return false;

}

}catch (SQLException e) {

// TODO Auto-generated catch block

            e.printStackTrace();

}finally {

DBUtil.close(rs, state, conn);

}

return true;

}

}

Sql文件

/*

Navicat Premium Data Transfer

Source Server         : localhost

Source Server Type    : MySQL

Source Server Version : 80031 (8.0.31)

Source Host           : localhost:3306

Source Schema         : first

Target Server Type    : MySQL

Target Server Version : 80031 (8.0.31)

File Encoding         : 65001

Date: 23/10/2023 09:14:58

*/

SET NAMES utf8mb4;

SET FOREIGN_KEY_CHECKS = 0;

-- ----------------------------

-- Table structure for user

-- ----------------------------

DROP TABLE IF EXISTS `user`;

CREATE TABLE `user`  (

`username` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL,

`password` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL

) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;

-- ----------------------------

-- Records of user

-- ----------------------------

INSERT INTO `user` VALUES ('123zhang', '123456');

SET FOREIGN_KEY_CHECKS = 1;

 

[实验任务三]:依赖倒转原则与合成复用原则

在一画图软件中提供了多种大小不同的画笔,并且可以给画笔指定不同的颜色,某设计人员对画笔进行了如上图所示的设计。通过分析,可以发现增加画笔的种类和颜色会使得系统中类的数目急剧增加,请根据合成复用原则和依赖倒转原则对上述设计进行重构。

实验要求:

1. 提交源代码;

BigPen

package org.example.test2;

public class MianClass {

public static void main(String[] args) {

//颜色大小随意组合

        Pen pen=new Pen();

//组合小型红色钢笔

        pen.setSize(new SmallPen());

pen.setColor(new RedPen());

//组合大型绿色钢笔

        pen.setSize(new BigPen());

pen.setColor(new GreenPen());

}

}

Color

package org.example.test2;

public abstract class Color {

public abstract void colorPen();

}

GreenPen

package org.example.test2;

public class GreenPen extends Color{

public void colorPen() {

System.out.println("绿色");

}

}

MainClass

package org.example.test2;

public class MianClass {

public static void main(String[] args) {

//颜色大小随意组合

        Pen pen=new Pen();

//组合小型红色钢笔

        pen.setSize(new SmallPen());

pen.setColor(new RedPen());

//组合大型绿色钢笔

        pen.setSize(new BigPen());

pen.setColor(new GreenPen());

}

}

MiddlePen

package org.example.test2;

public class MiddlePen extends Size {

//中型

    public void sizePen() {

System.out.println("中型");

}

}

Pen

package org.example.test2;

public class Pen {

//钢笔

    private Size size;

private Color color;

public Size getSize() {

return size;

}

public void setSize(Size size) {

this.size = size;

}

public Color getColor() {

return color;

}

public void setColor(Color color) {

this.color = color;

}

}

RedPen

package org.example.test2;

public class RedPen extends Color {

public void colorPen() {

System.out.println("红色");

}

}

Size

package org.example.test2;

public abstract class Size {

public abstract void sizePen();

}

SmallPen

package org.example.test2;

public class SmallPen extends Size {

//小型

    public void sizePen() {

System.out.println("小型");

}

}

2. 画出重构后的类图。

实验1:UML与面向对象程序设计原则的更多相关文章

  1. UML与面向对象程序设计原则

    [实验任务一]:UML复习 阅读教材第一章复习UML,回答下述问题: 面向对象程序设计中类与类的关系都有哪几种?分别用类图实例说明. 1.  关联关系 (1)  双向关联 (2)  单向关联 (3)  ...

  2. 20162308 实验二《Java面向对象程序设计》实验报告

    20162308 实验二<Java面向对象程序设计>实验报告 实验内容 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装.继承.多态 初步掌握UML建模 熟悉S.O.L.I.D原则 ...

  3. 20162330 实验二 《Java面向对象程序设计》 实验报告

    2016-2017-2 实验报告目录: 1 2 3 4 5 20162330 实验二 <Java面向对象程序设计> 实验报告 课程名称:<程序设计与数据结构> 学生班级:162 ...

  4. 2018-2019-2 20175217 实验二《Java面向对象程序设计》实验报告

    一.实验报告封面 课程:Java程序设计 班级:1752班 姓名:吴一凡 学号:20175217 指导教师:娄嘉鹏 实验日期:2019年4月15日 实验时间:--- 实验序号:实验二 实验名称:Jav ...

  5. 20175221曾祥杰 实验二《Java面向对象程序设计》

    实验二<Java面向对象程序设计> 实验报告封面 课程:Java程序设计 班级:1752班 姓名:曾祥杰 学号:20175221 指导教师:娄嘉鹏 实验日期:2019年4月17日 实验时间 ...

  6. 20175209 实验二《Java面向对象程序设计》实验报告

    20175209 实验二<Java面向对象程序设计>实验报告 一.实验前期准备 了解三种代码 伪代码 产品代码 测试代码 我们先写伪代码,伪代码 从意图层面来解决问题: 有了伪代码 我们用 ...

  7. 20175315 实验二《Java面向对象程序设计》实验报告

    20175315 实验二<Java面向对象程序设计>实验报告 一.实验内容及步骤 1.初步掌握单元测试和TDD 单元测试 任务一:三种代码 用程序解决问题时,要学会写以下三种代码: 伪代码 ...

  8. 2018-2019-2 20175320实验二《Java面向对象程序设计》实验报告

    2018-2019-2 20175320实验二<Java面向对象程序设计>实验报告 一.实验步骤及内容 (一)了解使用JUint,并对示例代码MyUtil进行测试 1.先在IDEA中安装J ...

  9. #20175201 实验二:Java面向对象程序设计

    20175201 实验二:Java面向对象程序设计 实验二 Java面向对象程序设计 实验内容 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装.继承.多态 初步掌握UML建模 熟悉S.O.L ...

  10. 2018-2019-2 20175317 实验二《Java面向对象程序设计》实验报告

    2018-2019-2 20175317 实验二<Java面向对象程序设计>实验报告 一.实验步骤及内容 面向对象程序设计-1 参考 http://www.cnblogs.com/roce ...

随机推荐

  1. 4.4 C++ Boost 数据集序列化库

    Boost 库是一个由C/C++语言的开发者创建并更新维护的开源类库,其提供了许多功能强大的程序库和工具,用于开发高质量.可移植.高效的C应用程序.Boost库可以作为标准C库的后备,通常被称为准标准 ...

  2. Windows安装、配置、卸载MySQL教程

    MySQL是一个关系型数据库管理系统,目前为Oracle旗下产品,它具有开源.体积小.速度快的优点,许多网站使用的都是MySQL数据库. 简单而言,MySQL数据库核心功能就是用来存储数据的. MyS ...

  3. 现代 CSS 解决方案:原生嵌套(Nesting)

    很早之前,就写过一篇与原生嵌套相关的文章 -- CSS 即将支持嵌套,SASS/LESS 等预处理器已无用武之地?,彼时 CSS 原生嵌套还处于工作草案 Working Draft (WD) 阶段,而 ...

  4. 分布式环境下Session共享问题解决和原理讲解

    1.分布式环境下Session共享问题: 2.几种解决方法 3.通过后端统一存储方法在实际项目中问题的体现: 当session的作用域只限于auth.gulimall.com时,在auth.gulim ...

  5. Visual Studio 2022 Preview 3和2019 16.11发布

    Visual Studio 2022 Preview 3 主要特点 个人和团队生产力 附加到进程改进 新项目设计器 黑暗主题提升 开发现代应用 远程测试 新的JavaScript和TypeScript ...

  6. Vue源码学习(七):合并生命周期(混入Vue.Mixin)

    好家伙,   1.使用场景 现在来,来想一下,作为一个使用Vue的开发者,假设现在我们要使用created(),我们会如何使用 1.1.  .vue文件中使用 <template> < ...

  7. 兴达易控modbus转profinet网关三菱变频器通讯

    兴达易控modbus转profinet网关与三菱变频器通讯 本案例分享兴达易控modbus转profinet网关(MDPN100)连接西门子1200plc,实现三菱变频器485通讯兼容转modbusT ...

  8. 文心一言 VS 讯飞星火 VS chatgpt (99)-- 算法导论9.3 5题

    五.用go语言,假设你已经有了一个最坏情况下是线性时间的用于求解中位数的"黑箱"子程序.设计一个能在线性时间内解决任意顺序统计量的选择问题算法. 文心一言: 为了在线性时间内解决任 ...

  9. ReactPortals传送门

    ReactPortals传送门 React Portals提供了一种将子节点渲染到父组件以外的DOM节点的解决方案,即允许将JSX作为children渲染至DOM的不同部分,最常见用例是子组件需要从视 ...

  10. linux常见命令(五)

    用于文本内容处理的相关命令 sort uniq cut comm diff sort:对文件中数据进行排序,并将结果显示在标准输出上 命令语法:sort [选项] [文件] 选项 选项含义 -m 如果 ...