第一次课-需求分析和系统架构

飞一样的编程
飞一样的编程
擅长邻域:Java,MySQL,Linux,nginx,springboot,mongodb,微信小程序,vue

分类: ssm 专栏: 手游app项目 标签: 手游app

2023-10-30 22:09:24 1890浏览

手游app管理系统需求分析和系统架构

系统开发流程

需求分析-》原型图效果图(axure或者墨刀)-》数据库表设计-》开发代码-》测试-》上线-》运维

需求分析

image.png

预计效果图

登录

image.png

开发者app列表

只显示登录用户发布的app列表
正确显示logo图片
正确显示游戏分类
正确显示最新版本号
正确显示下拉列表和三级分类列表
image.png

添加手游基本信息

正确使用表单非空验证
apk名称唯一性验证
手游状态设置为待审核
image.png

修改手游基本信息

正确显示三级分类
手游状态设置为待审核
image.png

删除手游信息

删除对应手游所有版本
删除对应手游版本所有apk文件
删除对应手游logo图片
删除对应手游信息
image.png

上下架

对应状态下拉菜单如下:
1、待审核 修改、删除、添加版本
2、审核通过 上架、删除
3、审核未通过 修改、删除、添加版本
4、已上架 下架
5、已下架 修改、删除、上架、添加版本

添加版本

非空验证
正确显示版本列表

发布状态:默认为预发布状态

.apk文件:上传格式限定为.apk,文件大小不能超过500mb

image.png

管理员app列表

显示所有开发者待审核的app
正确显示开发者名称
image.png

管理员审核app

image.png

数据库设计

1.开发者表dev_user

devCode 开发者帐号
devName 开发者名称
devPassword 开发者密码
devEmail 开发者电子邮箱
devInfo 开发者简介
createdBy 创建者(来源于backend_user用户表的用户id)
creationDate 创建时间
modifyBy 更新者(来源于backend_user用户表的用户id)
modifyDate 最新更新时间

2.管理员表backend_user

表字段省略
image.png

3.手游基础信息表app_info

4.手游版本信息表app_version

5.数据字典表data_dictionary

6.分类表app_category

开发安排

)LRBTY8Q36IW56`AF9848US.png

前端搭建和后端搭建

1.环境准备

1、 安装node.js
https://nodejs.org/zh-cn/
2、 npm设置国内镜像(在cmd中执行如下命令)
npm config set registry https://registry.npm.taobao.org或npm config set registry http://registry.npmmirror.com
3、 安装vue/cli
npm install -g @vue/cli

2.创建前端项目

请使用管理员身份运行cmd,并cd c:/
image.png
在命令行执行vue ui打开图像界面创建项目(文件夹需要存在,需要联网)
image.png
image.png
安装插件
image.png

npm install –registry=https://registry.npmmirror.com

3.环境变量配置

前端项目开发完成后,一般会通过nginx部署,需要在nginx中根据特定的路径前缀反向代理到相应的后端,所以给前端项目请求统一添加一个前缀,方便nginx解析
新建.env.development

# 开发环境配置
ENV = 'development'
VUE_APP_BASE_API = '/dev-api'

新建.env.production

# 生产环境配置
ENV = 'production'
VUE_APP_BASE_API = '/prod-api'

修改axios.js
取代jquery.ajax,功能更专一,性能更好

…….
let config = {
  // baseURL: process.env.baseURL || process.env.apiUrl || ""
  // timeout: 60 * 1000, // Timeout
  // withCredentials: true, // Check cross-site Access-Control
  baseURL: process.env.VUE_APP_BASE_API
};
……

在最后一行添加,导出变量给其他模块使用
export {_axios as request}

4.配置代理

后端接口开发完成后,开发时需要通过代理服务器路由到后端,不再使用mock,所以配置如下,在根目录(跟package.json同级)添加vue.config.js配置代理服务器,将/dev-api开头的请求代理到后端服务器http://localhost:7001

module.exports = {
  devServer:{
    host:'localhost',
    port:8088, //前端项目端口号
    open: true,
    proxy:{
      [process.env.VUE_APP_BASE_API]: {
        target: `http://localhost:8080`, //后端项目地址
        changeOrigin: true,
        pathRewrite: {['^' + process.env.VUE_APP_BASE_API]: ''}
      }
    }
  }
}

表示如果通过axios请求后端/user/add的接口,axios会自动加上前缀/dev-api,变成/dev-api/user/add,代理服务器拦截所有/dev-api开头的请求,去掉/dev-api,自动转发到http://localhost:7001/user/add;这样就可以区分静态请求和动态请求了(根据.env配置文件获取前缀)
如果ssm项目未部署在tomcat根目录,则配置target:http://localhost:tomcat端口号/项目名字

5.定义api访问路径

路径:src/api/api_path.js

const news = '/news'
const user= '/users'

export default {news, user}

6.自定义请求后端js

以news api为例,路径:src/api/news.js
此js文件定义调用后端所有功能的js函数

import {request} from '@/plugins/axios'
import ApiPath from '@/api/api_path'

export function list(query) {
    return request({
        url: ApiPath.news,
        method: 'GET',
        params: query
    })
}

7.修改news.vue页面

路径:(src/views/news/index.vue)
在下引入api

import {list,del,add,update} from '@/api/news'

然后就可以在页面中调用上面import的函数访问后端了……
后端注意:前端通过axios发送Post或Put请求时,默认是使用的json格式,后端控制器参数需要些@RequetBody 实体类方式接收参数

8.添加静态路由

修改router/index.js

9.布局

从elementui复制布局代码,粘贴到src\layout\layout.vue文件
给文件添加和

export default {
        name: 'IndexLayout'
    }
</script>

修改router\index.js
image.png

10.菜单导航

1、从elementui中复制navMenu的相关代码到layout.vue,根据实际项目修改菜单代码,
2、在<el-menu 上添加属性router,开启路由功能
3、修改< el-menu-item的index,值为路由文件中定义的path

11.登录

定义token类
image.png
登录控制器返回token
image.png
前台登录成功处理
image.png

12.登录拦截器

image.png
image.png

13.前端axios请求拦截处理

在每一次异步请求的header中添加后端需要的变量(只能是非中文字符串)
image.png
修改axios.js

const _axios = axios.create(config);

_axios.interceptors.request.use(
    function (config) {
        // Do something before request is sent
        let token = sessionStorage.getItem("token");
        if (token) {
            config.headers['token'] = JSON.parse(token).token;
        }
        return config;
    },
    function (error) {
        // Do something with request error
        return Promise.reject(error);
    }
);

14.前端axios响应拦截

image.png

// Add a response interceptor
_axios.interceptors.response.use(
    function (response) {
        // Do something with response data
        return response.data
    },
    function (error) {
        // Do something with response error
        if (error.response.status == 401 || error.response.status == 403) {
            Message.error("登录已过期!")
            sessionStorage.removeItem("token")
            sessionStorage.removeItem("url")
            router.push("/")
        }
        return Promise.reject(error);
    }
);

15.注销

image.png

16.上传

1、 控制器入参去掉@RequestBody注解
image.png
2、 页面
image.png


QQ图片20231107183428.png



3、 js
image.png

17.显示图片或下载链接

1、 配置tomcat虚拟目录
a) 修改server.xml
image.png
2、 idea中修改tomcat配置
image.png
3、前端
image.png

好博客就要一起分享哦!分享海报

此处可发布评论

评论(0展开评论

暂无评论,快来写一下吧

展开评论

您可能感兴趣的博客

客服QQ 1913284695