当前位置: 首页 > news >正文

宁夏网站营销推广红色网站建设的比较好的高校

宁夏网站营销推广,红色网站建设的比较好的高校,网站建设黄荣,做外贸找生意上哪个网站注#xff1a;每个学校每个老师对论文的格式要求不一样#xff0c;故本论文只供参考#xff0c;本论文页数达到60页以上#xff0c;字数在6000及以上。 基于JavaSpringMvcVue技术的在线学习交流平台设计与实现 目录 第一章 绪论 1.1 研究背景 1.2 研究现状 1.3 研究内容…      注每个学校每个老师对论文的格式要求不一样故本论文只供参考本论文页数达到60页以上字数在6000及以上。 基于JavaSpringMvcVue技术的在线学习交流平台设计与实现 目录 第一章 绪论 1.1 研究背景 1.2 研究现状 1.3 研究内容 第二章 相关技术介绍 2.1  Java语言 2.2 HTML网页技术 2.3 MySQL数据库 2.4 Springboot 框架介绍 2.5 VueJS介绍 2.6 ElementUI介绍 第三章 系统分析 3.1 可行性分析 3.2 系统性能分析 3.3 系统功能分析 3.4 系统流程分析 第四章 系统设计 4.1 系统概要设计 4.2 系统结构设计 4.3 系统顺序图设计 4.4 系统关系图设计 4.5 数据库设计 第五章  系统详细设计 5.1 供应商管理 5.2 库存管理 5.3 供应商统计分析 5.4 商品管理 5.5 应收管理 5.6 库存盘点 5.7 入库历史 5.8 进货订单 第六章  部分代码实现 6.1  Spring boot  配置代码 6.2 用户管理及登录登出代码 6.3 Md5 加密算法代码 6.4  部分数据库代码 第七章 系统测试 7.1 测试定义 7.2 测试目的 7.3 测试方案 7.4 测试结论 第八章 结 论 致谢 附一、论文参考 附二、其他案例  第四章 系统设计 4.1 系统概要设计 系统采用B/S架构通过Web浏览器进行访问和操作。系统包括前台和后台两个主要部分 后台用户管理、菜单管理、权限管理、首页、供应商管理、进货管理、销售管理、仓库管理、采购记录、库存盘点、调拨单、出库单、借入单、进货报表、采购记录、销售往来账、采购往来账、图表分析、人事管理、销售报表、财务报表、个人中心、后台管理等功能模板。 4.2 系统结构设计 整个系统是由多个功能模块组合而成的要将所有的功能模块都一一列举出来然后进行逐个的功能设计使得每一个模块都有相对应的功能设计然后进行系统整体的设计。 本系统结构图如图4-2所示。  4.3 系统顺序图设计 4.3.1 登录模块顺序图 登录模块主要满足了管理员以及用户的权限登录登录模块顺序图如图4-3所示。 4.3.2 添加信息模块顺序图 管理员以及用户登录后均可进行添加信息操作添加信息模块顺序图如图4-4所示。 4.4 系统关系图设计 本系统各类之间关系图如图4-2所示。 4.5 数据库设计 一个好的数据库可以关系到程序开发的优劣数据库设计离不开表结构的设计还有表与表之间的联系以及系统开发需要设计的数据表内容等信息。在进行数据库设计期间要结合实际情况来对数据库进行针对性的开发设计[12]。 4.4.1 数据库E-R图设计 本系统采用的是mysql数据库数据存储快因为个人博客管理系统主要的就是对信息的管理信息内容比较多这就需要好好的设计一个好的数据库分类要清楚不能添加信息的时候造成信息太过混乱设计好的数据库首先就需要先把各个实体之间的关系表达明确系统的E-R图如下图所示  4.4.2 逻辑结构设计        逻辑结构设计是把概念结构设计阶段画好的数据库ER图转换为关系模型。该系统的关系模型的逻辑结构是由主要一下关系模式组成具体的关系模式如下 1用户信息主键id、用户id、用户姓名、表名、角色id、角色名、密码、新增时间、过期时间 2角色信息主键id、角色名称、角色描述、新增时间、过期时间 3角色权限信息主键id、角色id、角色名称、关联的菜单id、关联的菜单名、新增时间、过期时间 4菜单信息主键id、菜单名称、菜单访问路径、菜单描述、上级菜单id、新增时间、过期时间 5文章信息主键id、创建日期、文章名称、文章内容描述、文章类型、文章标签、文章点赞数、文章访问数、父节点id、上传用户id、上传用户姓名、状态、文章审核状态、审核人id、审核人 6评论信息主键id、创建日期、文章id、文章名、评论人id、评论人姓名、评论内容、是否审核、评论时间等 第五章  系统详细设计 5.1 供应商管理 5.2 库存管理 5.3 供应商统计分析 5.4 商品管理 5.5 应收管理 5.6 库存盘点 5.7 入库历史 5.8 进货订单 第六章  部分代码实现 6.1  Spring boot  配置代码 # Tomcat server:tomcat:uri-encoding: UTF-8port: 8080servlet:context-path: /springboot0t8qlspring:datasource:driverClassName: com.mysql.jdbc.Driverurl: jdbc:mysql://127.0.0.1:3306/springboot0t8ql?useUnicodetruecharacterEncodingutf-8useJDBCCompliantTimezoneShifttrueuseLegacyDatetimeCodefalseserverTimezoneGMT%2B8username: rootpassword: 123456# driverClassName: com.microsoft.sqlserver.jdbc.SQLServerDriver # url: jdbc:sqlserver://127.0.0.1:1433;DatabaseNamespringboot0t8ql # username: sa # password: 123456servlet:multipart:max-file-size: 10MBmax-request-size: 10MBresources:static-locations: classpath:/testStatic/,classpath:/META-INF/resources/,classpath:/resources/,classpath:/static/,classpath:/public/#mybatis mybatis-plus:mapper-locations: classpath*:mapper/*.xml#实体扫描多个package用逗号或者分号分隔typeAliasesPackage: com.entityglobal-config:#主键类型 0:数据库ID自增, 1:用户输入ID,2:全局唯一ID (数字类型唯一ID), 3:全局唯一ID UUID;id-type: 1#字段策略 0:忽略判断,1:非 NULL 判断),2:非空判断field-strategy: 2#驼峰下划线转换db-column-underline: true#刷新mapper 调试神器refresh-mapper: true#逻辑删除配置logic-delete-value: -1logic-not-delete-value: 0#自定义SQL注入器sql-injector: com.baomidou.mybatisplus.mapper.LogicSqlInjectorconfiguration:map-underscore-to-camel-case: truecache-enabled: falsecall-setters-on-nulls: true#springboot 项目mybatis plus 设置 jdbcTypeForNull (oracle数据库需配置JdbcType.NULL, 默认是Other) jdbc-type-for-null: null 6.2 用户管理及登录登出代码 /*** 用户账户用于保存用户登录信息(User)表控制层*/ Slf4j RestController RequestMapping(user) public class UserController extends BaseControllerUser, UserService {/*** 服务对象*/Autowiredpublic UserController(UserService service) {setService(service);}/*** Token服务*/Autowiredprivate AccessTokenService tokenService;Autowiredprivate UserGroupService userGroupService;/*** 注册* param user* return*/PostMapping(register)public MapString, Object signUp(RequestBody User user) {// 查询用户MapString, String query new HashMap();query.put(username,user.getUsername());List list service.select(query, new HashMap()).getResultList();if (list.size()0){return error(30000, 用户已存在);}user.setUserId(null);user.setPassword(service.encryption(user.getPassword()));service.save(user);return success(1);}/*** 找回密码* param form* return*/PostMapping(forget_password)public MapString, Object forgetPassword(RequestBody User form,HttpServletRequest request) {JSONObject ret new JSONObject();String username form.getUsername();String code form.getCode();String password form.getPassword();// 判断条件if(code null || code.length() 0){return error(30000, 验证码不能为空);}if(username null || username.length() 0){return error(30000, 用户名不能为空);}if(password null || password.length() 0){return error(30000, 密码不能为空);}// 查询用户MapString, String query new HashMap();query.put(username,username);Query select service.select(query, service.readConfig(request));List list select.getResultList();if (list.size() 0) {User o (User) list.get(0);JSONObject query2 new JSONObject();JSONObject form2 new JSONObject();// 修改用户密码query2.put(user_id,o.getUserId());form2.put(password,service.encryption(password));service.update(query, service.readConfig(request), form2);return success(1);}return error(70000,用户不存在);}/*** 登录* param data* param httpServletRequest* return*/PostMapping(login)public MapString, Object login(RequestBody MapString, String data, HttpServletRequest httpServletRequest) {log.info([执行登录接口]);String username data.get(username);String email data.get(email);String phone data.get(phone);String password data.get(password);List resultList null;MapString, String map new HashMap();if(username ! null .equals(username) false){map.put(username, username);resultList service.select(map, new HashMap()).getResultList();}else if(email ! null .equals(email) false){map.put(email, email);resultList service.select(map, new HashMap()).getResultList();}else if(phone ! null .equals(phone) false){map.put(phone, phone);resultList service.select(map, new HashMap()).getResultList();}else{return error(30000, 账号或密码不能为空);}if (resultList null || password null) {return error(30000, 账号或密码不能为空);}//判断是否有这个用户if (resultList.size()0){return error(30000,用户不存在);}User byUsername (User) resultList.get(0);MapString, String groupMap new HashMap();groupMap.put(name,byUsername.getUserGroup());List groupList userGroupService.select(groupMap, new HashMap()).getResultList();if (groupList.size()1){return error(30000,用户组不存在);}UserGroup userGroup (UserGroup) groupList.get(0);//查询用户审核状态if (!StringUtils.isEmpty(userGroup.getSourceTable())){String sql select examine_state from userGroup.getSourceTable() WHERE user_id byUsername.getUserId();String res String.valueOf(service.runCountSql(sql).getSingleResult());if (resnull){return error(30000,用户不存在);}if (!res.equals(已通过)){return error(30000,该用户审核未通过);}}//查询用户状态if (byUsername.getState()!1){return error(30000,用户非可用状态不能登录);}String md5password service.encryption(password);if (byUsername.getPassword().equals(md5password)) {// 存储Token到数据库AccessToken accessToken new AccessToken();accessToken.setToken(UUID.randomUUID().toString().replaceAll(-, ));accessToken.setUser_id(byUsername.getUserId());tokenService.save(accessToken);// 返回用户信息JSONObject user JSONObject.parseObject(JSONObject.toJSONString(byUsername));user.put(token, accessToken.getToken());JSONObject ret new JSONObject();ret.put(obj,user);return success(ret);} else {return error(30000, 账号或密码不正确);}}/*** 修改密码* param data* param request* return*/PostMapping(change_password)public MapString, Object change_password(RequestBody MapString, String data, HttpServletRequest request){// 根据Token获取UserIdString token request.getHeader(x-auth-token);Integer userId tokenGetUserId(token);// 根据UserId和旧密码获取用户MapString, String query new HashMap();String o_password data.get(o_password);query.put(user_id ,String.valueOf(userId));query.put(password ,service.encryption(o_password));Query ret service.count(query, service.readConfig(request));List list ret.getResultList();Object s list.get(0);int count Integer.parseInt(list.get(0).toString());if(count 0){// 修改密码MapString,Object form new HashMap();form.put(password,service.encryption(data.get(password)));service.update(query,service.readConfig(request),form);return success(1);}return error(10000,密码修改失败);}/*** 登录态* param request* return*/GetMapping(state)public MapString, Object state(HttpServletRequest request) {JSONObject ret new JSONObject();// 获取状态String token request.getHeader(x-auth-token);// 根据登录态获取用户IDInteger userId tokenGetUserId(token);log.info([返回userId] {},userId);if(userId null || userId 0){return error(10000,用户未登录!);}// 根据用户ID获取用户MapString,String query new HashMap();query.put(user_id ,String.valueOf(userId));// 根据用户ID获取Query select service.select(query,service.readConfig(request));List resultList select.getResultList();if (resultList.size() 0) {JSONObject user JSONObject.parseObject(JSONObject.toJSONString(resultList.get(0)));user.put(token,token);ret.put(obj,user);return success(ret);} else {return error(10000,用户未登录!);}}/*** 登录态* param request* return*/GetMapping(quit)public MapString, Object quit(HttpServletRequest request) {String token request.getHeader(x-auth-token);JSONObject ret new JSONObject();MapString, String query new HashMap(16);query.put(token, token);try{tokenService.delete(query,service.readConfig(request));}catch (Exception e){e.printStackTrace();}return success(退出登录成功);}/*** 获取登录用户ID* param token* return*/public Integer tokenGetUserId(String token) {log.info([获取的token] {},token);// 根据登录态获取用户IDif(token null || .equals(token)){return 0;}MapString, String query new HashMap(16);query.put(token, token);AccessToken byToken tokenService.findOne(query);if(byToken null){return 0;}return byToken.getUser_id();}/*** 重写add* return*/PostMapping(/add)Transactionalpublic MapString, Object add(HttpServletRequest request) throws IOException {MapString,Object map service.readBody(request.getReader());map.put(password,service.encryption(String.valueOf(map.get(password))));service.insert(map);return success(1);}} 6.3 Md5 加密算法代码 public class MD5Utils {private static final Logger logger LoggerFactory.getLogger(MD5Utils.class);// 全局数组private final static String[] strDigits {0, 1, 2, 3, 4, 5,6, 7, 8, 9, a, b, c, d, e, f};/*** 16进制字符*/private final static char hexdigits[] {0, 1, 2, 3, 4, 5, 6, 7, 8,9, a, b, c, d, e, f};/*** 对文件全文生成MD5摘要** param file 要加密的文件* return MD5摘要码*/public static String getMD5ForFile(String filePath) {FileInputStream fis null;MessageDigest md null;try {md MessageDigest.getInstance(MD5);File file new File(filePath);if (!file.exists()) {return ;}fis new FileInputStream(file);byte[] buffer new byte[4096];int length -1;while ((length fis.read(buffer)) ! -1) {md.update(buffer, 0, length);}byte[] b md.digest();return byteToHexString(b);} catch (Exception ex) {logger.error(获取MD5信息发生异常 ex.toString());return null;} finally {try {if (null ! fis) {fis.close();}} catch (IOException e) {logger.error(获取MD5信息发生异常 e.toString());}}}/*** 把byte[]数组转换成十六进制字符串表示形式** param tmp 要转换的byte[]* return 十六进制字符串表示形式*/private static String byteToHexString(byte[] tmp) {String s;char str[] new char[16 * 2];int k 0;for (int i 0; i 16; i) {byte byte0 tmp[i];str[k] hexdigits[byte0 4 0xf];str[k] hexdigits[byte0 0xf];}s new String(str);return s;}// 返回形式为数字跟字符串private static String byteToArrayString(byte bByte) {int iRet bByte;// System.out.println(iRetiRet);if (iRet 0) {iRet 256;}int iD1 iRet / 16;int iD2 iRet % 16;return strDigits[iD1] strDigits[iD2];}// 返回形式只为数字private static String byteToNum(byte bByte) {int iRet bByte;System.out.println(iRet1 iRet);if (iRet 0) {iRet 256;}return String.valueOf(iRet);}// 转换字节数组为16进制字串private static String byteToString(byte[] bByte) {StringBuffer sBuffer new StringBuffer();for (int i 0; i bByte.length; i) {sBuffer.append(byteToArrayString(bByte[i]));}return sBuffer.toString();}public static String GetMD5Code(String strObj) {if (StringUtils.isEmpty(strObj)) {return ;}String resultString null;try {resultString new String(strObj);MessageDigest md MessageDigest.getInstance(MD5);// md.digest() 该函数返回值为存放哈希值结果的byte数组resultString byteToString(md.digest(strObj.getBytes()));} catch (NoSuchAlgorithmException ex) {ex.printStackTrace();}return resultString;}} 6.4  部分数据库代码 -- ---------------------------- -- 1、部门表 -- ---------------------------- drop table if exists sys_dept; create table sys_dept (dept_id bigint(20) not null auto_increment comment 部门id,parent_id bigint(20) default 0 comment 父部门id,ancestors varchar(50) default comment 祖级列表,dept_name varchar(30) default comment 部门名称,order_num int(4) default 0 comment 显示顺序,leader varchar(20) default null comment 负责人,phone varchar(11) default null comment 联系电话,email varchar(50) default null comment 邮箱,status char(1) default 0 comment 部门状态0正常 1停用,del_flag char(1) default 0 comment 删除标志0代表存在 2代表删除,create_by varchar(64) default comment 创建者,create_time datetime comment 创建时间,update_by varchar(64) default comment 更新者,update_time datetime comment 更新时间,primary key (dept_id) ) engineinnodb auto_increment200 comment 部门表;-- ---------------------------- -- 初始化-部门表数据 -- ---------------------------- insert into sys_dept values(100, 0, 0, MCS科技, 0, MCS, 15888888888, ryqq.com, 0, 0, admin, sysdate(), , null); insert into sys_dept values(101, 100, 0,100, 深圳总公司, 1, MCS, 15888888888, ryqq.com, 0, 0, admin, sysdate(), , null); insert into sys_dept values(102, 100, 0,100, 长沙分公司, 2, MCS, 15888888888, ryqq.com, 0, 0, admin, sysdate(), , null); insert into sys_dept values(103, 101, 0,100,101, 研发部门, 1, MCS, 15888888888, ryqq.com, 0, 0, admin, sysdate(), , null); insert into sys_dept values(104, 101, 0,100,101, 市场部门, 2, MCS, 15888888888, ryqq.com, 0, 0, admin, sysdate(), , null); insert into sys_dept values(105, 101, 0,100,101, 测试部门, 3, MCS, 15888888888, ryqq.com, 0, 0, admin, sysdate(), , null); insert into sys_dept values(106, 101, 0,100,101, 财务部门, 4, MCS, 15888888888, ryqq.com, 0, 0, admin, sysdate(), , null); insert into sys_dept values(107, 101, 0,100,101, 运维部门, 5, MCS, 15888888888, ryqq.com, 0, 0, admin, sysdate(), , null); insert into sys_dept values(108, 102, 0,100,102, 市场部门, 1, MCS, 15888888888, ryqq.com, 0, 0, admin, sysdate(), , null); insert into sys_dept values(109, 102, 0,100,102, 财务部门, 2, MCS, 15888888888, ryqq.com, 0, 0, admin, sysdate(), , null);-- ---------------------------- -- 2、用户信息表 -- ---------------------------- drop table if exists sys_user; create table sys_user (user_id bigint(20) not null auto_increment comment 用户ID,dept_id bigint(20) default null comment 部门ID,login_name varchar(30) not null comment 登录账号,user_name varchar(30) default comment 用户昵称,user_type varchar(2) default 00 comment 用户类型00系统用户 01注册用户,email varchar(50) default comment 用户邮箱,phonenumber varchar(11) default comment 手机号码,sex char(1) default 0 comment 用户性别0男 1女 2未知,avatar varchar(100) default comment 头像路径,password varchar(50) default comment 密码,salt varchar(20) default comment 盐加密,status char(1) default 0 comment 帐号状态0正常 1停用,del_flag char(1) default 0 comment 删除标志0代表存在 2代表删除,login_ip varchar(128) default comment 最后登录IP,login_date datetime comment 最后登录时间,pwd_update_date datetime comment 密码最后更新时间,create_by varchar(64) default comment 创建者,create_time datetime comment 创建时间,update_by varchar(64) default comment 更新者,update_time datetime comment 更新时间,remark varchar(500) default null comment 备注,primary key (user_id) ) engineinnodb auto_increment100 comment 用户信息表;-- ---------------------------- -- 初始化-用户信息表数据 -- ---------------------------- insert into sys_user values(1, 103, admin, MCS, 00, ry163.com, 15888888888, 1, , 29c67a30398638269fe600f73a054934, 111111, 0, 0, 127.0.0.1, null, null, admin, sysdate(), , null, 管理员); insert into sys_user values(2, 105, ry, MCS, 00, ryqq.com, 15666666666, 1, , 8e6d98b90472783cc73c17047ddccf36, 222222, 0, 0, 127.0.0.1, null, null, admin, sysdate(), , null, 测试员);-- ---------------------------- -- 3、岗位信息表 -- ---------------------------- drop table if exists sys_post; create table sys_post (post_id bigint(20) not null auto_increment comment 岗位ID,post_code varchar(64) not null comment 岗位编码,post_name varchar(50) not null comment 岗位名称,post_sort int(4) not null comment 显示顺序,status char(1) not null comment 状态0正常 1停用,create_by varchar(64) default comment 创建者,create_time datetime comment 创建时间,update_by varchar(64) default comment 更新者,update_time datetime comment 更新时间,remark varchar(500) default null comment 备注,primary key (post_id) ) engineinnodb comment 岗位信息表;-- ---------------------------- -- 初始化-岗位信息表数据 -- ---------------------------- insert into sys_post values(1, ceo, 董事长, 1, 0, admin, sysdate(), , null, ); insert into sys_post values(2, se, 项目经理, 2, 0, admin, sysdate(), , null, ); insert into sys_post values(3, hr, 人力资源, 3, 0, admin, sysdate(), , null, ); insert into sys_post values(4, user, 普通员工, 4, 0, admin, sysdate(), , null, );-- ---------------------------- -- 4、角色信息表 -- ---------------------------- drop table if exists sys_role; create table sys_role (role_id bigint(20) not null auto_increment comment 角色ID,role_name varchar(30) not null comment 角色名称,role_key varchar(100) not null comment 角色权限字符串,role_sort int(4) not null comment 显示顺序,data_scope char(1) default 1 comment 数据范围1全部数据权限 2自定数据权限 3本部门数据权限 4本部门及以下数据权限,status char(1) not null comment 角色状态0正常 1停用,del_flag char(1) default 0 comment 删除标志0代表存在 2代表删除,create_by varchar(64) default comment 创建者,create_time datetime comment 创建时间,update_by varchar(64) default comment 更新者,update_time datetime comment 更新时间,remark varchar(500) default null comment 备注,primary key (role_id) ) engineinnodb auto_increment100 comment 角色信息表;-- ---------------------------- -- 初始化-角色信息表数据 -- ---------------------------- insert into sys_role values(1, 超级管理员, admin, 1, 1, 0, 0, admin, sysdate(), , null, 超级管理员); insert into sys_role values(2, 普通角色, common, 2, 2, 0, 0, admin, sysdate(), , null, 普通角色);-- ---------------------------- -- 5、菜单权限表 -- ---------------------------- drop table if exists sys_menu; create table sys_menu (menu_id bigint(20) not null auto_increment comment 菜单ID,menu_name varchar(50) not null comment 菜单名称,parent_id bigint(20) default 0 comment 父菜单ID,order_num int(4) default 0 comment 显示顺序,url varchar(200) default # comment 请求地址,target varchar(20) default comment 打开方式menuItem页签 menuBlank新窗口,menu_type char(1) default comment 菜单类型M目录 C菜单 F按钮,visible char(1) default 0 comment 菜单状态0显示 1隐藏,is_refresh char(1) default 1 comment 是否刷新0刷新 1不刷新,perms varchar(100) default null comment 权限标识,icon varchar(100) default # comment 菜单图标,create_by varchar(64) default comment 创建者,create_time datetime comment 创建时间,update_by varchar(64) default comment 更新者,update_time datetime comment 更新时间,remark varchar(500) default comment 备注,primary key (menu_id) ) engineinnodb auto_increment2000 comment 菜单权限表;-- ---------------------------- -- 初始化-菜单信息表数据 -- ---------------------------- -- 一级菜单 insert into sys_menu values(1, 系统管理, 0, 1, #, , M, 0, 1, , fa fa-gear, admin, sysdate(), , null, 系统管理目录); insert into sys_menu values(2, 系统监控, 0, 2, #, , M, 0, 1, , fa fa-video-camera, admin, sysdate(), , null, 系统监控目录); insert into sys_menu values(3, 系统工具, 0, 3, #, , M, 0, 1, , fa fa-bars, admin, sysdate(), , null, 系统工具目录); insert into sys_menu values(4, MCS官网, 0, 4, http://ruoyi.vip, menuBlank, C, 0, 1, , fa fa-location-arrow, admin, sysdate(), , null, MCS官网地址); -- 二级菜单 insert into sys_menu values(100, 用户管理, 1, 1, /system/user, , C, 0, 1, system:user:view, fa fa-user-o, admin, sysdate(), , null, 用户管理菜单); insert into sys_menu values(101, 角色管理, 1, 2, /system/role, , C, 0, 1, system:role:view, fa fa-user-secret, admin, sysdate(), , null, 角色管理菜单); insert into sys_menu values(102, 菜单管理, 1, 3, /system/menu, , C, 0, 1, system:menu:view, fa fa-th-list, admin, sysdate(), , null, 菜单管理菜单); insert into sys_menu values(103, 部门管理, 1, 4, /system/dept, , C, 0, 1, system:dept:view, fa fa-outdent, admin, sysdate(), , null, 部门管理菜单); insert into sys_menu values(104, 岗位管理, 1, 5, /system/post, , C, 0, 1, system:post:view, fa fa-address-card-o, admin, sysdate(), , null, 岗位管理菜单); insert into sys_menu values(105, 字典管理, 1, 6, /system/dict, , C, 0, 1, system:dict:view, fa fa-bookmark-o, admin, sysdate(), , null, 字典管理菜单); insert into sys_menu values(106, 参数设置, 1, 7, /system/config, , C, 0, 1, system:config:view, fa fa-sun-o, admin, sysdate(), , null, 参数设置菜单); insert into sys_menu values(107, 通知公告, 1, 8, /system/notice, , C, 0, 1, system:notice:view, fa fa-bullhorn, admin, sysdate(), , null, 通知公告菜单); insert into sys_menu values(108, 日志管理, 1, 9, #, , M, 0, 1, , fa fa-pencil-square-o, admin, sysdate(), , null, 日志管理菜单); insert into sys_menu values(109, 在线用户, 2, 1, /monitor/online, , C, 0, 1, monitor:online:view, fa fa-user-circle, admin, sysdate(), , null, 在线用户菜单); insert into sys_menu values(110, 定时任务, 2, 2, /monitor/job, , C, 0, 1, monitor:job:view, fa fa-tasks, admin, sysdate(), , null, 定时任务菜单); insert into sys_menu values(111, 数据监控, 2, 3, /monitor/data, , C, 0, 1, monitor:data:view, fa fa-bug, admin, sysdate(), , null, 数据监控菜单); insert into sys_menu values(112, 服务监控, 2, 4, /monitor/server, , C, 0, 1, monitor:server:view, fa fa-server, admin, sysdate(), , null, 服务监控菜单); insert into sys_menu values(113, 缓存监控, 2, 5, /monitor/cache, , C, 0, 1, monitor:cache:view, fa fa-cube, admin, sysdate(), , null, 缓存监控菜单); insert into sys_menu values(114, 表单构建, 3, 1, /tool/build, , C, 0, 1, tool:build:view, fa fa-wpforms, admin, sysdate(), , null, 表单构建菜单); insert into sys_menu values(115, 代码生成, 3, 2, /tool/gen, , C, 0, 1, tool:gen:view, fa fa-code, admin, sysdate(), , null, 代码生成菜单); insert into sys_menu values(116, 系统接口, 3, 3, /tool/swagger, , C, 0, 1, tool:swagger:view, fa fa-gg, admin, sysdate(), , null, 系统接口菜单); -- 三级菜单 insert into sys_menu values(500, 操作日志, 108, 1, /monitor/operlog, , C, 0, 1, monitor:operlog:view, fa fa-address-book, admin, sysdate(), , null, 操作日志菜单); insert into sys_menu values(501, 登录日志, 108, 2, /monitor/logininfor, , C, 0, 1, monitor:logininfor:view, fa fa-file-image-o, admin, sysdate(), , null, 登录日志菜单); -- 用户管理按钮 insert into sys_menu values(1000, 用户查询, 100, 1, #, , F, 0, 1, system:user:list, #, admin, sysdate(), , null, ); insert into sys_menu values(1001, 用户新增, 100, 2, #, , F, 0, 1, system:user:add, #, admin, sysdate(), , null, ); insert into sys_menu values(1002, 用户修改, 100, 3, #, , F, 0, 1, system:user:edit, #, admin, sysdate(), , null, ); insert into sys_menu values(1003, 用户删除, 100, 4, #, , F, 0, 1, system:user:remove, #, admin, sysdate(), , null, ); insert into sys_menu values(1004, 用户导出, 100, 5, #, , F, 0, 1, system:user:export, #, admin, sysdate(), , null, ); insert into sys_menu values(1005, 用户导入, 100, 6, #, , F, 0, 1, system:user:import, #, admin, sysdate(), , null, ); insert into sys_menu values(1006, 重置密码, 100, 7, #, , F, 0, 1, system:user:resetPwd, #, admin, sysdate(), , null, ); -- 角色管理按钮 insert into sys_menu values(1007, 角色查询, 101, 1, #, , F, 0, 1, system:role:list, #, admin, sysdate(), , null, ); insert into sys_menu values(1008, 角色新增, 101, 2, #, , F, 0, 1, system:role:add, #, admin, sysdate(), , null, ); insert into sys_menu values(1009, 角色修改, 101, 3, #, , F, 0, 1, system:role:edit, #, admin, sysdate(), , null, ); insert into sys_menu values(1010, 角色删除, 101, 4, #, , F, 0, 1, system:role:remove, #, admin, sysdate(), , null, ); insert into sys_menu values(1011, 角色导出, 101, 5, #, , F, 0, 1, system:role:export, #, admin, sysdate(), , null, ); -- 菜单管理按钮 insert into sys_menu values(1012, 菜单查询, 102, 1, #, , F, 0, 1, system:menu:list, #, admin, sysdate(), , null, ); insert into sys_menu values(1013, 菜单新增, 102, 2, #, , F, 0, 1, system:menu:add, #, admin, sysdate(), , null, ); insert into sys_menu values(1014, 菜单修改, 102, 3, #, , F, 0, 1, system:menu:edit, #, admin, sysdate(), , null, ); insert into sys_menu values(1015, 菜单删除, 102, 4, #, , F, 0, 1, system:menu:remove, #, admin, sysdate(), , null, ); -- 部门管理按钮 insert into sys_menu values(1016, 部门查询, 103, 1, #, , F, 0, 1, system:dept:list, #, admin, sysdate(), , null, ); insert into sys_menu values(1017, 部门新增, 103, 2, #, , F, 0, 1, system:dept:add, #, admin, sysdate(), , null, ); insert into sys_menu values(1018, 部门修改, 103, 3, #, , F, 0, 1, system:dept:edit, #, admin, sysdate(), , null, ); insert into sys_menu values(1019, 部门删除, 103, 4, #, , F, 0, 1, system:dept:remove, #, admin, sysdate(), , null, ); -- 岗位管理按钮 insert into sys_menu values(1020, 岗位查询, 104, 1, #, , F, 0, 1, system:post:list, #, admin, sysdate(), , null, ); insert into sys_menu values(1021, 岗位新增, 104, 2, #, , F, 0, 1, system:post:add, #, admin, sysdate(), , null, ); insert into sys_menu values(1022, 岗位修改, 104, 3, #, , F, 0, 1, system:post:edit, #, admin, sysdate(), , null, ); insert into sys_menu values(1023, 岗位删除, 104, 4, #, , F, 0, 1, system:post:remove, #, admin, sysdate(), , null, ); insert into sys_menu values(1024, 岗位导出, 104, 5, #, , F, 0, 1, system:post:export, #, admin, sysdate(), , null, ); -- 字典管理按钮 insert into sys_menu values(1025, 字典查询, 105, 1, #, , F, 0, 1, system:dict:list, #, admin, sysdate(), , null, ); insert into sys_menu values(1026, 字典新增, 105, 2, #, , F, 0, 1, system:dict:add, #, admin, sysdate(), , null, ); insert into sys_menu values(1027, 字典修改, 105, 3, #, , F, 0, 1, system:dict:edit, #, admin, sysdate(), , null, ); insert into sys_menu values(1028, 字典删除, 105, 4, #, , F, 0, 1, system:dict:remove, #, admin, sysdate(), , null, ); insert into sys_menu values(1029, 字典导出, 105, 5, #, , F, 0, 1, system:dict:export, #, admin, sysdate(), , null, ); -- 参数设置按钮 insert into sys_menu values(1030, 参数查询, 106, 1, #, , F, 0, 1, system:config:list, #, admin, sysdate(), , null, ); insert into sys_menu values(1031, 参数新增, 106, 2, #, , F, 0, 1, system:config:add, #, admin, sysdate(), , null, ); insert into sys_menu values(1032, 参数修改, 106, 3, #, , F, 0, 1, system:config:edit, #, admin, sysdate(), , null, ); insert into sys_menu values(1033, 参数删除, 106, 4, #, , F, 0, 1, system:config:remove, #, admin, sysdate(), , null, ); insert into sys_menu values(1034, 参数导出, 106, 5, #, , F, 0, 1, system:config:export, #, admin, sysdate(), , null, ); -- 通知公告按钮 insert into sys_menu values(1035, 公告查询, 107, 1, #, , F, 0, 1, system:notice:list, #, admin, sysdate(), , null, ); insert into sys_menu values(1036, 公告新增, 107, 2, #, , F, 0, 1, system:notice:add, #, admin, sysdate(), , null, ); insert into sys_menu values(1037, 公告修改, 107, 3, #, , F, 0, 1, system:notice:edit, #, admin, sysdate(), , null, ); insert into sys_menu values(1038, 公告删除, 107, 4, #, , F, 0, 1, system:notice:remove, #, admin, sysdate(), , null, ); -- 操作日志按钮 insert into sys_menu values(1039, 操作查询, 500, 1, #, , F, 0, 1, monitor:operlog:list, #, admin, sysdate(), , null, ); insert into sys_menu values(1040, 操作删除, 500, 2, #, , F, 0, 1, monitor:operlog:remove, #, admin, sysdate(), , null, ); insert into sys_menu values(1041, 详细信息, 500, 3, #, , F, 0, 1, monitor:operlog:detail, #, admin, sysdate(), , null, ); insert into sys_menu values(1042, 日志导出, 500, 4, #, , F, 0, 1, monitor:operlog:export, #, admin, sysdate(), , null, ); -- 登录日志按钮 insert into sys_menu values(1043, 登录查询, 501, 1, #, , F, 0, 1, monitor:logininfor:list, #, admin, sysdate(), , null, ); insert into sys_menu values(1044, 登录删除, 501, 2, #, , F, 0, 1, monitor:logininfor:remove, #, admin, sysdate(), , null, ); insert into sys_menu values(1045, 日志导出, 501, 3, #, , F, 0, 1, monitor:logininfor:export, #, admin, sysdate(), , null, ); insert into sys_menu values(1046, 账户解锁, 501, 4, #, , F, 0, 1, monitor:logininfor:unlock, #, admin, sysdate(), , null, ); -- 在线用户按钮 insert into sys_menu values(1047, 在线查询, 109, 1, #, , F, 0, 1, monitor:online:list, #, admin, sysdate(), , null, ); insert into sys_menu values(1048, 批量强退, 109, 2, #, , F, 0, 1, monitor:online:batchForceLogout, #, admin, sysdate(), , null, ); insert into sys_menu values(1049, 单条强退, 109, 3, #, , F, 0, 1, monitor:online:forceLogout, #, admin, sysdate(), , null, ); -- 定时任务按钮 insert into sys_menu values(1050, 任务查询, 110, 1, #, , F, 0, 1, monitor:job:list, #, admin, sysdate(), , null, ); insert into sys_menu values(1051, 任务新增, 110, 2, #, , F, 0, 1, monitor:job:add, #, admin, sysdate(), , null, ); insert into sys_menu values(1052, 任务修改, 110, 3, #, , F, 0, 1, monitor:job:edit, #, admin, sysdate(), , null, ); insert into sys_menu values(1053, 任务删除, 110, 4, #, , F, 0, 1, monitor:job:remove, #, admin, sysdate(), , null, ); insert into sys_menu values(1054, 状态修改, 110, 5, #, , F, 0, 1, monitor:job:changeStatus, #, admin, sysdate(), , null, ); insert into sys_menu values(1055, 任务详细, 110, 6, #, , F, 0, 1, monitor:job:detail, #, admin, sysdate(), , null, ); insert into sys_menu values(1056, 任务导出, 110, 7, #, , F, 0, 1, monitor:job:export, #, admin, sysdate(), , null, ); -- 代码生成按钮 insert into sys_menu values(1057, 生成查询, 115, 1, #, , F, 0, 1, tool:gen:list, #, admin, sysdate(), , null, ); insert into sys_menu values(1058, 生成修改, 115, 2, #, , F, 0, 1, tool:gen:edit, #, admin, sysdate(), , null, ); insert into sys_menu values(1059, 生成删除, 115, 3, #, , F, 0, 1, tool:gen:remove, #, admin, sysdate(), , null, ); insert into sys_menu values(1060, 预览代码, 115, 4, #, , F, 0, 1, tool:gen:preview, #, admin, sysdate(), , null, ); insert into sys_menu values(1061, 生成代码, 115, 5, #, , F, 0, 1, tool:gen:code, #, admin, sysdate(), , null, );-- ---------------------------- -- 6、用户和角色关联表 用户N-1角色 -- ---------------------------- drop table if exists sys_user_role; create table sys_user_role (user_id bigint(20) not null comment 用户ID,role_id bigint(20) not null comment 角色ID,primary key(user_id, role_id) ) engineinnodb comment 用户和角色关联表;-- ---------------------------- -- 初始化-用户和角色关联表数据 -- ---------------------------- insert into sys_user_role values (1, 1); insert into sys_user_role values (2, 2);-- ---------------------------- -- 7、角色和菜单关联表 角色1-N菜单 -- ---------------------------- drop table if exists sys_role_menu; create table sys_role_menu (role_id bigint(20) not null comment 角色ID,menu_id bigint(20) not null comment 菜单ID,primary key(role_id, menu_id) ) engineinnodb comment 角色和菜单关联表;-- ---------------------------- -- 初始化-角色和菜单关联表数据 -- ---------------------------- insert into sys_role_menu values (2, 1); insert into sys_role_menu values (2, 2); insert into sys_role_menu values (2, 3); insert into sys_role_menu values (2, 4); insert into sys_role_menu values (2, 100); insert into sys_role_menu values (2, 101); insert into sys_role_menu values (2, 102); insert into sys_role_menu values (2, 103); insert into sys_role_menu values (2, 104); insert into sys_role_menu values (2, 105); insert into sys_role_menu values (2, 106); insert into sys_role_menu values (2, 107); insert into sys_role_menu values (2, 108); insert into sys_role_menu values (2, 109); insert into sys_role_menu values (2, 110); insert into sys_role_menu values (2, 111); insert into sys_role_menu values (2, 112); insert into sys_role_menu values (2, 113); insert into sys_role_menu values (2, 114); insert into sys_role_menu values (2, 115); insert into sys_role_menu values (2, 116); insert into sys_role_menu values (2, 500); insert into sys_role_menu values (2, 501); insert into sys_role_menu values (2, 1000); insert into sys_role_menu values (2, 1001); insert into sys_role_menu values (2, 1002); insert into sys_role_menu values (2, 1003); insert into sys_role_menu values (2, 1004); insert into sys_role_menu values (2, 1005); insert into sys_role_menu values (2, 1006); insert into sys_role_menu values (2, 1007); insert into sys_role_menu values (2, 1008); insert into sys_role_menu values (2, 1009); insert into sys_role_menu values (2, 1010); insert into sys_role_menu values (2, 1011); insert into sys_role_menu values (2, 1012); insert into sys_role_menu values (2, 1013); insert into sys_role_menu values (2, 1014); insert into sys_role_menu values (2, 1015); insert into sys_role_menu values (2, 1016); insert into sys_role_menu values (2, 1017); insert into sys_role_menu values (2, 1018); insert into sys_role_menu values (2, 1019); insert into sys_role_menu values (2, 1020); insert into sys_role_menu values (2, 1021); insert into sys_role_menu values (2, 1022); insert into sys_role_menu values (2, 1023); insert into sys_role_menu values (2, 1024); insert into sys_role_menu values (2, 1025); insert into sys_role_menu values (2, 1026); insert into sys_role_menu values (2, 1027); insert into sys_role_menu values (2, 1028); insert into sys_role_menu values (2, 1029); insert into sys_role_menu values (2, 1030); insert into sys_role_menu values (2, 1031); insert into sys_role_menu values (2, 1032); insert into sys_role_menu values (2, 1033); insert into sys_role_menu values (2, 1034); insert into sys_role_menu values (2, 1035); insert into sys_role_menu values (2, 1036); insert into sys_role_menu values (2, 1037); insert into sys_role_menu values (2, 1038); insert into sys_role_menu values (2, 1039); insert into sys_role_menu values (2, 1040); insert into sys_role_menu values (2, 1041); insert into sys_role_menu values (2, 1042); insert into sys_role_menu values (2, 1043); insert into sys_role_menu values (2, 1044); insert into sys_role_menu values (2, 1045); insert into sys_role_menu values (2, 1046); insert into sys_role_menu values (2, 1047); insert into sys_role_menu values (2, 1048); insert into sys_role_menu values (2, 1049); insert into sys_role_menu values (2, 1050); insert into sys_role_menu values (2, 1051); insert into sys_role_menu values (2, 1052); insert into sys_role_menu values (2, 1053); insert into sys_role_menu values (2, 1054); insert into sys_role_menu values (2, 1055); insert into sys_role_menu values (2, 1056); insert into sys_role_menu values (2, 1057); insert into sys_role_menu values (2, 1058); insert into sys_role_menu values (2, 1059); insert into sys_role_menu values (2, 1060); insert into sys_role_menu values (2, 1061);-- ---------------------------- -- 8、角色和部门关联表 角色1-N部门 -- ---------------------------- drop table if exists sys_role_dept; create table sys_role_dept (role_id bigint(20) not null comment 角色ID,dept_id bigint(20) not null comment 部门ID,primary key(role_id, dept_id) ) engineinnodb comment 角色和部门关联表;-- ---------------------------- -- 初始化-角色和部门关联表数据 -- ---------------------------- insert into sys_role_dept values (2, 100); insert into sys_role_dept values (2, 101); insert into sys_role_dept values (2, 105);-- ---------------------------- -- 9、用户与岗位关联表 用户1-N岗位 -- ---------------------------- drop table if exists sys_user_post; create table sys_user_post (user_id bigint(20) not null comment 用户ID,post_id bigint(20) not null comment 岗位ID,primary key (user_id, post_id) ) engineinnodb comment 用户与岗位关联表;-- ---------------------------- -- 初始化-用户与岗位关联表数据 -- ---------------------------- insert into sys_user_post values (1, 1); insert into sys_user_post values (2, 2);-- ---------------------------- -- 10、操作日志记录 -- ---------------------------- drop table if exists sys_oper_log; create table sys_oper_log (oper_id bigint(20) not null auto_increment comment 日志主键,title varchar(50) default comment 模块标题,business_type int(2) default 0 comment 业务类型0其它 1新增 2修改 3删除,method varchar(200) default comment 方法名称,request_method varchar(10) default comment 请求方式,operator_type int(1) default 0 comment 操作类别0其它 1后台用户 2手机端用户,oper_name varchar(50) default comment 操作人员,dept_name varchar(50) default comment 部门名称,oper_url varchar(255) default comment 请求URL,oper_ip varchar(128) default comment 主机地址,oper_location varchar(255) default comment 操作地点,oper_param varchar(2000) default comment 请求参数,json_result varchar(2000) default comment 返回参数,status int(1) default 0 comment 操作状态0正常 1异常,error_msg varchar(2000) default comment 错误消息,oper_time datetime comment 操作时间,cost_time bigint(20) default 0 comment 消耗时间,primary key (oper_id),key idx_sys_oper_log_bt (business_type),key idx_sys_oper_log_s (status),key idx_sys_oper_log_ot (oper_time) ) engineinnodb auto_increment100 comment 操作日志记录; 第八章 结 论 本文研究了在线学习交流平台系统的设计与实现在文章开端首先对个研究背景、研究现状和研究内容作了简单的介绍然后通过系统分析引申出本系统研究的主要内容。 通过对java语言、springboot框架和mysql数据库的简介系统的说明了在线学习交流平台的设计与实现的可行性本文结论及研究成果如下实现了java与mysql相结合构建的在线学习交流平台通过本次对在线学习交流平台的设计与实现的研究与实现我感触到学习一门新技术最重要的是实践只有多动手才能尽快掌握它一个系统的开发经验是最重要的经验不足就难免会有许多考虑不周之处。要想吸引更多的用户系统的界面必须要美观、有特色、友好功能要健全。 由于在此之前对于java知识并不了解所以从一开始就碰到许多困难例如一开始的页面显示不规范、数据库连接有问题已经无法实现参数的传递等等不过通过我不断的查阅相关的资料以及向老师同学请教最后出现的所有的问题都得到了解决通过这次的系统开发我学到了很多的知识也明白了自己在哪些方面有不足的地方尤其是学会如何从大量的信息中筛选出所需有用的信息同时我更加深刻的体会到了虽然书本上的大部分知识都是有价值正确的但实际上每个人编程的思路和对数据处理的方法、思想都是不同的这就要求我们一定要通过实践才能找到解决问题的方案。在此次毕业设计活动中我不断的提高了自己也得到了宝贵的经验我相信这些对我以后的发展都会有很大帮助。 通过这次对药品进销存仓库管理系统的开发让我学到了更多的知识同时通过这次系统的设计也让我明白了自己在哪方面有不足以后加以学习争取可以开发住更多有用的适用的系统软件本次系统的设计提高了我的编程水平为了我今后系统的开发打下了结实的基础。  参考文献 [1] 高永强.基于深度学习的个性化推荐研究[J].工业控制计算机,2021,34(10):90-92. [2] 张安淇,李元旭.互联网知识共享平台信息过载效应与弱化机制——基于知乎的案例研究[J]. 情报科学,2020,38(01):24-2941.DOI:10.13833/j.issn.1007-7634.2020.01.004. [3] Xiaoqin Shelley Zhang,Xiaojie Zhang,Pavan Kaparthi. Combat Information Overload Problem in Social Networks With Intelligent Information-Sharing and Response Mechanisms[J]. IEEE Transactions on Computational Social Systems,2020. [4] 刘馨蔚.“它经济”升温 宠物吸金强劲[J].中国对外贸易,2021(04):54-55. [5] 狗民网.2020 年中国宠物行业白皮书. [6] Lou Feng,Ning Xin. E-Commerce Recommendation Technology Based on Collaborative Filtering Algorithm and Mobile Cloud Computing[J]. Wireless Communications and Mobile Computing,2022,2022. [7] Goldberg D, Nichols D.A, Oki B.M, et al. Using collaborative filtering to weave an information tapestry[J]. Communications of The ACM, 1992, 35(12): 61-70. [8] Konstan J.A, Miller B.N, Maltz D.A, et al. GroupLens: Applying collaborative filtering to Usenet news[J]. Communications of The ACM, 1997, 40(3): 77-87. [9] Venture Beat [EB/OB]. htp:/venturebeat.comn/ [2009-04]. [10] He X, Deng K, Wang X, et al. LightGCN: Simplifying and Powering Graph Convolution Network for Recommendation[C]. In ACM 2020. [11] Wang Hulong,Shen Zesheng,Jiang Shuzhen,Sun Guang,Zhang Ren Jie. User-based Collaborative Filtering Algorithm Design and Implementation[J]. Journal of Physics: Conference Series,2021,1757(1).0 [12] 邓园园吴美香,潘家辉.基于物品的改进协同过滤算法及应用[].计算机系统应用 2019,28(01):184-189. [13] Jena, Kalyan Kumar,Bhoi, Sourav Kumar,Mallick, Chittaranjan,Jena, Soumya Ranjan,Kumar, Raghvendra,Long, Hoang Viet,Son, Nguyen Thi Kim. Neural model based collaborative filtering for movie recommendation system[J]. International Journal of Information Technology,2022(prepublish). [14] Zhang Kaihan,Wang Zhiqiang,Liang Jiye,Zhao Xingwang. A Bayesian matrix factorization model for dynamic user embedding in recommender system[J]. Frontiers of Computer Science,2022,16(5). [15] 吴青洋,程旭,邓程鹏,丁浩轩,张宏,林胜海.基于聚类和奖惩用户模型的协同过滤算法[J].计 算机系统应用,2020,29(08):135-143.DOI:10.15888/j.cnki.csa.007491. [16] 陆文超,崔海朋.一种基于融合自编码与神经网络的协同过滤算法[J].中国水运(下半 月),2022,22(03):18-20. [17] 王宁,沈正一,崔德龙,刘晴瑞.结合协同过滤与隐语义模型的视频推荐策略[J].湖南工程学院 学报(自然科学版),2021,31(04):40-43.DOI:10.15987/j.cnki.hgbjbz.2021.04.007. [18] Thomas N. Kipf and Max Welling. Semi-Supervised Classification with Graph Convolutional Networks. In ICLR.2017 [19] 张术梅.MVC架构下网站的设计与实现思考[J].信息记录材 料,2022,23(01):92-94.DOI:10.16009/j.cnki.cn13-1295/tq.2022.01.036. [20] R.Karthik,T.S.Sridhar,R.Sriram. Digital Food ordering system based on Spring Framework[J]. International Journal of Recent Technology and Engineering (IJRTE),2020,8(6). [21] 曹华山.SSM 框架在 Web 应用开发中的设计与实现[J].无线互联科技,2021,18(11):108-109. [22] 胡世洋,赖森林.浅论SSM框架在构建“微农”信息服务中的应用[J].电脑知识与技 术,2021,17(34):4-6.DOI:10.14004/j.cnki.ckt.2021.3589. [23] Di Lu,Yuping Qiu,Chun Qian,Xi Wang,Wei Tan. Design of Campus Resource Sharing Platform based on SSM Framework[J]. IOP Conference Series: Materials Science and Engineering,2019,490(6). [24] Xiaojie Guo,Tingmei Wang*. Design and Implementation of Graduate Information Management System Based on SSM Framework[J]. Journal of Simulation,2020,8(2). [25] Feng Leijie,Mu Zehui. Research on Mobile Point Exchange System Based on Collaborative Filtering Recommendation Algorithm[J]. International Journal of Advanced Network, Monitoring and Controls,2021,6(2). [26] 赖佳星.基于Bootstrap和JavaScript技术设计与实现简易Web计算器[J].科技资 讯,2022,20(01):13-16.DOI:10.16661/j.cnki.1672-3791.2110-5042-2874. [27] Haokun Qi, Qingyang Feng , Junyan Zhang. Technology and analysis of JSP-based merchandising system[J]. Scientific Journal of Intelligent Systems Research,2022,4(2). [28] 周公平.基于jQuery框架的Web前端开发设计方法研究[J].信息与电脑(理论 版),2022,34(05):128-130. [29] Liu Hongqing,Liu Yan. Research on Personalized Blog Customization System Based on AJAX[C]//.Proceedings of 2018 5th International Conference on Electrical Electronics Engineering and Computer Science(ICEEECS 2018).,2018:136-139. [30] 朱克武.Ajax技术在就业网站用户信息管理中的应用[J].电脑知识与技 术,2021,17(33):9-11.DOI:10.14004/j.cnki.ckt.2021.3303.  致谢 在毕业设计的过程中通过对药品进销存仓库管理系统的设计我受益匪浅。在这段时间里大学四年所学的知识得到了综合的运用掌握了软件开发的基本方法了解了当今软件开发的一些新技术。 本设计是在A老师的悉心指导和热情帮助下完成的。无论在理论上还是在实践中老师都给予我很大的帮助每当遇到困难时老师总是耐心的给我讲解老师认真负责的工作态度让我敬佩。值此论文完成之际特别向指导老师表示衷心的感谢和崇高的敬意谢谢他细心而又耐心地辅导使得我得以顺利的完成毕业设计开发工作同时也要感谢其他帮助过我的老师和同学他们在我完成设计过程中给予我很大的帮助在此一并表示感谢。 在论文编写过程中虽然反复推敲核证但由于本人水平有限加上时间紧促本文一定有不少缺点和不足恳请各位老师给予帮助和指正。 ------------------------------------------------------------------  附一、论文参考 附二、其他案例  附三、源码获取 大家点赞、收藏、关注、评论啦 、查看获取联系方式 打卡 文章 更新 308/  365天 精彩专栏推荐订阅在下方专栏 Java项目精品实战案例《100套》 Java微信小程序项目实战《100套》
http://www.pierceye.com/news/248567/

