基于javaweb的进销存管理系统(前后端分离+java+vue+springboot+ssm+mysql+redis)

运行环境

Java≥8、MySQL≥5.7、Node.js≥10

开发工具

后端:eclipse/idea/myeclipse/sts等均可配置运行

前端:WebStorm/VSCode/HBuilderX等均可

适用

课程设计,大作业,毕业设计,项目练习,学习演示等

功能说明

基于javaweb+mysql的进销存管理系统(前后端分离+java+vue+Springboot+ssm+mysql+maven+redis)

一、项目简述

本系统功能包括: 库存管理,入库管理,出库管理,往来管理,基础资料, 系统管理,消息中心,系统监控等等。

二、项目运行

环境配置: Jdk1.8 + Tomcat8.5 + Mysql + HBuilderX ( Webstorm也 行)+ Eclispe ( IntelliJ IDEA ,Eclispe,MyEclispe , Sts都支持)。

项目技术: Springboot + Maven + Mybatis-plus+ Vue + Redis + Shiro + Druid + logback 组成,B/S模萤;,其他:fastjson, poi, Swagger-ui, quartz, lombok (简化代码)等

接口返回数据格式:

/**

  • 接口返回数据格式

  • @author scott

*/

@Data

@ApiModel(value=“接口返回对象”, descriiption=“接口返回对象”)

