学习不走弯路,通过《mall视频教程(最新版)》,使用更系统、高效的方式来学习mall电商实战项目吧!
mall项目开发设计思路
mall项目开发设计思路
在我们做项目之前,往往会有一些开发设计思路,我在开发mall项目时也是有的。这节课程我们来讲解下mall项目的开发设计思路,此思路为通用开发思路,用来开发其他项目也是可以的,希望大家经过这节课程的学习,对项目的开发流程有所了解。
相关视频教程
项目开发流程
我们开发项目的具体流程如下,其中与后端开发有关的主要是功能设计、数据库设计、接口设计与实现这三部分,下面将以mall项目中权限模块的功能为例,来讲解下项目开发的通用思路。
功能设计
一般来说,我们都会按照产品给的原型图或者UI给的效果图来进行功能设计,由于mall项目的权限模块已经开发完成了,我们就直接按照它的界面来进行功能设计。
- 我们这里以
用户列表
功能为例,首先我们查看下用户列表和添加用户功能,提取下需要实现的功能和功能所涉及的数据字段;
- 之后我们可以同思维导图工具记录下我们提取出来的内容,方便我们进行之后的数据库设计,这里使用了ProcessOn的思维笔记功能;
- 然后我们再提取下
角色列表
功能需要实现的功能和功能所涉及的数据字段;
- 具体提取的信息如下,权限模块其他表的提取基本相同,大家可以自行实践下。
数据库设计
- 最终提取出来的功能和所涉及的数据字段如下;
- 之后我们就可以根据提取出来的内容来设计数据库了,刚开始设计数据库的时候只要考虑如何存储,满足这些数据的存储需求即可,比如用户表设计如下:
CREATE TABLE `ums_admin` (
`id` bigint(20) NOT NULL AUTO_INCREMENT,
`username` varchar(64) DEFAULT NULL,
`password` varchar(64) DEFAULT NULL,
`icon` varchar(500) DEFAULT NULL COMMENT '头像',
`email` varchar(100) DEFAULT NULL COMMENT '邮箱',
`nick_name` varchar(200) DEFAULT NULL COMMENT '昵称',
`note` varchar(500) DEFAULT NULL COMMENT '备注信息',
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
`login_time` datetime DEFAULT NULL COMMENT '最后登录时间',
`status` int(1) DEFAULT '1' COMMENT '帐号启用状态:0->禁用;1->启用',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8 COMMENT='后台用户表';
- 角色表的设计如下;
CREATE TABLE `ums_role` (
`id` bigint(20) NOT NULL AUTO_INCREMENT,
`name` varchar(100) DEFAULT NULL COMMENT '名称',
`description` varchar(500) DEFAULT NULL COMMENT '描述',
`admin_count` int(11) DEFAULT NULL COMMENT '后台用户数量',
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
`status` int(1) DEFAULT '1' COMMENT '启用状态:0->禁用;1->启用',
`sort` int(11) DEFAULT '0',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8 COMMENT='后台用户角色表';
- 设计数据库时除了设计表之外,还需设计好表之间的关系,比如在我们用户列表功能中,有个
分配角色
的功能;
- 考虑到用户和角色是
多对多
关系,我们需设计一张关系表,同时存储这两张表的ID;
- 在我们资源列表功能中,还有一种
一对多
的关系,比如资源分类和资源之间;
- 像这种
一对多
的关系,只需要在多的那张表上添加关联ID即可;
- 最终设计完成后,权限模块的数据库结果如下。
接口设计与实现
- 接下来我们就根据功能分析下需要设计哪些即可,首先是列表页面;
分配角色
是需要回显用户角色和分配角色接口;
编辑用户
时需要回显用户信息和编辑用户接口;
- 所有需要设计的接口在接口文档中显示如下,其他接口有需要的时候再设计添加;
- 具体接口实现可参考
UmsAdminController
类中的方法,涉及数据库操作比较简单,这里就不详细叙述了。
/**
* 后台用户管理Controller
* Created by macro on 2018/4/26.
*/
@Controller
@Api(tags = "UmsAdminController")
@Tag(name = "UmsAdminController", description = "后台用户管理")
@RequestMapping("/admin")
public class UmsAdminController {
@Autowired
private UmsAdminService adminService;
@Autowired
private UmsRoleService roleService;
@ApiOperation(value = "用户注册")
@RequestMapping(value = "/register", method = RequestMethod.POST)
@ResponseBody
public CommonResult<UmsAdmin> register(@Validated @RequestBody UmsAdminParam umsAdminParam) {
UmsAdmin umsAdmin = adminService.register(umsAdminParam);
if (umsAdmin == null) {
return CommonResult.failed();
}
return CommonResult.success(umsAdmin);
}
@ApiOperation("根据用户名或姓名分页获取用户列表")
@RequestMapping(value = "/list", method = RequestMethod.GET)
@ResponseBody
public CommonResult<CommonPage<UmsAdmin>> list(@RequestParam(value = "keyword", required = false) String keyword,
@RequestParam(value = "pageSize", defaultValue = "5") Integer pageSize,
@RequestParam(value = "pageNum", defaultValue = "1") Integer pageNum) {
List<UmsAdmin> adminList = adminService.list(keyword, pageSize, pageNum);
return CommonResult.success(CommonPage.restPage(adminList));
}
@ApiOperation("获取指定用户信息")
@RequestMapping(value = "/{id}", method = RequestMethod.GET)
@ResponseBody
public CommonResult<UmsAdmin> getItem(@PathVariable Long id) {
UmsAdmin admin = adminService.getItem(id);
return CommonResult.success(admin);
}
@ApiOperation("修改指定用户信息")
@RequestMapping(value = "/update/{id}", method = RequestMethod.POST)
@ResponseBody
public CommonResult update(@PathVariable Long id, @RequestBody UmsAdmin admin) {
int count = adminService.update(id, admin);
if (count > 0) {
return CommonResult.success(count);
}
return CommonResult.failed();
}
@ApiOperation("删除指定用户信息")
@RequestMapping(value = "/delete/{id}", method = RequestMethod.POST)
@ResponseBody
public CommonResult delete(@PathVariable Long id) {
int count = adminService.delete(id);
if (count > 0) {
return CommonResult.success(count);
}
return CommonResult.failed();
}
@ApiOperation("修改帐号状态")
@RequestMapping(value = "/updateStatus/{id}", method = RequestMethod.POST)
@ResponseBody
public CommonResult updateStatus(@PathVariable Long id,@RequestParam(value = "status") Integer status) {
UmsAdmin umsAdmin = new UmsAdmin();
umsAdmin.setStatus(status);
int count = adminService.update(id,umsAdmin);
if (count > 0) {
return CommonResult.success(count);
}
return CommonResult.failed();
}
@ApiOperation("给用户分配角色")
@RequestMapping(value = "/role/update", method = RequestMethod.POST)
@ResponseBody
public CommonResult updateRole(@RequestParam("adminId") Long adminId,
@RequestParam("roleIds") List<Long> roleIds) {
int count = adminService.updateRole(adminId, roleIds);
if (count >= 0) {
return CommonResult.success(count);
}
return CommonResult.failed();
}
@ApiOperation("获取指定用户的角色")
@RequestMapping(value = "/role/{adminId}", method = RequestMethod.GET)
@ResponseBody
public CommonResult<List<UmsRole>> getRoleList(@PathVariable Long adminId) {
List<UmsRole> roleList = adminService.getRoleList(adminId);
return CommonResult.success(roleList);
}
}
总结
对于后端开发人员来说,我们主要关注开发流程中的功能设计、数据库设计和接口设计与实现这三部分,大家只要掌握这三部分的设计思路,开发项目就简单多了!