相关文章:

  • 东莞做汽车有没有买票的网站做谷歌推广一个月赚10万
  • 抚州城乡建设厅网站建设局官网查询
  • 汉中微信网站建设装修3d效果图怎么制作
  • wordpress 主题放哪站内关键词自然排名优化
  • 网站备案后经营做网站实例教程
  • 软件网站怎么做的python下载安装教程
  • 旅游网站开发分析报告网站建设教程搭建芽嘱湖南岚鸿信赖
  • 网站的配色方案高校网站建设意义
  • 滇中引水工程建设管理局网站网站开发怎样验收
  • ps制作网站logo阿里云网站备案拍照
  • 网站建设合同】wordpress翻书
  • 电商网站建设制作隆化县建设局网站
  • 宁波网站建设rswl网页美工设计教案
  • 贵州省住房城乡建设部网站json网站开发
  • 桥头网站仿做百度里面的站长工具怎么取消
  • 博物馆网站页面设计说明山东高端网站定制
  • python网站开发效率jsp做网站下载图片
  • 营销式网站建设免费注册个人网站官网
  • 高职高专 网站建设与维护开发一个网站平台多少钱
  • 网站后缀有哪些宜昌建设网站
  • iis做网站的流程wordpress有中文版没
  • 一般的美工可以做网站吗网站做相册
  • 扁平化网站psd招聘类网站怎么做
  • 想当淘客自己的网站怎么做服装网页设计网站
  • 网站怎么做数据接口wordpress主题知更
  • 注册网站登录企业网站建设论文模板
  • 营销型网站模板免费下载常用wordpress搭建环境
  • 浦东新区手机网站建设wordpress 视频页面
  • 做课件最好的素材网站网站背景动图怎么做
  • 做网站时已做好了ps怎么倒入深圳燃气公司地址