搜档网
当前位置:搜档网 › 报刊订阅管理系统——课程设计说明书

报刊订阅管理系统——课程设计说明书

报刊订阅管理系统——课程设计说明书
报刊订阅管理系统——课程设计说明书

目录

1 需求分析 (1)

2 概要设计 (3)

3详细设计 (6)

4调试分析 (14)

5用户使用说明 (15)

6测试结果 (22)

7结论 (23)

8致谢 (24)

9附录 (25)

10参考文献 (32)

摘要

随着社会发展的多元化、信息化,订阅报刊的管理已经成为一个令人头痛的事情。由于现在报刊总类繁多,需求量大,交易速度快,如何在最短的时间内,对各种报刊进行有效的管理,已成为十分迫切的问题。

本系统是一个基于JAVA和数据库的企业报刊订阅管理系统。系统是智能化的管理系统,它面向企业所有的部门的职业用户,但具有安全性。它能够实现报刊订阅的基本功能,包括对用户、报刊信息的录入、统计、增删改查等操作。用户合法注

册后必须输入有效密码才能成功进入此系统,可以进行报刊订阅与退订,修改个人信息和订单信息等操作。

关键词:报刊订阅管理系统,JAVA,数据库

引言

随着社会不断的发展,人们的生活水平越来越高,对知识和时事的渴求也越来越高,人们希望能够方便快捷地订阅各种报刊杂志。但是各种各样的报刊名目和详细信息以及订阅,为相关企业的管理造成很大的麻烦。因此我们想到开发一个报刊订阅管理系统。

在本系统中,需要实现:管理员可以录入用户信息,报刊信息,同时可按用户名、报刊名、部门对系统进行相应的查询信息以及统计信息等功能;用户可以注册、更新自己的信息,同时还可以订阅、退订报刊和查询、修改订单。

1 需求分析

一直以来,人们在企业单位中都是使用传统人工方式管理单位的报刊订阅,这种管理方式存在着许多缺点,譬如,效率低,保密性差,而且时间一长,将产生大量的文件和数据,难以归类整理,这对于查找、更新和维护都带来了不少的麻烦。

通过学习,了解了JAVA、数据库,并在本次课程设计中利用这些知识点,实现一个面向于企业的报刊订阅管理系统,能够通过计算机和数据库对本单位的报刊订阅进行一系列的管理,实现智能化管理,克服了传统人工管理方式的缺点以及弊端。在报刊订阅管理系统中,要实现:管理员可以录入用户信息,报刊信息,同时可按用户名、报刊名、部门对系统进行相应的查询信息以及统计信息等功能;用户可以注册、更新自己的信息,同时还可以订阅、退订报刊和查询、修改订单。

订阅信息处理的特点是订阅信息处理量比较大,所管理的信息信息种类繁多,

而且订阅单、编辑单的发生量特别大,关联信息多,查询和统计的方式各不相同。因此在管理上实现起来有一定因难。

本系统在设计过程中,为了克服这些困难,需要使程序代码标准化,软件统一化,确保软件的可维护性和实用性;删除不必要的管理冗余,实现管理规范化、科学化;界面友好、简单化,做到实用、方便,尽量满足报刊订阅中员工的需要。

1.1任务与分析

(1)界面需求:用户界面简洁明了,提供功能实用,按钮逻辑排列清晰,容易使用。

(2)登陆功能需求:通过数据库连接,对管理员ID和密码进行身份验证,进入报刊订阅管理系统界面。

(3)录入功能: 1)系统管理员可以录入新用户信息,,信息一旦提交就存入到

后台数据库中;

2) 系统管理员可以录入新报刊信息,,信息一旦提交就存入到后台

数据库中。

(4)订阅功能:系统管理员可以代替用户订阅报刊,系统自动计算所需金额。

(5)查询功能:1) 管理员可以按人员查询信息。

2) 管理员可以按报刊查询信息。

3) 管理员可以按部门查询信息。

(6)统计功能:1) 管理员可以按人员统计信息。

2) 管理员可以按报刊统计信息。

3) 管理员可以按部门统计信息。

(7)注册:新用户可以注册新帐号,并且将新用户的数据提交到数据库中。

1.2测试数据

