小程序二手商城|使用Springboot+vue+微信小程序开发校园二手商城系统

本文主要是介绍小程序二手商城|使用Springboot+vue+微信小程序开发校园二手商城系统,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

作者主页:编程指南针

作者简介:Java领域优质创作者、CSDN博客专家 、CSDN内容合伙人、掘金特邀作者、阿里云博客专家、51CTO特邀作者、多年架构师设计经验、腾讯课堂常驻讲师

主要内容:Java项目、Python项目、前端项目、人工智能与大数据、简历模板、学习资料、面试题库、技术互助

收藏点赞不迷路  关注作者有好处

文末获取源码 

  

 项目编号:BS-XCX-024

一,环境介绍

语言环境:Java:  jdk1.8 

数据库:Mysql: mysql5.7

应用服务器:Tomcat:  tomcat8.5.31

开发工具:IDEA或eclipse+微信开发者工具

开发技术:Springboot+vue+微信小程序

二,项目简介

本项目基于Springboot+vue+微信小程序实现了一个校园二手物品商城交易系统。系统的后台使用springboot+mybatis开发实现,后台管理页面使用Vue+ElementUI开发实现,用户端基于微信小程序开发实现。前端用户使用微信登录小程序后,可以在线浏览二手商品,并在线购买下单和评论等,同时自己也可以发布相应的二手商品,并管理自己的订单信息和销售信息。管理员登录后台管理系统可以管理人员、商品分类、商品、订单等相关信息。具体见下面展示。

三,系统展示

前端小程序

在商品详情里可以和发布人在线发消息交流,在线评论,在线下单交易

商品分类查询

发布二手商品

在线信息交流

个人中心:可以管理自己发布的商品,查看自己的收藏记录,查看自己的订单,查看己销售的订单,查看评论和消息回复等。

后台管理

分类管理

商品管理

其它略

四,核心代码展示

