(基于B/S架构的java毕业设计)网上药店信息管理系统(附论文+源码)

大家好!我是职场程序猿,感谢您阅读本文,欢迎一键三连哦。

💞当前专栏:Java毕业设计

精彩专栏推荐👇🏻👇🏻👇🏻

👉🎀 安卓app毕业设计
👉🌎微信小程序毕业设计

一、项目简介

网上药店管理信息管理系统的开发方法为结构化开发方法,遵循系统分析、系统设计、系统实施和系统测试相应阶段的规则与要求。通过系统分析,明确了网上药店管理信息管理系统所需要完成的功能,并从技术、经济、法律三个方面进行可行性分析。系统设计分为系统总体设计和系统详细设计,总体设计明确了Browser/Server结构作为系统开发模式,并给出了总体功能结构图,详细设计包括数据库设计、处理过程设计和界面设计。在系统的实施阶段,采用的开发环境为 Eclipse,运用Java 高级编程语言做前台开发,Mysql数据库做后台数据库开发。网上药店管理信息管理系统的主要使用者分为游客、会员用户、管理员。游客只能浏览以及详细信息,会员用户能进行注册,登录,查看和修改帐户信息的操作,管理员则能进行登录、用户管理,管理和订单管理操作。药店管理系统分为前端药店药品商城和后台管理,前端商城主要实现普通商城功能,也包括个人信息设置;后台管理端包括:登录管理、新闻管理、药品管理、订单管理、出入库管理、销售统计等功能。是一个非常优秀的网上药店管理信息管理系统。

二、系统设计

2.1系统结构设计

系统架构图属于系统设计阶段,系统架构图只是这个阶段一个产物,系统的总体架构决定了整个系统的模式,是系统的基础。网上药店管理信息管理系统的整体结构设计如图4-2所示。
在这里插入图片描述

登录系统结构图,如图4-3所示:在这里插入图片描述
管理员所能使用的功能主要有:新闻管理、药店药品管理、订单管理、出入库管理、销售统计等功能。管理员结构图,如图4-4所示。在这里插入图片描述

2.2数据库设计

本系统的主要实体图如下:
1、管理员信息实体属性图如图4-5所示。在这里插入图片描述

2、药品信息实体图如图4-7所示:在这里插入图片描述

三、系统项目部分截图

3.1登录功能模块

系统主界面如下图5-1所示,包括:首页、新闻信息、在线交流信息、购物车信息、订单信息、评价信息等功能按钮。在这里插入图片描述

3.2管理员后台功能

选择管理员成功登录系统后,可以看到主要包括首页,信息管理部分,首页部分包括了对药品分类销售的统计图,例如可以选择以饼图进行显示。信息管理又包括管理员信息、用户信息、在线交流信息、新闻信息、药品类型、药品详情、订单信息、评价信息和个人信息。如下图5-5所示。在这里插入图片描述

3.3个人信息管理功能

个人设置主要包括个人资料和充值金额。个人资料包括管理员的姓名、昵称、联系电话和 Email等资料模块,个人资料修改就可以对这些资料进行修改。用户也可以选择在账户余额部分进行充值以进行相应药品的购买。如图5-5所示。在这里插入图片描述

四、论文目录

1 概述 1
1.1课题背景及意义 1
1.2 国内外研究现状 2
1.3 论文研究的目的与意义 3
1.4 本课题主要工作 3
2 系统开发环境 4
2.1 Java 相关技术简介 4
2.2 B/S结构 5
2.3 Spring boot框架 5
2.4Mysql数据库 6
3 系统分析 8
3.1 可行性分析 8
3.1.1 技术可行性 8
3.1.2操作可行性 8
3.1.3 经济可行性 9
3.1.4 法律可行性 9
3.2系统流程分析 9
3.2.1系统开发流程 9
3.2.2 用户登录流程 10
3.2.3 系统操作流程 10
3.2.4 添加信息流程 11
3.2.5 修改信息流程 11
3.2.6 删除信息流程 12
4 系统设计 13
4.1 系统概述 13
4.2 系统结构设计 13
4.3数据库设计 15
4.3.1 数据库设计原则 15
5统详细设计 17
5.1登录功能模块 17
5.2管理员后台功能 17
5.3个人信息管理功能 18
6系统测试 19
6.1系统测试的意义 19
6.2 测试方法 20
6.3测试分析 20
结 论 21
致 谢 22
参考文献 23

五、部分核心代码

4.1 用户部分

package com.example.controller;