(1)管理员:用户名(admin)、密码(admin)。

(2)录入报刊信息:报刊代号(1-3)、报刊名称(华西都市报)、出版社(华西

都市报出版社)、出版日期(2016-05-10)、内容介绍(生活)、季

度报价(45)。

(3)注册:用户帐号(3120130901506)、真实姓名(赵六)、用户密码(1234)、

联系电话(183********)、部门名称(公关部)、部门号(0135)、用户联系地址(西华大学)。

(4)订阅报刊:用户帐号(3120130901506)、真实姓名(赵六)、报刊代号(1-3)、报刊名称(华西都市报)、部门名称(公关部)、部门号(0135)、订阅份数(2)。

2 概要设计

报刊订阅管理系统功能结构图如下:

本系统分为六大模块:

(1)登录功能:登录系统为身份验证登录。分为管理员登录和一般用户登录。分别通过不同的用户名和密码进入报刊订阅管理界面,新的用户需要注册。(2)录入新信息功能:录入报刊和用户信息,并能对报刊和用户信息进行增删

改查。

(3)订阅功能:用户可以订阅报刊,系统自动计算所需金额,并显示在界面上。

(4)查询功能:按人员查询、按报刊查询、按部门查询有关订阅信息,对查询结果能进行预览和打印。

(5)统计功能:按报刊统计、按人员统计、按部门统计,对统计结果能进行预览和打印。

(6)系统维护:权限管理,管理员只能登录管理员界面,用户只能根据正确的用户名和密码登录用户界面。

E-R如下:

数据库设计如下: admin管理员表

book订单表

users用户表

newspaper报刊表

3 详细设计

3.1主函数的实现

(1)连接数据库(Dbutils.java) package com.jdbc.utils;

import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet;

import java.sql.SQLException;

import java.sql.Statement;

import java.util.ResourceBundle;

public class Dbutils {

private static String driver;

private static String url;

private static String user;

private static String pwd;

private static ResourceBundle

rb=ResourceBundle.getBundle("com.jdbc.utils.jdbc");

static

{

driver=rb.getString("driver");

url=rb.getString("url");

user=rb.getString("user");

pwd=rb.getString("pwd");

try {

Class.forName(driver);

} catch (ClassNotFoundException e) {

// TODO 自动生成的 catch 块

e.printStackTrace();

}

}

private Dbutils() {}

public static Connection getConnection()

{

Connection conn=null;

try {

conn=DriverManager.getConnection(url,user,pwd); } catch (SQLException e) {

// TODO 自动生成的 catch 块

e.printStackTrace();

}

return conn;

}

public static void close(Connection conn,Statement stmt,ResultSet rs) {

try {

if(conn!=null)conn.close();

if(stmt!=null)stmt.close();

if(rs!=null)rs.close();

} catch (SQLException e) {

// TODO 自动生成的 catch 块

e.printStackTrace();

}

}

public static void main(String [] args)

{

System.out.println(getConnection());

}

}

(2)主界面:添加面板,页面跳转(其他页面类似)Main.java class Main extends JFrame implements ActionListener{ JRadioButton manager,users;

JLabel label,label1,label2;

JTextField userName;

JPasswordField password;

JButton login,register,exit;

JPanel p1,p2,p3;

public Main(){

init();

setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); setVisible(true);

}

void init(){

setLayout(new FlowLayout());

setSize(390,260);

p1=new JPanel();

p2=new JPanel();

p3=new JPanel();

label=new JLabel("欢迎使用报刊管理系统"); Font font=new Font("隶书",Font.PLAIN,30); label.setFont(font);

p1.add(label);

ButtonGroup group=new ButtonGroup(); manager=new JRadioButton("管理员");

users=new JRadioButton("用户");

group.add(manager);

group.add(users);

p2.add(manager);

p2.add(users);

label1=new JLabel("用户名");

p3.add(label1);

userName=new JTextField(10);

p3.add(userName);

label2=new JLabel("密码");

p3.add(label2);

password=new JPasswordField(10); p3.add(password);

add(p1,BorderLayout.CENTER);

add(p2,BorderLayout.CENTER);

add(p3,BorderLayout.CENTER);

login=new JButton("登录"); register=new JButton("注册");

exit=new JButton("退出");

add(login);

add(register);

add(exit);

userName.addActionListener(this); login.addActionListener(this); register.addActionListener(this); exit.addActionListener(this);

}