public class Result implements Serializable {

private static final long serialVersionUID = 1L;

/**

  • 成功标志

*/

@ApiModelProperty(value = “成功标志”)

private boolean success = true;

/**

  • 返回处理消息

*/

@ApiModelProperty(value = “返回处理消息”)

private String message = “操作成功!”;

/**

  • 返回代码

*/

@ApiModelProperty(value = “返回代码”)

private Integer code = 0;

/**

  • 返回数据对象 data

*/

@ApiModelProperty(value = “返回数据对象”)

private T result;

/**

  • 时间戳

*/

@ApiModelProperty(value = “时间戳”)

private long timestamp = System.currentTimeMillis();

public Result() {

public Result success(String message) {

this.message = message;

this.code = CommonConstant.SC_OK_200;

this.success = true;

return this;

public static Result ok() {

Result r = new Result();

r.setSuccess(true);

r.setCode(CommonConstant.SC_OK_200);

r.setMessage(“成功”);

return r;

public static Result ok(String msg) {

Result r = new Result();

r.setSuccess(true);

r.setCode(CommonConstant.SC_OK_200);

r.setMessage(msg);

return r;

public static Result ok(Object data) {

Result r = new Result();

r.setSuccess(true);

r.setCode(CommonConstant.SC_OK_200);

r.setResult(data);

return r;

public static Result error(String msg) {

return error(CommonConstant.SC_INTERNAL_SERVER_ERROR_500, msg);

public static Result error(int code, String msg) {

Result r = new Result();

r.setCode(code);

r.setMessage(msg);

r.setSuccess(false);

return r;

public Result error500(String message) {

this.message = message;

this.code = CommonConstant.SC_INTERNAL_SERVER_ERROR_500;

this.success = false;

return this;

/**

  • 无权限访问返回结果

*/

public static Result noauth(String msg) {

return error(CommonConstant.SC_JEECG_NO_AUTHZ, msg);

用户信息控制器:

/**

  • 用户表 前端控制器

*/

@Slf4j

@RestController

@RequestMapping(“/sys/common”)

public class CommonController {

@Autowired

private ISysBaseAPI sysBaseAPI;

@Value(value = “${jeecg.path.upload}”)

private String uploadpath;

/**

  • 本地:local minio:minio 阿里:alioss

*/

@Value(value=“${jeecg.uploadType}”)

private String uploadType;

/**

  • @Author 政辉

  • @return

*/

@GetMapping(“/403”)

public Result<?> noauth() {

return Result.error(“没有权限,请联系管理员授权”);

/**

  • 文件上传统一方法

  • @param request

  • @param response

  • @return

*/

@PostMapping(value = “/upload”)

public Result<?> upload(HttpServletRequest request, HttpServletResponse response) {

Result<?> result = new Result<>();

String savePath = “”;

String bizPath = request.getParameter(“biz”);

MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;

MultipartFile file = multipartRequest.getFile(“file”);// 获取上传文件对象

if(oConvertUtils.isEmpty(bizPath)){

if(CommonConstant.UPLOAD_TYPE_OSS.equals(uploadType)){

//未指定目录,则用阿里云默认目录 upload

bizPath = “upload”;

//result.setMessage(“使用阿里云文件上传时,必须添加目录!”);

//result.setSuccess(false);

//return result;

}else{

bizPath = “”;

if(CommonConstant.UPLOAD_TYPE_LOCAL.equals(uploadType)){

//针对jeditor编辑器如何使 lcaol模式,采用 base64格式存储

String jeditor = request.getParameter(“jeditor”);

if(oConvertUtils.isNotEmpty(jeditor)){

result.setMessage(CommonConstant.UPLOAD_TYPE_LOCAL);

result.setSuccess(true);

return result;

}else{

savePath = this.uploadLocal(file,bizPath);

}else{

savePath = sysBaseAPI.upload(file,bizPath,uploadType);

if(oConvertUtils.isNotEmpty(savePath)){

result.setMessage(savePath);

result.setSuccess(true);

}else {

result.setMessage(“上传失败!”);

result.setSuccess(false);

return result;

/**

  • 本地文件上传

  • @param mf 文件

  • @param bizPath 自定义路径

  • @return

*/

private String uploadLocal(MultipartFile mf,String bizPath){

try {

String ctxPath = uploadpath;

String fileName = null;

File file = new File(ctxPath + File.separator + bizPath + File.separator );

if (!file.exists()) {

file.mkdirs();// 创建文件根目录

String orgName = mf.getOriginalFilename();// 获取文件名

orgName = CommonUtils.getFileName(orgName);

if(orgName.indexOf(“.”)!=-1){

fileName = orgName.substring(0, orgName.lastIndexOf(“.”)) + “_” + System.currentTimeMillis() + orgName.substring(orgName.indexOf(“.”));

}else{

fileName = orgName+ “_” + System.currentTimeMillis();

String savePath = file.getPath() + File.separator + fileName;

File savefile = new File(savePath);

FileCopyUtils.copy(mf.getBytes(), savefile);

String dbpath = null;

if(oConvertUtils.isNotEmpty(bizPath)){

dbpath = bizPath + File.separator + fileName;

}else{

dbpath = fileName;

if (dbpath.contains(“\”)) {

dbpath = dbpath.replace(“\”, “/”);

return dbpath;

} catch (IOException e) {

log.error(e.getMessage(), e);

return “”;

// @PostMapping(value = “/upload2”)

// public Result<?> upload2(HttpServletRequest request, HttpServletResponse response) {

// Result<?> result = new Result<>();

// try {

// String ctxPath = uploadpath;

// String fileName = null;

// String bizPath = “files”;

// String tempBizPath = request.getParameter(“biz”);

// if(oConvertUtils.isNotEmpty(tempBizPath)){

// bizPath = tempBizPath;

// }

// String nowday = new SimpleDateFormat(“yyyyMMdd”).format(new Date());

// File file = new File(ctxPath + File.separator + bizPath + File.separator + nowday);

// if (!file.exists()) {

// file.mkdirs();// 创建文件根目录

// }

// MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;

// MultipartFile mf = multipartRequest.getFile(“file”);// 获取上传文件对象

// String orgName = mf.getOriginalFilename();// 获取文件名

// fileName = orgName.substring(0, orgName.lastIndexOf(“.”)) + “_” + System.currentTimeMillis() + orgName.substring(orgName.indexOf(“.”));

// String savePath = file.getPath() + File.separator + fileName;

// File savefile = new File(savePath);

// FileCopyUtils.copy(mf.getBytes(), savefile);

// String dbpath = bizPath + File.separator + nowday + File.separator + fileName;

// if (dbpath.contains(“\”)) {

// dbpath = dbpath.replace(“\”, “/”);

// }

// result.setMessage(dbpath);

// result.setSuccess(true);

// } catch (IOException e) {

// result.setSuccess(false);

// result.setMessage(e.getMessage());

// log.error(e.getMessage(), e);

// }

// return result;

// }

/**

  • 预览图片&下载文件

  • 请求地址:http://localhost:8080/common/static/{user/20190119/e1fe9925bc315c60addea1b98eb1cb1349547719_1547866868179.jpg}

  • @param request

  • @param response

*/

@GetMapping(value = “/static/**”)

public void view(HttpServletRequest request, HttpServletResponse response) {

// ISO-8859-1 ==> UTF-8 进行编码转换

String imgPath = extractPathFromPattern(request);

if(oConvertUtils.isEmpty(imgPath) || imgPath==“null”){

return;

// 其余处理略

InputStream inputStream = null;

OutputStream outputStream = null;

try {

imgPath = imgPath.replace(“…”, “”);

if (imgPath.endsWith(“,”)) {

imgPath = imgPath.substring(0, imgPath.length() - 1);

String filePath = uploadpath + File.separator + imgPath;

File file = new File(filePath);

if(!file.exists()){

response.setStatus(404);

throw new RuntimeException(“文件不存在…”);

response.setContentType(“application/force-download”);// 设置强制下载不打开

response.addHeader(“Content-Disposition”, “attachment;fileName=” + new String(file.getName().getBytes(“UTF-8”),“iso-8859-1”));

inputStream = new BufferedInputStream(new FileInputStream(filePath));

outputStream = response.getOutputStream();

byte[] buf = new byte[1024];

int len;

while ((len = inputStream.read(buf)) > 0) {

outputStream.write(buf, 0, len);

response.flushBuffer();

} catch (IOException e) {

log.error(“预览文件失败” + e.getMessage());

response.setStatus(404);

e.printStackTrace();

} finally {

if (inputStream != null) {

try {

inputStream.close();

} catch (IOException e) {

log.error(e.getMessage(), e);

if (outputStream != null) {

try {

outputStream.close();

} catch (IOException e) {

log.error(e.getMessage(), e);

// /**

// * 下载文件

// * 请求地址:http://localhost:8080/common/download/{user/20190119/e1fe9925bc315c60addea1b98eb1cb1349547719_1547866868179.jpg}

// *

// * @param request

// * @param response

// * @throws Exception

// */

// @GetMapping(value = “/download/**”)

// public void download(HttpServletRequest request, HttpServletResponse response) throws Exception {

// // ISO-8859-1 ==> UTF-8 进行编码转换

// String filePath = extractPathFromPattern(request);

// // 其余处理略

// InputStream inputStream = null;

// OutputStream outputStream = null;

// try {

// filePath = filePath.replace(“…”, “”);

// if (filePath.endsWith(“,”)) {

// filePath = filePath.substring(0, filePath.length() - 1);

// }

// String localPath = uploadpath;

// String downloadFilePath = localPath + File.separator + filePath;

// File file = new File(downloadFilePath);

// if (file.exists()) {

// response.setContentType(“application/force-download”);// 设置强制下载不打开

// response.addHeader(“Content-Disposition”, “attachment;fileName=” + new String(file.getName().getBytes(“UTF-8”),“iso-8859-1”));

// inputStream = new BufferedInputStream(new FileInputStream(file));

// outputStream = response.getOutputStream();

// byte[] buf = new byte[1024];

// int len;

// while ((len = inputStream.read(buf)) > 0) {

// outputStream.write(buf, 0, len);

// }

// response.flushBuffer();

// }

//

// } catch (Exception e) {

// log.info(“文件下载失败” + e.getMessage());

// // e.printStackTrace();

// } finally {

// if (inputStream != null) {

// try {

// inputStream.close();

// } catch (IOException e) {

// e.printStackTrace();

// }

// }

// if (outputStream != null) {

// try {

// outputStream.close();

// } catch (IOException e) {

// e.printStackTrace();

// }

// }

// }

//

// }

/**

  • @功能:pdf预览Iframe

  • @param modelAndView

  • @return

*/

@RequestMapping(“/pdf/pdfPreviewIframe”)

public ModelAndView pdfPreviewIframe(ModelAndView modelAndView) {

modelAndView.setViewName(“pdfPreviewIframe”);

return modelAndView;

/**

  • 把指定URL后的字符串全部截断当成参数

  • 这么做是为了防止URL中包含中文或者特殊字符(/等)时,匹配不了的问题

  • @param request

  • @return

*/

private static String extractPathFromPattern(final HttpServletRequest request) {

String path = (String) request.getAttribute(HandlerMapping.PATH_WITHIN_HANDLER_MAPPING_ATTRIBUTE);

String bestMatchPattern = (String) request.getAttribute(HandlerMapping.BEST_MATCHING_PATTERN_ATTRIBUTE);

return new AntPathMatcher().extractPathWithinPattern(bestMatchPattern, path);

/**

  • 中转HTTP请求,解决跨域问题

  • @param url 必填:请求地址

  • @return

*/

@RequestMapping(“/transitRESTful”)

public Result transitRESTful(@RequestParam(“url”) String url, HttpServletRequest request) {

try {

ServletServerHttpRequest httpRequest = new ServletServerHttpRequest(request);

// 中转请求method、body

HttpMethod method = httpRequest.getMethod();

JSONObject params;

try {

params = JSON.parseObject(JSON.toJSONString(httpRequest.getBody()));

} catch (Exception e) {

params = new JSONObject();

// 中转请求问号参数

JSONObject variables = JSON.parseObject(JSON.toJSONString(request.getParameterMap()));

variables.remove(“url”);

// 在 headers 里传递Token

String token = TokenUtils.getTokenByRequest(request);

HttpHeaders headers = new HttpHeaders();

headers.set(“X-Access-Token”, token);

// 发送请求

String httpURL = URLDecoder.decode(url, “UTF-8”);

ResponseEntity response = RestUtil.request(httpURL, method, headers , variables, params, String.class);

// 封装返回结果

Result result = new Result<>();

int statusCode = response.getStatusCodeValue();

result.setCode(statusCode);

result.setSuccess(statusCode == 200);

String responseBody = response.getBody();

try {

// 尝试将返回结果转为JSON

Object json = JSON.parse(responseBody);

result.setResult(json);

} catch (Exception e) {

// 转成JSON失败,直接返回原始数据

result.setResult(responseBody);

return result;

} catch (Exception e) {

log.debug(“中转HTTP请求失败”, e);

return Result.error(e.getMessage());

付款单控制层:

/**

  • @Descriiption: 付款单

*/

@Api(tags=“付款单”)

@RestController

@RequestMapping(“/finance/finPayment”)

@Slf4j

public class FinPaymentController {

@Autowired

private IFinPaymentService finPaymentService;

@Autowired

private IFinPaymentEntryService finPaymentEntryService;

/**

  • 分页列表查询

  • @param finPayment

  • @param pageNo

  • @param pageSize

  • @param req

  • @return

*/

@AutoLog(value = “付款单-分页列表查询”)

@ApiOperation(value=“付款单-分页列表查询”, notes=“付款单-分页列表查询”)

@GetMapping(value = {“/list”, “/list/{paymentType}”}) //paymentType会传至finPayment.paymentType

public Result<?> queryPageList(FinPayment finPayment,

@RequestParam(name=“pageNo”, defaultValue=“1”) Integer pageNo,

@RequestParam(name=“pageSize”, defaultValue=“10”) Integer pageSize,

HttpServletRequest req) {

QueryWrapper queryWrapper = QueryGenerator.initQueryWrapper(finPayment, req.getParameterMap());

Page page = new Page(pageNo, pageSize);

IPage pageList = finPaymentService.page(page, queryWrapper);

return Result.ok(pageList);

@GetMapping(value = “/checkableList”)

public Result<?> queryCheckablePageList(FinPayment finPayment,

@RequestParam(name=“pageNo”, defaultValue=“1”) Integer pageNo,

@RequestParam(name=“pageSize”, defaultValue=“10”) Integer pageSize,

HttpServletRequest req) {

QueryWrapper queryWrapper = QueryGenerator.initQueryWrapper(finPayment, req.getParameterMap());

List list = new ArrayList();

list.add(“23”);

list.add(“31”);

list.add(“32”);

queryWrapper.in(“bill_proc_Status”, list);

queryWrapper.eq(“is_approved”, 1);

queryWrapper.eq(“is_closed”, 0);

queryWrapper.eq(“is_voided”, 0);

queryWrapper.apply(“amt - deducted_amt - checked_amt > 0”);

Page page = new Page(pageNo, pageSize);

IPage pageList = finPaymentService.page(page, queryWrapper);

return Result.ok(pageList);

/**

  • 添加

  • @param finPaymentPage

  • @return

*/

@AutoLog(value = “付款单-添加”)

@ApiOperation(value=“付款单-添加”, notes=“付款单-添加”)

@PostMapping(value = “/add”)

public Result<?> add(@RequestBody FinPaymentPage finPaymentPage) {

FinPayment finPayment = new FinPayment();

BeanUtils.copyProperties(finPaymentPage, finPayment);

finPaymentService.saveMain(finPayment, finPaymentPage.getFinPaymentEntryList());

return Result.ok(“添加成功!”);

/**

  • 编辑

  • @param finPaymentPage

  • @return

*/

@AutoLog(value = “付款单-编辑”)

@ApiOperation(value=“付款单-编辑”, notes=“付款单-编辑”)

@PutMapping(value = “/edit”)

public Result<?> edit(@RequestBody FinPaymentPage finPaymentPage) {

FinPayment finPayment = new FinPayment();

BeanUtils.copyProperties(finPaymentPage, finPayment);

FinPayment finPaymentEntity = finPaymentService.getById(finPayment.getId());

if(finPaymentEntity==null) {

return Result.error(“未找到对应数据”);

finPaymentService.updateMain(finPayment, finPaymentPage.getFinPaymentEntryList());

return Result.ok(“编辑成功!”);

/**

  • 通过id删除

  • @param id

  • @return

*/

@AutoLog(value = “付款单-通过id删除”)

@ApiOperation(value=“付款单-通过id删除”, notes=“付款单-通过id删除”)

@DeleteMapping(value = “/delete”)

public Result<?> delete(@RequestParam(name=“id”,required=true) String id) {

finPaymentService.delMain(id);

return Result.ok(“删除成功!”);

/**

  • 批量删除

  • @param ids

  • @return

*/

@AutoLog(value = “付款单-批量删除”)

@ApiOperation(value=“付款单-批量删除”, notes=“付款单-批量删除”)

@DeleteMapping(value = “/deleteBatch”)

public Result<?> deleteBatch(@RequestParam(name=“ids”,required=true) String ids) {

this.finPaymentService.delBatchMain(Arrays.asList(ids.split(“,”)));

return Result.ok(“批量删除成功!”);

/**

  • 通过id查询

  • @param id

  • @return

*/

@AutoLog(value = “付款单-通过id查询”)

@ApiOperation(value=“付款单-通过id查询”, notes=“付款单-通过id查询”)

@GetMapping(value = “/queryById”)

public Result<?> queryById(@RequestParam(name=“id”,required=true) String id) {

FinPayment finPayment = finPaymentService.getById(id);

if(finPayment==null) {

return Result.error(“未找到对应数据”);

return Result.ok(finPayment);

/**

  • 通过id查询

  • @param id

  • @return

*/

@AutoLog(value = “付款明细集合-通过id查询”)

@ApiOperation(value=“付款明细集合-通过id查询”, notes=“付款明细-通过id查询”)

@GetMapping(value = “/queryFinPaymentEntryByMainId”)

public Result<?> queryFinPaymentEntryListByMainId(@RequestParam(name=“id”,required=true) String id) {

List finPaymentEntryList = finPaymentEntryService.selectByMainId(id);

return Result.ok(finPaymentEntryList);

/**

  • 导出excel

  • @param request

  • @param finPayment

*/

@RequestMapping(value = {“/exportXls”, “/exportXls/{paymentType}”})

public ModelAndView exportXls(HttpServletRequest request, FinPayment finPayment) {

// Step.1 组装查询条件查询数据

QueryWrapper queryWrapper = QueryGenerator.initQueryWrapper(finPayment, request.getParameterMap());

LoginUser sysUser = (LoginUser) SecurityUtils.getSubject().getPrincipal();

//Step.2 获取导出数据

List queryList = finPaymentService.list(queryWrapper);

// 过滤选中数据

String selections = request.getParameter(“selections”);

List finPaymentList = new ArrayList();

if(oConvertUtils.isEmpty(selections)) {

finPaymentList = queryList;

}else {

List selectionList = Arrays.asList(selections.split(“,”));

finPaymentList = queryList.stream().filter(item -> selectionList.contains(item.getId())).collect(Collectors.toList());

// Step.3 组装pageList

List pageList = new ArrayList();

for (FinPayment main : finPaymentList) {

FinPaymentPage vo = new FinPaymentPage();

BeanUtils.copyProperties(main, vo);

List finPaymentEntryList = finPaymentEntryService.selectByMainId(main.getId());

vo.setFinPaymentEntryList(finPaymentEntryList);

pageList.add(vo);

// Step.4 AutoPoi 导出Excel

ModelAndView mv = new ModelAndView(new JeecgEntityExcelView());

mv.addObject(NormalExcelConstants.FILE_NAME, “付款单列表”);

mv.addObject(NormalExcelConstants.CLASS, FinPaymentPage.class);

mv.addObject(NormalExcelConstants.PARAMS, new ExportParams(“付款单数据”, “导出人:”+sysUser.getRealname(), “付款单”));

mv.addObject(NormalExcelConstants.DATA_LIST, pageList);

return mv;

/**

  • 通过excel导入数据

  • @param request

  • @param response

  • @return

*/

@RequestMapping(value = “/importExcel”, method = RequestMethod.POST)

public Result<?> importExcel(HttpServletRequest request, HttpServletResponse response) {

MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;

Map<String, MultipartFile> fileMap = multipartRequest.getFileMap();

for (Map.Entry<String, MultipartFile> entity : fileMap.entrySet()) {

MultipartFile file = entity.getValue();// 获取上传文件对象

ImportParams params = new ImportParams();

params.setTitleRows(2);

params.setHeadRows(1);

params.setNeedSave(true);

try {

List list = ExcelImportUtil.importExcel(file.getInputStream(), FinPaymentPage.class, params);

for (FinPaymentPage page : list) {

FinPayment po = new FinPayment();

BeanUtils.copyProperties(page, po);

finPaymentService.saveMain(po, page.getFinPaymentEntryList());

return Result.ok(“文件导入成功!数据行数:” + list.size());

} catch (Exception e) {

log.error(e.getMessage(),e);

return Result.error(“文件导入失败:”+e.getMessage());

} finally {

try {

file.getInputStream().close();

} catch (IOException e) {

e.printStackTrace();

return Result.ok(“文件导入失败!”);

@AutoLog(value = “付款单-通过id审核”)

@ApiOperation(value=“付款单-通过id审核”, notes=“付款单-通过id审核”)

@PutMapping(value = “/approve”)

public Result<?> approve(@RequestBody JSONObject json) {

finPaymentService.approve(json.getString(“id”));

return Result.ok(“审核通过!”);


基于javaweb的进销存管理系统(前后端分离+java+vue+springboot+ssm+mysql+redis)相关推荐

  1. Java项目:进销存管理系统(前后端分离+java+vue+Springboot+ssm+mysql+maven+redis)

    源码获取:博客首页 "资源" 里下载! 一.项目简述 本系统功能包括: 库存管理,入库管理,出库管理,往来管理,基础资料, 系统管理,消息中心,系统监控等等. 二.项目运行 环境配 ...

  2. 基于javaweb的在线小说阅读系统(前后端分离+java+vue+springboot+ssm+mysql+redis)

    基于javaweb的在线小说阅读系统(前后端分离+java+vue+springboot+ssm+mysql+redis) 运行环境 Java≥8.MySQL≥5.7.Node.js≥10 开发工具 ...

  3. Java项目:成绩管理系统(前后端分离+java+vue+Springboot+ssm+mysql+maven+redis)

    源码获取:博客首页 "资源" 里下载! 一.项目简述 本系统功能包括: 超豪华成绩管理系统,学生,教师,管理员三类用户集 成,课程表管理,成绩查询,成绩详情数据统计,课程录 入,用 ...

  4. Java项目:员工管理系统(前后端分离+java+vue+Springboot+ssm+mysql+maven+redis)

    源码获取:博客首页 "资源" 里下载! 一.项目简述 本系统功能包括:分为前端翻后端部分,包括用户,区分晋通用户以及誉里员用户,包括首页展示,部门管理,人事管理,员工管理三个模块等 ...

  5. Java项目:网上电商项目(前后端分离+java+vue+Springboot+ssm+mysql+maven+redis)

    源码获取:博客首页 "资源" 里下载! 一.项目简述 本系统功能包括: 一款基于Springboot+Vue的电商项目,前后端分离项目,前台后台都有,前台商品展示购买,购物车分类, ...

  6. Java项目:仿小米商城系统(前后端分离+java+vue+Springboot+ssm+mysql+maven+redis)

    源码获取:博客首页 "资源" 里下载! 一.项目简述 本系统功能包括: 基于vue + Springboot前后端分离项目精简版仿小米商城 系统,注册登录,首页展示,商品展示,商品 ...

  7. Java项目:朴素风个人博客系统(前后端分离+java+vue+Springboot+ssm+mysql+maven+redis)

    源码获取:博客首页 "资源" 里下载! 一.项目简述 本系统功能包括: 基于vue + Springboo痼J后端分离项目个人博客系统,注册 登录,首页展示,喜爰图书展示,后台图书 ...

  8. Java项目:精美网上音乐平台(前后端分离+java+vue+Springboot+ssm+mysql+maven+redis)

    源码获取:博客首页 "资源" 里下载! 一.项目简述 本系统功能包括: 音乐播放 用户登录注册 用户信息编辑.头像修改 歌曲.歌单搜索 歌单打分 歌单.歌曲评论 歌单列表.歌手列表 ...

  9. Java项目:个人博客系统(前后端分离+java+vue+Springboot+ssm+mysql+maven+redis)

    源码获取:博客首页 "资源" 里下载! 一.项目简述 本系统功能包括:文章展示.热门文章.文章分类.标签云用户登录评论.匿名评论用户留言.匿名留言评论管理.文章发布.文章管理文章数 ...

最新文章

  1. swift 用协议实现代理传值功能
  2. Task Runner Explorer for vs2015找不到啊
  3. NLP基础 : HMM 隐马尔可夫模型
  4. 云海技术u盘怎么恢复成普通盘_BITLOCKER加密中断数据无法读取恢复一例
  5. python django+bootstrap4+mysql智慧交通系统构建
  6. Yarn无法查看日志: Aggregation may not be complete, Check back later or try the nodemanager at xxxx:xxxx
  7. 隐马尔可夫模型HMM(一)
  8. 智能算法之免疫算法求解TSP问题
  9. 遥感数字图像处理学习 一、概念及组成
  10. iOS可持续化集成: Jenkins + bundler + cocoapods + shenzhen + fastlane + pgyer
  11. 计算机无法识别建行网盾,建行网银盾无法识别 如何解决这种问题?
  12. 珍藏,最全面+最完善的Excel条件格式使用手册
  13. 辐射定标、辐射校正、大气校正、正射校正等相关概念
  14. 怎么查python题答案_知到智慧树_Python程序设计基础_答案免费查询
  15. 【decode()】
  16. 【文献学习】热电偶信号调理、IOT接入
  17. GooglePlay应用上架完整流程
  18. 库卡工业机器人负载曲线图_KUKA/库卡工业机器人 KR12 R1810 负载120kg 臂展1813mm
  19. 第 1 章 SQL 索引剖析
  20. matlab 极坐标 二维,matlab笔记二维绘图(极坐标隐函数等)008.docx

热门文章

  1. 修改 Tomcat 默认首页
  2. 学习canvas(一):用线画出正方形和三角形
  3. asp.net 的 web form 过时了吗?
  4. C# WebForm %%用法
  5. 云队友丨王兴:九败一胜,百炼成钢
  6. JavaScript 《公司开发功能》 99+ 大合集
  7. 寄生感知共质心 FinFET 布局和布线以实现电流比匹配
  8. alpha冲刺(事后诸葛亮)
  9. 阿里云服务器+MobaXtern+Anaconda
  10. 自动拍照扫描识别身份证信息SDK