import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.collection.CollectionUtil;
import cn.hutool.core.io.IoUtil;
import cn.hutool.core.util.ObjectUtil;
import cn.hutool.core.util.StrUtil;
import cn.hutool.poi.excel.ExcelUtil;
import cn.hutool.poi.excel.ExcelWriter;
import com.example.common.Result;
import com.example.common.ResultCode;
import com.example.entity.UserInfo;
import com.example.service.UserInfoService;
import com.example.exception.CustomException;
import com.example.common.ResultCode;
import com.example.vo.UserInfoVo;

import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import com.example.service.*;
import org.springframework.web.bind.annotation.*;
import org.springframework.beans.factory.annotation.Value;
import cn.hutool.core.util.StrUtil;
import org.springframework.web.multipart.MultipartFile;

import javax.annotation.Resource;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;

@RestController
@RequestMapping(value = "/userInfo")
public class UserInfoController {

    @Resource
    private UserInfoService userInfoService;

    @PostMapping
    public Result<UserInfo> add(@RequestBody UserInfoVo userInfo) {
        userInfoService.add(userInfo);
        return Result.success(userInfo);
    }

    @DeleteMapping("/{id}")
    public Result delete(@PathVariable Long id) {
        userInfoService.delete(id);
        return Result.success();
    }

    @PutMapping
    public Result update(@RequestBody UserInfoVo userInfo) {
        userInfoService.update(userInfo);
        return Result.success();
    }

    @GetMapping("/{id}")
    public Result<UserInfo> detail(@PathVariable Long id) {
        UserInfo userInfo = userInfoService.findById(id);
        return Result.success(userInfo);
    }

    @GetMapping
    public Result<List<UserInfoVo>> all() {
        return Result.success(userInfoService.findAll());
    }

    @GetMapping("/page/{name}")
    public Result<PageInfo<UserInfoVo>> page(@PathVariable String name,
                                                @RequestParam(defaultValue = "1") Integer pageNum,
                                                @RequestParam(defaultValue = "5") Integer pageSize,
                                                HttpServletRequest request) {
        return Result.success(userInfoService.findPage(name, pageNum, pageSize, request));
    }

    @PostMapping("/register")
    public Result<UserInfo> register(@RequestBody UserInfo userInfo) {
        if (StrUtil.isBlank(userInfo.getName()) || StrUtil.isBlank(userInfo.getPassword())) {
            throw new CustomException(ResultCode.PARAM_ERROR);
        }
        return Result.success(userInfoService.add(userInfo));
    }

    /**
    * 批量通过excel添加信息
    * @param file excel文件
    * @throws IOException
    */
    @PostMapping("/upload")
    public Result upload(MultipartFile file) throws IOException {

        List<UserInfo> infoList = ExcelUtil.getReader(file.getInputStream()).readAll(UserInfo.class);
        if (!CollectionUtil.isEmpty(infoList)) {
            // 处理一下空数据
            List<UserInfo> resultList = infoList.stream().filter(x -> ObjectUtil.isNotEmpty(x.getName())).collect(Collectors.toList());
            for (UserInfo info : resultList) {
                userInfoService.add(info);
            }
        }
        return Result.success();
    }

    @GetMapping("/getExcelModel")
    public void getExcelModel(HttpServletResponse response) throws IOException {
        // 1. 生成excel
        Map<String, Object> row = new LinkedHashMap<>();
		row.put("name", "张天志");
		row.put("password", "123456");
		row.put("nickName", "老张");
		row.put("sex", "男");
		row.put("age", 22);
		row.put("birthday", "TIME");
		row.put("phone", "18843232356");
		row.put("address", "上海市");
		row.put("email", "aa@163.com");
		row.put("cardId", "342425199001116372");
		row.put("level", 3);

        List<Map<String, Object>> list = CollUtil.newArrayList(row);

        // 2. 写excel
        ExcelWriter writer = ExcelUtil.getWriter(true);
        writer.write(list, true);

        response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8");
        response.setHeader("Content-Disposition","attachment;filename=userInfoModel.xlsx");

        ServletOutputStream out = response.getOutputStream();
        writer.flush(out, true);
        writer.close();
        IoUtil.close(System.out);
    }
}

4.2菜单部分

package com.example.controller;

import cn.hutool.json.JSONArray;
import cn.hutool.json.JSONObject;
import com.example.common.Result;
import com.example.entity.Account;
import com.example.service.*;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import java.util.HashMap;
import java.util.Map;

@RestController
public class MenuController {

	@Resource
	private AdminInfoService adminInfoService;
	@Resource
	private BusinessInfoService businessInfoService;
	@Resource
	private UserInfoService userInfoService;
	@Resource
	private AdvertiserInfoService advertiserInfoService;