public static void main(String[] args)

{

Main f=new Main();

f.setTitle("报刊订阅管理系统");

}

public void actionPerformed(ActionEvent e) {

// TODO 自动生成的方法存根

if(e.getSource()==register) //注册(登录、退出类似)

{

new UsersRegister();//过渡到新的窗口Menu;

this.dispose();//释放当前窗口

}

}

3.2数据录入实现

录入报刊信息(录入用户信息和对用户、报刊、订单的增删改查与之类似) (1)LoggingdataNewspaper.java

public static void main(String[] args)

{

LoggingdataNewspaper f=new LoggingdataNewspaper();

f.setTitle("报刊信息");

}

public void actionPerformed(ActionEvent e) {

// TODO 自动生成的方法存根

if(e.getSource()==button5) // 退出

{

new ManagerHome();//过渡到新的窗口Menu;

this.dispose();//释放当前窗口

}

if(e.getSource()==button1) // 添加

{

//定义一个空的newspaper对象

newspaper news=new newspaper();

//将数据封装到news中

news.setNewsNo(text1.getText().trim());

news.setNewsName(text2.getText().trim());

news.setPublish(text3.getText().trim());

news.setPubPeriod(text4.getText().trim());

news.setContent(text5.getText().trim());

news.setPrice(Float.parseFloat(text6.getText().trim())); System.out.println(news);

//定义一个控制对象

InformationDaoImpl ifd=new InformationDaoImpl();

//执行添加用户操作

ifd.addNews(news);

}

if(e.getSource()==button2) // 删除

{

//定义一个空的newspaper对象

newspaper delnews=new newspaper();

//将数据封装到delnews中

delnews.setNewsNo(text1.getText().trim()); delnews.setNewsName(text2.getText().trim()); System.out.println(delnews);

//定义一个控制对象

InformationDaoImpl ifd=new InformationDaoImpl(); //执行添加用户操作

ifd.deleteNews(delnews);

}

if(e.getSource()==button3) // 查询

{

//定义一个空的newspaper对象

newspaper n=new newspaper();

//将数据封装在n中

String news=text1.getText().trim();

//定义一个控制对象

InformationDaoImpl ifd=new InformationDaoImpl(); n=ifd.FindNewsByNewspaper(news);

System.out.println(n);

text2.setText(n.getNewsName());

text3.setText(n.getPublish());

text4.setText(n.getPubPeriod());

text5.setText(n.getContent());

text6.setText(String.valueOf(n.getPrice())); }

if(e.getSource()==button4) // 修改

{

//定义一个空的users对象

newspaper news=new newspaper();

//将数据封装到u当中

news.setNewsNo(text1.getText().trim()); news.setNewsName(text2.getText().trim()); news.setPublish(text3.getText().trim()); news.setPubPeriod(text4.getText().trim()); news.setContent(text5.getText().trim());

news.setPrice(Float.parseFloat(text6.getText().trim())); //定义一个控制对象

InformationDaoImpl ifd=new InformationDaoImpl();

//执行修改用户信息操作

ifd.updateNewspaper(news);

System.out.println(news);

}

}

(2)InformationDaoImpl.java

//添加报刊

public void addNews(newspaper n){

//定义一个空的连接对象

Connection conn=null;

//定义一个准备sql语句

PreparedStatement ps=null;

//自定义将要执行的sql语句

String sql="insert into

newspaper(newsNo,newsName,publish,pubPeriod,content,price) values(?,?,?,?,?,?)";

//通过Dbutils得到数据库的连接

conn=Dbutils.getConnection();

System.out.println(conn);

try {

//将sql语句传给ps(接收sql语句的容器)

ps=conn.prepareStatement(sql);

//将news的各个属性值添加到?处

ps.setString(1, n.getNewsNo());

ps.setString(2, n.getNewsName());

ps.setString(3, n.getPublish());

ps.setString(4, n.getPubPeriod());

ps.setString(5, n.getContent());

ps.setFloat(6, n.getPrice());

//执行sql语句(相当于在数据库中执行sql语句)

相关主题