小型超市进销存管理系统的设计与实现.doc
本科毕业设计(论文)题 目: 小型超市进销存管理系统的设计与实现院 系: 计算机科学系 专 业: 计算机科学与技术 姓 名: 学 号: 指导教师: 教师职称: 填写日期: 2012年 4月27日摘要最初的小型超市进销存管理都是靠人力来完成的,随着我国小型超市经营规模日益扩大,销售额和门店数大幅度增加,许多小型超市正向品种多样化发展,需要处理大量的信息,时刻要更新产品销售信息,不断添加商品信息,并对商品的各种信息进行统计分析。一般大中型小型超市都具有完善的进销存管理体系,但是针对于小型小型超市的这种系统还不多见。有鉴于小型小型超市数量多,种类较丰富,操作人员少的特点,小型小型超市进销存管理系统的设计重在操作简单,功能齐备,一目了然。本系统主要针对小型小型超市的管理,包括顾客管理、厂家管理、商品管理、退货管理,购物车管理,采购管理、个人管理,管理员管理,系统管理等几个方面。系统可以完成对各类信息的浏览、查询、添加、删除、修改等功能。系统采用C/S架构,采用MySQL来设计数据库,并使用优秀的集成开发工具Eclipse并安装MyEclipse插件,使用当前主流的Hibernate和Spring框架,项目运行环境为JDK1.6。开发模式采用敏捷开发模式,使用CVS进行协同开发,代码书写格式规范,注释详细。关键字:MySQL 、小型超市、Eclipse、进销存管理系统AbstractThe supermarket Invoicing management is to rely on manpower to complete, along with our country supermarket the increasing scale of operation, sales and store numbers greatly increased, many supermarkets to breed diversification development, need to process large amounts of information, to update the product sales information, and constantly add product information, goods and a variety of statistical information analysis of. General large and medium-sized supermarkets have improved the Invoicing management system, but for the small supermarket this system also does not see more. In view of the small supermarket amount much, type is rich, few operating staff characteristics, small supermarket Invoicing management system design is simple operation, complete functions, stick out a mile. This system mainly for small supermarket management, including customer management, vendor management, commodity management, returns management, shopping cart management, procurement management, personal management, administrator management, system management and so on several aspects. System can complete all types of information browsing, query, add, delete, modify the functions of. The system adopts C / S structure, using MySQL to design the database, and use the excellent integrated development tool Eclipse and install MyEclipse plug-in, the use of the current mainstream Hibernate and Spring framework, project operating environment for JDK1.6. Development of model using agile development mode, the use of CVS collaborative development, code writing format specification, detailed notes.Keywords: MySQL 、supermarket、Eclipse、Enterprise Resourse Planning (ERP)目 录摘要IAbstractII第一章 概述1第二章 系统分析2第一节 可行性分析2一、技术可行性2二、经济可行性2三、操作可行性2四、运行可行性2第二节 系统需求分析2一、职能分析3二、功能分析3三、附加功能4第三章 系统设计与实现5第一节、数据库设计5一、E-R图6二、使用使用PowerDesigner建模7三、数据字典8第二节 功能模块设计13第三节 模块的实现15一、登陆功能实现15二、商品管理实现17三、购物车管理模块实现20四、管理员功能模块实现23第四章 系统测试与发布26第一节 单元测试概述26第二节 什么是单元测试26第三节 系统打包发布26第四节 API参考文档27第五章 总结与展望28致谢29参考文献30第一章 概述小型小型超市一般是十人以下,分布较广的小型超市集群。针对与小型小型超市的进销存管理系统,其开发主要包括后台数据库的建立和维护以和前端界面程序的开发两个方面。小型小型超市进销存管理系统在设计上体现了人性化和“以人为本”的精神,要求操作简单,权限明确,功能完善。界面设计上亲切友好,简单直观,便于操作。系统的核心是进货、销售和库存三者之间的联系,每一个表的修改都将会牵扯到其它的表,当完成进货、销售和退货操作时系统会自动地完成相对应信息的修改。查询功能也是系统的核心之一,在系统中可以进行模糊查询和精确查询,其目的都是为了方便用户使用,以求更快的查找到相应的基本信息。利用小型超市管理系统可以在以下几个方面提高小型超市管理的水平:ü 提高管理效率ü 提高销售额ü 降低人工成本ü 降低采购成本ü 商业数据智能分析ü 高效决策第二章 系统分析第一节 可行性分析随着市场经济和现代技术的发展,小型超市的管理系统逐渐走向信息化。为了更加节约人力资源,压缩成本,简便操作,小型超市进销存管理系统的建立尤为必要。而随着小型超市的普和,针对小型超市的进销存管理系统将应运而生。我们从技术、经济、操作、运行等几个方面进行可行性分析。一、技术可行性从技术角度分析,这项开发工作所涉和的专业技术为:Java编程技术、Swing、J2SE、MySQL、Hibernate、Spring。二、经济可行性采用计算机管理不但可以提高工作效率,而且还可以节省人力、物力、财力,这样原来几个人干的工作现在一个人就完全可以胜任。因此单从节省的职工工资、提高工作效率而避免各种直接或间接的经济损失角度来看,该系统实际所能够起到的作用将会远远大于投入的开发费用,所以从经济上是完全可行的。三、操作可行性开发所采用的工具是MyEclipse,开发出的应用程序均是图形化界面,操作员几乎不用记住任何DOS命令就可以直接操作此软件。另外,软件的操作员大多已经会基本的Windows操作,即便不会操作Windows,经过短期的培训也能熟练地使用本软件,所以在操作上也是可行的。四、运行可行性本系统经过精心设计开发,比较紧凑,项目比较小,所以对软硬的要求并不高,运行投入也相对较少,现在普通的电脑都能够满足条件,因此,本系统在运行上是可行的。综上所述,此系统开发目标已明确,在技术和经济等方面都可行,不会存在问题,并且投入少、效率高。因此认为该小型小型超市进销存管理系统可以开发。第二节 系统需求分析小型超市进销存系统必须提供顾客信息、厂家信息、采购信息、销售信息、库存信息和财务信息的基础设计,提供强大的精确查找和模糊查找信息的功能,可以分不同权限、不同用户对该系统进行操作。另外,该系统还必须保证数据的安全性、完整性和准确性。小型超市进销存管理系统的目标是实现小型超市信息化管理,减少盲目采购、降低采购成本、合理控制库存、减少资金占用并提升小型超市综合竞争力。时间就是金钱,效率就是生命。小型超市进销存管理系统能够为小型超市节省大量人力资源,减少管理费用,从而间接为小型超市节约成本,提高小型超市效率,创造收益。一、职能分析通过与各种类型小型超市人员进行交流,发现小型超市管理系统需要满足来自多个不同用户的要求。在小型超市经营中,按照人员的职能分为五大类,分别是顾客、营业员、采购员、经理、系统管理员。从小型超市的角度出发,一般也具有这五大职能类别。顾客顾客是小型超市的上帝,是小型超市创造收入的直接对象,因此小型超市的所有商品都是建立在顾客的需求上的!而顾客的要求就是能购买到经济实惠的商品。我将顾客按类型分为三种:1.普通顾客:购买次数少,金额小。购买商品(无积分,无须注册)。2.会员:购买次数多,金额比较大,是主要服务对象购买商品送积分,办会员卡免费,有充值功能!如果充值金额大于100,每充100元送5元,积分用于节日促销活动。3.贵宾:购买次数一般,金额大,是需要经常维护的对象。会员积分达到一定的数量时,可以转成贵宾卡,购买商品送更多的积分,有充值功能!如果充值金额大于100,每充100元送5元,积分用于节日促销活动。贵宾拥有更多的权利。采购员采购员的要求是查看经理指派给自己的所有采购信息并按规定完成任务,即去联系厂家并按规定验收采购的商品,并退回不合格的采购商品。修改自己的账号密码。营业员营业员的要求是销售商品给顾客,添加购物车信息、可以查看、查找、添加、修改顾客信息、但不可以删除顾客信息。并做好记录顾客因各种原因而退货的商品信息。修改自己的账号密码。经理经理的要求是能够查看1)采购、2)销售、3)库存、4)商品、5)营业额等信息从而进行高效决策,如:下达采购信息;添加删除用户,即雇佣和解雇职员。修改自己的账号密码。系统管理员系统管理员只具有管理用户和管理系统的权限,不具备所有用户的权限,即没有采购员、营业员、经理等角色的权限。修改自己的账号密码。二、功能分析小型超市的管理系统必须建立在实用,适用的基础上,因此在通过与小型超市管理人员进行反复的讨论后,最终确定系统应该实现以下功能:(一) 对商品信息的变动进行处理在商品的采购和销售过程中,商品信息总是在不断变化的,比如商品价格的调整、商品信息的修改、新商品信息的增加以和旧商品信息的删除,因此设计系统时必须考虑到这些情况。商品信息有商品编号、商品名、商品数量、商品规格、商品价格、厂家名等属性。(二) 对用户信息的变动进行处理需考虑到职员的雇佣和解雇、所以用户信息的修改和删除也是要有的。(三) 对采购信息的变动进行处理采购员在采购的过程中采购信息也在不断发生改变,因此也要充分考虑。采购信息有采购编号、采购日期、商品厂家、采购员、商品价格、商品规格、商品数量等属性。(四) 对销售信息的变动进行处理营业员在销售的过程中销售信息也在不断发生改变,如顾客买到了劣质产品要求退货,因此也要充分考虑。(五) 查询和统计功能要求可以根据指定的条件对厂家信息、顾客信息、商品信息、采购信息、销售信息进行查询和对每天账务的收入支出进行统计查询!查询又分为精确查询和模糊查询。三、附加功能为了能当小型超市增加新的业务需求时能方便的升级系统,所以系统应当具有良好的扩张性,将能够与第三方产品对接,比如:与短信平台对接以提供短信发送和接收功能;与声讯系统对接,提供自动呼叫服务;与邮件系统对接以发送和接受邮件;当然,种种功能的完善和实现,都需要进一步的研究和更新。第三章 系统设计与实现根据系统分析的描述以和与小型超市人员的沟通,实现目标如下:l 界面设计简洁、友好、美观大方。l 操作简单、快捷方便。l 数据存储安全、可靠。l 信息分类清晰、准确。l 强大的查询功能,保证数据查询的灵活性。l 提供销售排行榜,为管理员提供真实的数据信息。l 提供灵活、方便的权限设置功能,使整个系统的管理分工明确。l 对用户输入的数据,系统进行严格的数据检验,尽可能排除人为的错误。由于此系统是一个典型的客户/服务器(C/S)体系结构的数据库应用程序,因此具体设计阶段主要分两大部分进行:数据库的设计和各种功能模块和界面的设计。从运用的技术角度分析,即MySQL部分的设计和Java部分的设计。下面,我们将从这两个方面对系统的设计进行阐述。第一节、数据库设计小型超市进销存管理系统是一个基于C/S架构的应用程序,它可以直接在本地计算机上运行,而不需要向Web应用那样部署到指定的服务器中。所以这个小型超市进销存管理系统在本地计算机上安装了MySQL数据库服务器,将数据库和应用程序放在同一个计算机中,可以节省开销、提升系统安全性。另外,本系统也可以在网络内的其他计算机中运行,但是这需要将数据库对外开放、会降低数据安全性,其数据库运行环境如下:Ø 硬件平台:ü CPU:Inter E2180 2GHzü 内存:2GBü 硬盘空间:160GBØ 软件平台:ü 操作系统:Windows XP SP3ü 数据库:MySQL5.0小型超市进销存管理系统的数据库设计采用关系数据模型理论,有关系的元素组成一张表,表与表之间用外键保持一致性,用主键的方式确保记录的唯一性。涉和的表有充值表、顾客表、厂家表、商品表、日志表、财务表、退货表、销售表、购物车表、采购表和用户表共十一张表。小型超市管理系统模块分为:登录模块、顾客管理模块、厂家管理模块、商品管理模块、退货管理模块、购物车管理模块、采购管理模块、个人管理模块、管理员管理模块和系统管理模块共十大模块。为了方便数据库的设计,缩小开发周期,我用PowerDesigner软件把表都设计好,然后自动生成数据库的建表SQL语句。在对数据库进行访问时我用到了MVC设计模式中DAO(Data Access Object)技术封装对数据库的查询、删除、插入等各种操作,这样提高数据库访问的透明性和系统的灵活性。一、E-R图小型超市进销存管理系统主要实现从进货、退货、库存到销售的一体化信息管理,涉和到了顾客信息、厂家信息、商品信息等多个实体。下面简单介绍几个关键的实体E-R图。顾客实体E-R图小型超市进销存管理系统将记录所有的顾客信息,顾客实体包括顾客编号、顾客姓名、顾客性别、顾客年龄、顾客联系电话、顾客联系地址、顾客电子邮箱、顾客类型、顾客可用余额、顾客可用积分等属性,顾客E-R图如图1所示。顾客编号顾客顾客姓名顾客性别顾客年龄顾客联系电话顾客联系地址顾客电子邮箱顾客类型顾客可用余额顾客可用积分图3.1顾客实体E-R图厂家实体E-R图小型超市进销存管理系统将记录所有的厂家信息,厂家实体包括厂家编号、厂家名称、厂家负责人、厂家联系电话、厂家地址等属性,厂家E-R图如图2所示。厂家编号厂 家厂家名称厂家负责人厂家联系电话厂家地址图3.2 厂家实体E-R图商品实体E-R图小型超市进销存管理系统将记录所有的商品信息,商品实体包括商品编号、商品名称、商品数量、商品规格、商品价格、商品厂家名等属性,商品E-R图如图3所示。商品编号商品商品名称商品数量商品规格商品价格商品厂家名图3.3 商品实体E-R图二、使用使用PowerDesigner建模在数据库概念设计中已经分析了本系统中主要的数据实体对象,通过这些实体可以得出数据表结构的基本模型,最终实施到数据库中,形成完整的数据结构。本系统使用PowerDesigner工具完成数据库建模,使用的版本为12.5。使用该工具生成的模型如图4下:图3.4 小型超市进销存管理系统的模型三、数据字典表3.1 充值表表名数据表说明t_addmoney存储充值信息的数据表字段名称数据类型是否主键字段说明AddMoneyIDint(自增序列)是充值编号,顾客记录的唯一标识BuyerIDint顾客IDBuyerNamevarchar(20)顾客名AddMoneyfloat充值DonateMoneyfloat赠送AddMoneyDatedatetime时间UserNamevarchar(20)用户名Balancefloat卡内余额表3.2 顾客表表名数据表说明t_buyer存储顾客信息的数据表字段名称数据类型是否主键字段说明BuyerIDint(自增序列)是顾客编号,顾客记录的唯一标识BuyerNamevarchar(10)顾客姓名BuyerSexvarchar(4)顾客性别BuyerAgeint顾客年龄BuyerPhonevarchar(20)顾客联系电话BuyerAddressvarchar(50)顾客联系地址BuyerEmailvarchar(20)顾客电子邮箱BuyerTypeint顾客类型为0表示普通顾客,为1表示会员,为2表示贵宾BuyerBalancefloat顾客可用余额BuyerScoreint顾客用用积分表3.3 厂家表表名数据表说明t_factory存储厂家(供货商)信息的数据表字段名称数据类型是否主键字段说明FactoryIDint(自增序列)是厂家编号,厂家记录的唯一标识FactoryNamevarchar(20)厂家名称FactoryManagervarchar(10)厂家经理(负责人)FactoryPhonevarchar(10)厂家联系电话FactoryAddressvarchar(50)厂家地址表3.4 商品库存表表名数据表说明t_goods存储商品信息的数据表字段名称数据类型是否主键字段说明GoodsIDint(自增序列)是商品编号,商品记录的唯一标识GoodsNOvarchar(20)商品条形码编号GoodsNamevarchar(10)商品名称GoodsNumint商品数量GoodsTypevarchar(10)商品规格GoodsPricefloat商品价格FactoryNamevarchar(20)商品厂家名表3.5 日志表表名数据表说明t_money存储日志信息的数据表字段名称数据类型是否主键字段说明LogIDint(自增序列)是日志编号,日志记录的唯一标识LogDatedatetime日志日期IpAddressvarchar(20)IP地址UserNamevarchar(20)用户名LogContentvarchar(20)日志内容表3.6 财务表表名数据表说明t_money存储财务信息的数据表字段名称数据类型是否主键字段说明MoneyIDint(自增序列)是财务编号,财务记录的唯一标识UserNamevarchar(20)用户名MoneyBalancefloat金额MoneyContentvarchar(50)内容MoneyDatedatetime日期表3.7 退货表表名数据表说明t_quitgoods存储退货信息的数据表字段名称数据类型是否主键字段说明QuitGoodsIDint(自增序列)是退货编号,退货记录的唯一标识GoodsIDint退货商品IDQuitReaseontext退货原因QuitGoodsTypeint退货类型为0表示销售退货,为1表示采购退货QuitGoodsNumint退货数量UserNamevarchar(20)用户名表3.8 销售表表名数据表说明t_sell存储销售信息的数据表字段名称数据类型是否主键字段说明SellIDint(自增序列)是销售编号,销售记录的唯一标识UserNamevarchar(20)用户名BuyerNamevarchar(20)顾客名ShopCarIDvarchar(50)购物车IDGoodsNumint数量TotalMoneyfloat总金额GetMoneyfloat实收金额PayMoneyfloat找零金额SellDatedatetime销售日期表3.9 购物车表表名数据表说明t_shopcar存储购物车信息的数据表字段名称数据类型是否主键字段说明IDint是自增序列ShopCarIDvarchar(50)购物车编号,前面是XX-XX-XX(日期)后面是四位销售流水号GoodsIDint商品IDGoodsNamevarchar(10)商品名称GoodsTypevarchar(10)商品规格BuyGoodsNumint购买数量GoodsPricefloat商品单价BuyerNamevarchar(20)顾客名UserNamevarchar(20)用户名表3.10 采购表表名数据表说明t_stock存储采购信息的数据表字段名称数据类型是否主键字段说明StockIDint(自增序列)是采购编号,采购记录的唯一标识GoodsIDint商品IDUserIDint用户IDFactoryIDint厂家IDStockDatedatetime采购日期StockPricefloat采购价格SellPricefloat销售价格>=采购价格*1.25表3.11 用户表表名数据表说明t_user存储用户信息的数据表字段名称数据类型是否主键字段说明UserIDint(自增序列)是用户编号,用户记录的唯一标识UserNamevarchar(20)用户登陆系统时所用的用户名称UserPwdvarchar(20)用户密码UserPhonevarchar(20)用户联系电话UserAddressvarchar(50)用户联系地址UserTypeint用户类型为0表示管理员、为1表示经理、为2表示营业员、为3表示采购员GroupIdInt用户组(同上)表3.12 用户组表表名数据表说明t_group存储用户组信息的数据表字段名称数据类型是否主键字段说明GroupIdint(自增序列)是用户组编号,用户组记录的唯一标识GroupNameVarchar(20)用户组名称GroupDescribeVarchar(50)用户组描述表3.13 用户组权限表表名数据表说明t_group_permission存储用户组权限信息的数据表字段名称数据类型是否主键字段说明GroupPermissionIdint(自增序列)是用户组权限编号,用户组权限记录的唯一标识GroupIdInt用户组IdPermissionIdInt权限Id表3.14 权限表表名数据表说明t_permission存储权限信息的数据表字段名称数据类型是否主键字段说明PermissionIdint(自增序列)是权限编号,用户组权限记录的唯一标识PermissionNameVarchar(20)权限名称PermissionItemVarchar(20)权限项第二节 功能模块设计根据以上对小型超市管理系统数据库的分析,一个标准的小型超市进销存管理系统应该实现的主要的功能模块有:登录模块、采购管理模块、退货管理模块、商品信息管理模块、购物车管理模块、用户管理模块、顾客管理模块、厂家管理模块、统计管理模块、管理员管理模块。(共十大模块)为了方便,应该加入准确查询和模糊查询。下面对这些功能模块作下简单的介绍。登录模块用于验证用户的登录。不同的用户成功登录后显示的窗体是不一样的。这是每个系统都应该具有的功能,在这里我要特别的介绍一下了。别小看了一个普通的登录模块,它包含的用户需求可以是有几十条的。比如:用户不能重复登录,输入三次密码错误后,应该锁定用户的账号,记住密码功能,以和对密码进行MD5加密(解密)等等。顾客管理模块这个模块用于维护顾客的资料。系统中顾客分为三种:贵宾、会员、普通顾客。类型为0表示普通顾客,为1表示会员,为2表示贵宾,系统默认有一个BuyerID为0的普通顾客。其都有如下几个基本信息:顾客ID、顾客名、性别、年龄、地址、电话、E-mail、顾客类别。顾客的信息是小型超市一个很重要的市场资源、必须持久性的保存到数据库中,同时为了数据的安全性,应定期将数据备份到其他介质上保存或把数据打印成资料保管起来。顾客管理包括:增加顾客、删除顾客、修改顾客、查询顾客。厂家管理模块这个模块用于维护厂家的资料。系统中厂家有如下几个基本的信息:厂家ID、厂家名称、厂家经理、厂家联系电话、厂家地址。厂家的信息也是小型超市的一个很重要的信息,所以必须是管理员或经理才能查看。同时为了数据的安全性,应定期将数据备份到其他介质上保存或把数据打印成资料保管起来。厂家管理模块包括:增加厂家信息、删除厂家信息、修改厂家信息、查询厂家信息。商品管理模块这个模块用户维护商品的资料。当小型超市中出现了由于商品价格定价过高而导致商品不畅销的商品时,可以更新商品的价格信息。系统中商品都有如下几个基本信息:商品ID、商品名称、商品数量、商品规格、商品价格、商品厂家名。商品信息管理包括:更新商品信息、查询商品信息。退货管理模块用于对采购了问题产品而退货和顾客购买了问题产品而退货的信息进行登记。采购员对应采购退货,工作流程:对小型超市的采购退货记录进行详细记录。营业员对应销售退货,工作流程:对小型超市的销售退货记录进行详细记录。购物车管理模块用于营业员管理小型超市的销售业务,其主要功能是让营业员进行销售信息的添加和查询。为了让经理和系统管理员了解销售情况!购物车管理模块工作流程是:营业员先扫描顾客购物车里面的商品,然后确定顾客是普通顾客还是会员,是付现金还是刷卡,最后打印出销售小票。并把销售记录进行详细的记录。采购管理模块用于采购员管理小型超市的采购业务,其主要功能是完成小型超市采购信息的添加和查询。工作流程是:经理通过查看小型超市的销售状况和对库存进行盘点,对库存不足的商品进行采购,并下达采购信息,指派给相对应的采购员去完成,采购员则接受经理的命令,去厂家采购商品,并验收入库,还要对小型超市的采购记录进行详细记录。个人管理模块用户系统用户修改自己的账号密码和修改自己的个人信息。不同的用户只能够修改自己的密码和个人信息。提高了系统的安全性和准确性。个人管理模块还有换班管理以和局域网聊天子系统等功能,方便用户的特殊需求,如小型超市职工需请假,则可以通过换班管理,和其他人交接班,以方便小型超市的正常运转。局域网聊天是为了经理给小型超市职工下达通知以和小型超市职工向经理汇报情况等提供方便,提高工作效率,异地协同办公。管理员管理模块用于给系统分配登录用户。不同的用户具有不同的权限,权限管理可以提高系统的安全性。系统用户分为四种级别的用户,系统管理员、经理、营业员和采购员。其都有如下几个基本信息:用户ID、用户名、用户密码、用户电话、用户地址、用户类别。系统默认有一个系统管理员admin,密码设置为admin,系统管理员能够操作系统中所有的功能。用户管理包括对经理、营业员、采购员等用户进行添加和删除等管理。工作流程:1、负责系统登录用户的管理。系统管理模块系统管理是软件最基本、最重要的信息。其包含有查看系统日志、查看销售信息、查看充值信息和收入支出统计等功能。查看系统日志要求对该系统的使用情况进行记录,如何时何地何人使用过该小型超市进销存管理系统,以和对重要信息的增删改进行记录,方便经理进行查阅。查看销售信息、查看充值信息和收入支出统计等功能模块用于管理员或经理了解小型超市的经营情况,从而做出重要性的高校决策。提高管理效率!第三节 模块的实现 系统整体操作流程分别如下图3.5,由于系统设计的模块较多,不便一一叙述,因此挑选登录功能、图3.5 系统整体流程图一、 登录功能实现用户登录系统的登入,需要用户输入相应身份的用户名、密码,成功后方能进入系统,如果输入信息不正确,则无法登录,登录的流程图如下所示:图3.6 登陆流程图登录界面是使用者在使用此软件时需要输入自已的账号和密码,从而使用自已的权限来管理小型超市的运行。运行该系统出现登录窗体,如下图3.5所示。图3.7 系统登录界面主要实现代码如下:package org.yinpan.supermarket.gui; * 初始化窗体private void initFrame() loginFrame = new JFrame(Common.getMessage("title");loginFrame.setSize(380, 300);/ 设置窗口的显示位置和大小Dimension screenSize = Toolkit.getDefaultToolkit().getScreenSize();Dimension frameSize = loginFrame.getSize();int x = (int) (screenSize.getWidth() - frameSize.getWidth() / 2;int y = (int) (screenSize.getHeight() - frameSize.getHeight() / 2;loginFrame.setLocation(x, y);/ 设置窗口的大小固定loginFrame.setResizable(false);/ 设置窗口的布局格式loginFrame.setLayout(null);/ 添加图片Icon icon = new ImageIcon("resabout2.jpg");JLabel aboutLabel = new JLabel(icon);/ 创建具有指定图像的/ JLabel实例。该标签在其显示区内垂直和水平居中对齐。aboutLabel.setBounds(0, 0, 380, 150);loginFrame.add(aboutLabel);/ 添加用户名JLabel userNameLabel = new JLabel(Common.getMessage("username");userNameLabel.setBounds(5, 155, 80, 20);loginFrame.add(userNameLabel);userNameField = new JTextField();userNameField.setBounds(80, 155, 290, 20);loginFrame.add(userNameField);/ 添加密码JLabel userPwdLabel = new JLabel(Common.getMessage("userpwd");userPwdLabel.setBounds(5, 180, 80, 20);loginFrame.add(userPwdLabel);userPwdField = new JPasswordField();userPwdField.setBounds(80, 180, 290, 20);userPwdField.setFocusable(true);loginFrame.add(userPwdField);confirmBtn = new JButton(Common.getMessage("login");confirmBtn.setBounds(70, 220, 80, 20);loginFrame.add(confirmBtn);cancelBtn = new JButton(Common.getMessage("cancel");cancelBtn.setBounds(220, 220, 80, 20);loginFrame.add(cance