package com.spboot.tx.controller;import cn.hutool.core.bean.BeanUtil;
import cn.hutool.core.util.StrUtil;
import com.spboot.tx.mapper.*;
import com.spboot.tx.pojo.*;
import com.spboot.tx.service.*;
import com.spboot.tx.utils.*;
import io.swagger.annotations.*;
import java.io.*;
import java.util.*;
import javax.annotation.Resource;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.*;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.authentication.AuthenticationManager;
import org.springframework.security.authentication.UsernamePasswordAuthenticationToken;
import org.springframework.security.core.Authentication;
import org.springframework.web.bind.annotation.*;@Api(tags = { "管理员控制器" })
@RestController
@RequestMapping("/api/admins")
public class AdminsController {@Autowiredpublic AdminsService adminsService;@Autowiredpublic AdminsMapper adminsMapper;@Resourceprivate HttpServletRequest request;@Resourceprivate HttpServletResponse response;@ApiOperation(value = "获取全部管理员", httpMethod = "GET")@RequestMapping("/selectAll")public ResponseData<List<Admins>> selectAll() {return adminsService.selectAll();}@ApiOperation(value = "根据条件筛选获取管理员列表,并分页", httpMethod = "POST")@RequestMapping("/selectPages")public ResponseData selectPages(@RequestBody Map<String, Object> req) {return adminsService.selectPages(req);}@ApiOperation(value = "根据过滤信息获取相关数据", httpMethod = "POST")@RequestMapping("/filter")public ResponseData<List<Admins>> filter(@RequestBody Map<String, Object> req) {return adminsService.filter(req);}@Autowiredprivate AuthenticationManager authenticationManager;@ApiOperation(value = "修改密码", httpMethod = "POST")@PostMapping("/editPassword")public ResponseData<Object> editPassword(@RequestParam(required = false) String oldPassword,@RequestParam(required = false) String newPwd,@RequestParam(required = false) String newPwd2) {Authentication authentication = null;SessionUser user = Request.user();if (!user.getCx().equals("小程序")) {if (StrUtil.hasBlank(oldPassword) || StrUtil.hasBlank(newPwd) || StrUtil.hasBlank(newPwd2)) {return JsonResult.error("请输入密码");}if (!newPwd.equals(newPwd2)) {return JsonResult.error("确认密码不正确,请重试");}try {//会自动调用loadUserByUsername方法,若查到用户,且用户名密码正确,则验证通过。// 关于密码的解密,配置在WebSecurityConfig类中(与注册时的加密策略保持相同)String pwd = oldPassword;authentication = authenticationManager.authenticate(new UsernamePasswordAuthenticationToken(user.getUsername(), pwd));} catch (Exception e) {e.printStackTrace();//当loadUserByUsername方法找不到用户时,会进入此异常//若查到用户,且用户名密码不匹配,会进入此异常return JsonResult.error("原密码错误");}Admins admins = adminsMapper.selectById(user.getId());admins.setPwd(newPwd);return adminsService.update(admins, new HashMap());}return JsonResult.error("此用户不支持修改密码");}@ApiOperation(value = "根据id获取信息", httpMethod = "GET")@RequestMapping("/findById")@ApiImplicitParam(name = "id", value = "管理员对应的id", dataType = "Integer")public ResponseData findById(@RequestParam Integer id) {return adminsService.findById(id);}@ApiOperation(value = "根据id更新数据", httpMethod = "POST")@RequestMapping("/update")@ApiImplicitParam(name = "data", value = "使用json数据提交", type = "json", dataTypeClass = Admins.class, paramType = "body")public ResponseData update(@RequestBody Map data) {Admins post = BeanUtil.mapToBean(data, Admins.class, true);return adminsService.update(post, data);}@ApiOperation(value = "插入一行数据,返回插入后的管理员", httpMethod = "POST")@RequestMapping("/insert")@ApiImplicitParam(name = "data", value = "使用json数据提交", type = "json", dataTypeClass = Admins.class, paramType = "body")public ResponseData insert(@RequestBody Map data) {Admins post = BeanUtil.mapToBean(data, Admins.class, true);return adminsService.insert(post, data);}@ApiOperation(value = "根据id列表删除数据", httpMethod = "POST")@RequestMapping("/delete")@ApiImplicitParam(name = "id", value = "管理员对应的id", type = "json", dataTypeClass = List.class)public ResponseData delete(@RequestBody List<Integer> id) {return adminsService.delete(id);}
}
package com.spboot.tx.controller;import cn.hutool.core.bean.BeanUtil;
import com.spboot.tx.mapper.*;
import com.spboot.tx.pojo.*;
import com.spboot.tx.service.*;
import com.spboot.tx.utils.*;
import io.swagger.annotations.*;
import java.io.*;
import java.util.*;
import javax.annotation.Resource;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.*;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;@Api(tags = { "地区控制器" })
@RestController
@RequestMapping("/api/diqu")
public class DiquController {@Autowiredpublic DiquService diquService;@Resourceprivate HttpServletRequest request;@Resourceprivate HttpServletResponse response;@ApiOperation(value = "获取全部地区", httpMethod = "GET")@RequestMapping("/selectAll")public ResponseData<List<Diqu>> selectAll() {return diquService.selectAll();}@ApiOperation(value = "根据条件筛选获取地区列表,并分页", httpMethod = "POST")@RequestMapping("/selectPages")public ResponseData selectPages(@RequestBody Map<String, Object> req) {return diquService.selectPages(req);}@ApiOperation(value = "根据过滤信息获取相关数据", httpMethod = "POST")@RequestMapping("/filter")public ResponseData<List<Diqu>> filter(@RequestBody Map<String, Object> req) {return diquService.filter(req);}@ApiOperation(value = "根据id获取信息", httpMethod = "GET")@RequestMapping("/findById")@ApiImplicitParam(name = "id", value = "地区对应的id", dataType = "Integer")public ResponseData findById(@RequestParam Integer id) {return diquService.findById(id);}@ApiOperation(value = "根据id更新数据", httpMethod = "POST")@RequestMapping("/update")@ApiImplicitParam(name = "data", value = "使用json数据提交", type = "json", dataTypeClass = Diqu.class, paramType = "body")public ResponseData update(@RequestBody Map data) {Diqu post = BeanUtil.mapToBean(data, Diqu.class, true);return diquService.update(post, data);}@ApiOperation(value = "插入一行数据,返回插入后的地区", httpMethod = "POST")@RequestMapping("/insert")@ApiImplicitParam(name = "data", value = "使用json数据提交", type = "json", dataTypeClass = Diqu.class, paramType = "body")public ResponseData insert(@RequestBody Map data) {Diqu post = BeanUtil.mapToBean(data, Diqu.class, true);return diquService.insert(post, data);}@ApiOperation(value = "根据id列表删除数据", httpMethod = "POST")@RequestMapping("/delete")@ApiImplicitParam(name = "id", value = "地区对应的id", type = "json", dataTypeClass = List.class)public ResponseData delete(@RequestBody List<Integer> id) {return diquService.delete(id);}
}

五,相关作品展示

基于Java开发、Python开发、PHP开发、C#开发等相关语言开发的实战项目

基于Nodejs、Vue等前端技术开发的前端实战项目

基于微信小程序和安卓APP应用开发的相关作品

基于51单片机等嵌入式物联网开发应用

基于各类算法实现的AI智能应用

基于大数据实现的各类数据管理和推荐系统

 

 

这篇关于小程序二手商城|使用Springboot+vue+微信小程序开发校园二手商城系统的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/819054

相关文章

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

Mysql虚拟列的使用场景

《Mysql虚拟列的使用场景》MySQL虚拟列是一种在查询时动态生成的特殊列,它不占用存储空间,可以提高查询效率和数据处理便利性,本文给大家介绍Mysql虚拟列的相关知识,感兴趣的朋友一起看看吧... 目录1. 介绍mysql虚拟列1.1 定义和作用1.2 虚拟列与普通列的区别2. MySQL虚拟列的类型2

详解Java如何向http/https接口发出请求

《详解Java如何向http/https接口发出请求》这篇文章主要为大家详细介绍了Java如何实现向http/https接口发出请求,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 用Java发送web请求所用到的包都在java.net下,在具体使用时可以用如下代码,你可以把它封装成一

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

在C#中获取端口号与系统信息的高效实践

《在C#中获取端口号与系统信息的高效实践》在现代软件开发中,尤其是系统管理、运维、监控和性能优化等场景中,了解计算机硬件和网络的状态至关重要,C#作为一种广泛应用的编程语言,提供了丰富的API来帮助开... 目录引言1. 获取端口号信息1.1 获取活动的 TCP 和 UDP 连接说明:应用场景:2. 获取硬

关于@MapperScan和@ComponentScan的使用问题

《关于@MapperScan和@ComponentScan的使用问题》文章介绍了在使用`@MapperScan`和`@ComponentScan`时可能会遇到的包扫描冲突问题,并提供了解决方法,同时,... 目录@MapperScan和@ComponentScan的使用问题报错如下原因解决办法课外拓展总结@

mysql数据库分区的使用

《mysql数据库分区的使用》MySQL分区技术通过将大表分割成多个较小片段,提高查询性能、管理效率和数据存储效率,本文就来介绍一下mysql数据库分区的使用,感兴趣的可以了解一下... 目录【一】分区的基本概念【1】物理存储与逻辑分割【2】查询性能提升【3】数据管理与维护【4】扩展性与并行处理【二】分区的

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,