    @GetMapping(value = "/getMenu", produces="application/json;charset=UTF-8")
    public String getMenu(HttpServletRequest request) {
        Account account = (Account) request.getSession().getAttribute("user");
        Integer level;
        if (account == null) {
            level = 1;
        } else {
            level = account.getLevel();
        }
        JSONObject obj = new JSONObject();
        obj.putOpt("code", 0);
        obj.putOpt("msg", "");
        JSONArray dataArray = new JSONArray();

        dataArray.add(getJsonObject("/", "系统首页", "layui-icon-home", "/"));

        JSONObject tableObj = new JSONObject();
        tableObj.putOpt("title", "信息管理");
        tableObj.putOpt("icon", "layui-icon-table");
		if (1 == level) {
			JSONArray array = new JSONArray();
			array.add(getJsonObject("adminInfo", "管理员信息", "layui-icon-table", "adminInfo"));
			array.add(getJsonObject("businessInfo", "卖家信息", "layui-icon-table", "businessInfo"));
			array.add(getJsonObject("userInfo", "用户信息", "layui-icon-table", "userInfo"));
			array.add(getJsonObject("messageInfo", "在线交流信息", "layui-icon-table", "messageInfo"));
			array.add(getJsonObject("advertiserInfo", "新闻信息", "layui-icon-table", "advertiserInfo"));
			array.add(getJsonObject("typeInfo", "药品类型", "layui-icon-table", "typeInfo"));
			array.add(getJsonObject("goodsInfo", "药品详情", "layui-icon-table", "goodsInfo"));
			array.add(getJsonObject("orderInfo", "订单信息", "layui-icon-table", "orderInfo"));
			array.add(getJsonObject("commentInfo", "评价信息", "layui-icon-table", "commentInfo"));
			array.add(getJsonObject("accountAdminInfo", "个人信息", "layui-icon-user", "accountAdminInfo"));
			tableObj.putOpt("list", array);
		}

		if (2 == level) {
			JSONArray array = new JSONArray();
			array.add(getJsonObject("userInfo", "用户信息", "layui-icon-table", "userInfo"));
			array.add(getJsonObject("messageInfo", "在线交流信息", "layui-icon-table", "messageInfo"));
			array.add(getJsonObject("advertiserInfo", "新闻信息", "layui-icon-table", "advertiserInfo"));
			array.add(getJsonObject("typeInfo", "药品类型", "layui-icon-table", "typeInfo"));
			array.add(getJsonObject("goodsInfo", "药品详情", "layui-icon-table", "goodsInfo"));
			array.add(getJsonObject("orderInfo", "订单信息", "layui-icon-table", "orderInfo"));
			array.add(getJsonObject("commentInfo", "评价信息", "layui-icon-table", "commentInfo"));
			array.add(getJsonObject("accountBusinessInfo", "个人信息", "layui-icon-user", "accountBusinessInfo"));
			tableObj.putOpt("list", array);
		}

		if (3 == level) {
			JSONArray array = new JSONArray();
			array.add(getJsonObject("messageInfo", "在线交流信息", "layui-icon-table", "messageInfo"));
			array.add(getJsonObject("advertiserInfo", "新闻信息", "layui-icon-table", "advertiserInfo"));
			array.add(getJsonObject("typeInfo", "药品类型", "layui-icon-table", "typeInfo"));
			array.add(getJsonObject("goodsInfo", "药品详情", "layui-icon-table", "goodsInfo"));
			array.add(getJsonObject("orderInfo", "订单信息", "layui-icon-table", "orderInfo"));
			array.add(getJsonObject("commentInfo", "评价信息", "layui-icon-table", "commentInfo"));
			array.add(getJsonObject("accountUserInfo", "个人信息", "layui-icon-user", "accountUserInfo"));
			tableObj.putOpt("list", array);
		}


        dataArray.add(tableObj);

        dataArray.add(getJsonObject("updatePassword", "修改密码", "layui-icon-password", "updatePassword"));
        dataArray.add(getJsonObject("login", "退出登录", "layui-icon-logout", "login"));

        obj.putOpt("data", dataArray);
        return obj.toString();
    }

    private JSONObject getJsonObject(String name, String title, String icon, String jump) {
        JSONObject object = new JSONObject();
        object.putOpt("name", name);
        object.putOpt("title", title);
        object.putOpt("icon", icon);
        object.putOpt("jump", jump);
        return object;
    }

    @GetMapping(value = "/getTotal", produces="application/json;charset=UTF-8")
    public Result<Map<String, Integer>> getTotle() {
        Map<String, Integer> resultMap = new HashMap<>();
		resultMap.put("adminInfo", adminInfoService.findAll().size());
		resultMap.put("businessInfo", businessInfoService.findAll().size());
		resultMap.put("userInfo", userInfoService.findAll().size());
		resultMap.put("advertiserInfo", advertiserInfoService.findAll().size());

        return Result.success(resultMap);
    }
}


获取源码或论文

如嘘对应的源码,可以私wo。

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值