2.2 MySQL:
为了能更容易接受MySQL数据库,下面来描述一下它的主要特征。
(1)MySQL数据库的最佳选择都是为了节约开发资产,由于MySQL的源码早已在网络上公布表明,开发者也可以根据程序开发的需求免费下载,还可以在程序中使用一些转变,能够促进开发者开发这一程序进度。
(2)SQL数据信息语言表达同样适用于MySQL
(3)MySQL不但可以适用各种编程语言,如C语言、Java语言表达及其课下接触到的PHP语言表达,C 语言表达等计算机语言,它能够很好的适用,而MySQL安装与使用也不挑应用服务平台。
(4)MySQL能够支持日志记录数据库,电子计算机操作系统初次组装或重装,可根据实际情况挑选组装32位或64位操作系统,二种操作系统对表文件信息适用不一样,32位操作系统最多能存放4GB表文档,64位操作系统最多能存放8TB表文档。
(5)MySQL数据库能通过GPL协议书开展个性定制,开发者必须改动数据库的源码,进而开发自已的MySQL。
2.3 Springboot
程序开发语言许多,但到现在为止,Java语言依旧是IT领域深受认同和常用的创作语言之一。因而,在挑选这一程序的创作语言时,我决定选择使用程序编写语言开展程序开发。可以这么说,通过这些年的发展趋势,Java语言不但在Web开发领域作出了杰出贡献,并且在互联网开发和Android开发领域也得到广泛应用。因为Java语言具有极强的拓展性能可靠性,它已经成为大中型后端系统开发语言的最佳选择。现如今,Java语言成为了网络平台常见解决方案。
Java语言做为源码在互联网上开源系统的对象,其开发的程序不太可能直接从各个平台上运作。Java程序的运转必须在作业平台上配置其工作环境,包含数据分析软件和Java程序开发软件的安装及配置。Java程序工作环境配置在Win7、Win10或其它作业平台上,只需自然环境配置取得成功,Java程序就能运作。
三、系统设计:
3.1 系统功能设计:
仓库管理系统主要功能设计:
主要角色:用户 管理员 仓库管理员
3.2 登录流程设计:
3.3 登录时序图设计:
四、功能截图:
4.1 登录注册:
4.2 系统首页:
4.3 基础数据类型:
4.4 公告管理:
4.5 物资管理:
此页面让管理员管理物资的数据,物资管理页面见下图。此页面主要实现物资的增加、修改、删除、查看的功能
4.6 物资类型统计
4.7 物资申请管理
用户登录可以新增物资申请
用户申请之后-由仓库管理员审核申请-审核通过后用户申请成功-最后由超级管理员默认物资是否归还
4.8 用户管理:
五、部分数据设计:
在规划这一部分以前,首先要了解和掌握数据类型和每一个数据类型长度范畴,毕竟在一个特定数据表中,为了更好地了解,这里有一个典型的例子。比如,用户信息内容表中字段名是用户实体的属性。这时,必须设定字段名的数据类型和字段长度,并配有外键约束做为用户情况表的唯一鉴别。这都是数据库表结构设计方案要完成内容。依据仓储管理系统的功能分析和概念模型设计规定,显示设备的数据表构造。
(1)下图是公告实体和其具备的属性。
公告实体属性图
(2)下图是物资实体和其具备的属性。
物资实体属性图
(3)下图是物资申请实体和其具备的属性。
图物资申请实体属性
六、代码参考
/**
* 上传文件映射表
*/
@RestController
@RequestMapping("file")
@SuppressWarnings({"unchecked","rawtypes"})
public class FileController{
@Autowired
private ConfigService configService;
/**
* 上传文件
*/
@RequestMapping("/upload")
public R upload(@RequestParam("file") MultipartFile file,String type) throws Exception {
if (file.isEmpty()) {
throw new EIException("上传文件不能为空");
}
String fileExt = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf(".")+1);
File path = new File(ResourceUtils.getURL("classpath:static").getPath());
if(!path.exists()) {
path = new File("");
}
File upload = new File(path.getAbsolutePath(),"/upload/");
if(!upload.exists()) {
upload.mkdirs();
}
String fileName = new Date().getTime()+"."+fileExt;
File dest = new File(upload.getAbsolutePath()+"/"+fileName);
file.transferTo(dest);
if(StringUtils.isNotBlank(type) && type.equals("1")) {
ConfigEntity configEntity = configService.selectOne(new EntityWrapper<ConfigEntity>().eq("name", "faceFile"));
if(configEntity==null) {
configEntity = new ConfigEntity();
configEntity.setName("faceFile");
configEntity.setValue(fileName);
} else {
configEntity.setValue(fileName);
}
configService.insertOrUpdate(configEntity);
}
return R.ok().put("file", fileName);
}
/**
* 下载文件
*/
@IgnoreAuth
@RequestMapping("/download")
public ResponseEntity<byte[]> download(@RequestParam String fileName) {
try {
File path = new File(ResourceUtils.getURL("classpath:static").getPath());
if(!path.exists()) {
path = new File("");
}
File upload = new File(path.getAbsolutePath(),"/upload/");
if(!upload.exists()) {
upload.mkdirs();
}
File file = new File(upload.getAbsolutePath()+"/"+fileName);
if(file.exists()){
/*if(!fileService.canRead(file, SessionManager.getSessionUser())){
getResponse().sendError(403);
}*/
HttpHeaders headers = new HttpHeaders();
headers.setContentType(MediaType.APPLICATION_OCTET_STREAM);
headers.setContentDispositionFormData("attachment", fileName);
return new ResponseEntity<byte[]>(FileUtils.readFileToByteArray(file),headers, HttpStatus.CREATED);
}
} catch (IOException e) {
e.printStackTrace();
}
return new ResponseEntity<byte[]>(HttpStatus.INTERNAL_SERVER_ERROR);
}
}
七、项目总结:
仓库管理系统的开发制作,从题目确定到成品完成,自己投入的精力与心血是非常多的。从仓库管理系统的前台页面实现,到仓库管理系统的后台代码的编辑,我用到的软件包括了数据库软件MySQL,Java开发工具IDEA,办公软件Office,浏览器软件Fireworks,图像处理软件Photoshop等,这也是我第一次使用Java语言,开发的这个比较简单的仓库管理系统。
仓库管理系统开发过程中,自己之前觉得比较抽象的许多门课程,例如数据库原理,软件工程,动态网站开发等课程开始变得很清晰,只有自己独立开发程序,才会觉得这些开发类的课程在实践中具有的重要作用。为了让自己设计的作品能够顺利的完成,我把所学知识全部运用在程序的开发流程中,包括了程序的需求分析环节,程序的编码环节,程序的测试环节等,让程序软件在开发周期内完成制作,并能够保证程序质量达标,力求程序开发流程规范化,程序对应的配套文档标准化。
本次开发的系统整体界面还是比较清晰简明,功能上面考虑得比较全,几乎可以满足用户使用要求。尽管我对这次的毕设付出了许多的努力,但是程序还是有很多不足的地方,系统界面整体感觉还行,但是字体字号的选取上面还是有些不符合现实审美,在程序的CSS样式编码上面,我还有许多不熟悉的地方,虽然经过反复的测试与调试选中了现在这样的程序界面,但是我还是明显感觉到自己对一些常用CSS样式的不熟悉,编码过程中,我还要多次进行资料查看才知道。另外我编写的代码写作不是很规范,可读性比较差,幸运的是,我最终还是实现了系统中所要求的功能。
最后
码字不易,觉得有帮助的可以帮忙点个赞,让更多有需要的人看到
又是一年求职季,在这里,我为各位准备了一套Java程序员精选高频面试笔试真题,来帮助大家攻下BAT的offer,题目范围从初级的Java基础到高级的分布式架构等等一系列的面试题和答案,用于给大家作为参考
以下是部分内容截图
己对一些常用CSS样式的不熟悉,编码过程中,我还要多次进行资料查看才知道。另外我编写的代码写作不是很规范,可读性比较差,幸运的是,我最终还是实现了系统中所要求的功能。
最后
码字不易,觉得有帮助的可以帮忙点个赞,让更多有需要的人看到
又是一年求职季,在这里,我为各位准备了一套Java程序员精选高频面试笔试真题,来帮助大家攻下BAT的offer,题目范围从初级的Java基础到高级的分布式架构等等一系列的面试题和答案,用于给大家作为参考
以下是部分内容截图
[外链图片转存中…(img-yKgkGL5R-1714192095679)]