目录

微信小程序的校园二手物品交易平台系统-uniapp-小程序

目录

微信小程序的校园二手物品交易平台系统 uniapp 小程序

在大学校园里,存在着很多的二手商品,但是由于信息资源的不流通以及传统二手商品信息交流方式的笨拙,导致了很多仍然具有一定价值或者具有非常价值的二手商品的囤积,乃至被当作废弃物处理。现在通过微信小程序的校园二手交易平台,可以方便快捷的发布和交流任何二手商品的信息,并且可以通过留言方式进行深一步的交流。可以将一些同学们平时不用的东西变废为宝,而且在整个交易的过程中可以发动同学们的商业思维,如何将自己的物品卖到好的价格。同时卖东西的同学也得到了一定的经济收入,买东西的同学也可以买到物美价廉的东西。

https://i-blog.csdnimg.cn/blog_migrate/a1406c110e23bb5121305aa3c28478f2.png

功能介绍

校园二手交易平台是基于微信的一个小程序。这个小程序分为前端的设计,后端代码的实现以及数据库的连接三个方面。登入分为管理员登入和用户登入,不同的登入入口有着相对应的功能,然后进行对应的操作。

https://i-blog.csdnimg.cn/blog_migrate/60b3f51dad5fdd06c63fbd27a0c12a26.png

设计一个同学们能自由发布和浏览求购或卖出商品信息的校园二手交易小程序,解决信息的不流通以及传统二手商品信息交流方式的笨拙等问题。

环境需要

1.运行环境:微信开发者工具,最好是java jdk 1.8,这是目前最稳定的JDK也是被使用最多的JDK版本。

2.IDE环境:IDEA,Eclipse都可以。推荐IDEA;

3.tomcat环境:Tomcat7/Tomcat8/Tomcat9版本均可

4.硬件环境:windows 7/8/10 1G内存以上;或者 Mac OS;

5.数据库:MySql 5.7版本或以上版本;

6.是否Maven项目:是;

技术栈

后端:Spring+SpringMVC+Mybatis+Springboot

小程序端:uni-app+微信开发者工具混合开发模式

https://i-blog.csdnimg.cn/blog_migrate/87da8a62f04db0ee95a987581872673f.png

功能设计:

(1)前端功能设计

用户管理:用户可以通过微信号,手机号进行注册,设置密码。

商品管理:用户上架商品,买家通过商品的名称,价格,标签来查询浏览商品,商品被买家购入之后,商品下架。

交易管理:买家确认购买之后,进入交易页面自动生成订单。买家付款后,该商品不会被其他用户查询到。等到交易双方确定收到商品,商品下架。买家,卖家,管理员都可以查询到商品的物流信息,可以时实追踪交易的状态。

留言管理:每个商品的界面都有留言区域,方便买家卖家沟通。

(2) 后端管理功能设计

注册管理:管理注册的用户,防止恶意注册。

分类管理:管理员将分类不清楚的商品重新分类,放入合适的位置。

(3) 数据库的设计

小程序采用Mysql数据库,对数据库进行备份。数据库中的主要数据有用户数据表,商品数据表,订单数据表,物流数据表,商品分类数据表,评价数据表。

https://i-blog.csdnimg.cn/blog_migrate/689d67560d8683a2b873c6ed09cd3dad.png

学习的毕设项目选的是微信校园二手交易小程序,微信小程序也算是近年比较新的互联网平台了。所以学校也紧跟潮流选取小程序作为毕业设计。本人java专业,那么微信校园二手交易小程序平台自然就选java啦,所以本微信校园二手交易小程序平台毕业设计的技术框架就是Java+SpringBoot+小程序了。该毕业设计花了两个月写成,中间包括修复BUG、优化、测试等环境。学到很多的东西。收益良多!

https://i-blog.csdnimg.cn/blog_migrate/816a894c7f06407a31b78182be1864a5.png


/**
 * 登录相关
 */
@RequestMapping("users")
@RestController
public class UserController{
	
	@Autowired
	private UserService userService;
	
	@Autowired
	private TokenService tokenService;

    /**
     * 登录
     */
    @IgnoreAuth
    @PostMapping(value = "/login")
    public R login(String username, String password, String captcha, HttpServletRequest request) {
    	UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));
    	if(user==null || !user.getPassword().equals(password)) {
    		return R.error("账号或密码不正确");
    	}
    	String token = tokenService.generateToken(user.getId(),username, "users", user.getRole());
    	return R.ok().put("token", token);
    }

    /**
     * 注册
     */
    @IgnoreAuth
    @PostMapping(value = "/register")
    public R register(@RequestBody UserEntity user){

// ValidatorUtils.validateEntity(user);
if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !=null) {
return R.error("用户已存在");
}
userService.insert(user);
return R.ok();
}

    /**
     * 退出
     */
    @GetMapping(value = "logout")
    public R logout(HttpServletRequest request) {
    	request.getSession().invalidate();
    	return R.ok("退出成功");
    }

    /**
     * 密码重置
     */
    @IgnoreAuth
    @RequestMapping(value = "/resetPass")
    public R resetPass(String username, HttpServletRequest request){
    	UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));
    	if(user==null) {
    		return R.error("账号不存在");
    	}
    	user.setPassword("123456");
        userService.update(user,null);
        return R.ok("密码已重置为:123456");
    }

    /**
     * 列表
     */
    @RequestMapping("/page")
    public R page(@RequestParam Map<String, Object> params,UserEntity user){
        EntityWrapper<UserEntity> ew = new EntityWrapper<UserEntity>();
    	PageUtils page = userService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.allLike(ew, user), params), params));
        return R.ok().put("data", page);
    }

    /**
     * 列表
     */
    @RequestMapping("/list")
    public R list( UserEntity user){
       	EntityWrapper<UserEntity> ew = new EntityWrapper<UserEntity>();
      	ew.allEq(MPUtil.allEQMapPre( user, "user"));
        return R.ok().put("data", userService.selectListView(ew));
    }

    /**
     * 信息
     */
    @RequestMapping("/info/{id}")
    public R info(@PathVariable("id") String id){
        UserEntity user = userService.selectById(id);
        return R.ok().put("data", user);
    }

    /**
     * 获取用户的session用户信息
     */
    @RequestMapping("/session")
    public R getCurrUser(HttpServletRequest request){
    	Long id = (Long)request.getSession().getAttribute("userId");
        UserEntity user = userService.selectById(id);
        return R.ok().put("data", user);
    }

    /**
     * 保存
     */
    @PostMapping("/save")
    public R save(@RequestBody UserEntity user){

// ValidatorUtils.validateEntity(user);
if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !=null) {
return R.error("用户已存在");
}
userService.insert(user);
return R.ok();
}

    /**
     * 修改
     */
    @RequestMapping("/update")
    public R update(@RequestBody UserEntity user){

// ValidatorUtils.validateEntity(user);
userService.updateById(user);//全部更新
return R.ok();
}

    /**
     * 删除
     */
    @RequestMapping("/delete")
    public R delete(@RequestBody Long[] ids){
        userService.deleteBatchIds(Arrays.asList(ids));
        return R.ok();
    }

}

目录

1 绪论 1

1.1 课题背景 1

1.2 课题研究现状 1

1.3 初步设计方法与实施方案 2

1.4 本文研究内容 2

2 系统开发环境 4

2.1 使用工具简介 4

2.2 环境配置 4

2.3 B/S 结构简介 4

2.4 MySQL 数据库 5

2.5 框架介绍 5

3 系统分析 6

3.1 系统可行性分析 6

3.1.1 经济可行性 6

3.1.2 技术可行性 6

3.1.3 运行可行性 6

3.2 系统现状分析 6

3.3 功能需求分析 7

3.4 系统设计规则与运行环境 8

3.5 系统流程分析 8

3.5.1 操作流程 8

3.5.2 添加信息流程 9

3.5.3 删除信息流程 10

4 系统设计 11

4.1 系统设计主要功能 11

4.2 数据库设计 11

4.2.1 数据库设计规范 11

4.2.2 E/R 图 11

4.2.3 数据表 12

5 系统实现 25

5.1 系统功能模块 25

5.2 后台模块 27

5.2.1 管理员功能模块 27

5.2.2 用户功能模块 30

6 系统测试 33

6.1 功能测试 33

6.2 可用性测试 33

6.3 性能测试 34

6.4 测试结果分析 34

7 结 论 35

参考文献 36

致 谢 37