基于java+springboot+vue的农商对接系统

项目介绍

如今社会上各行各业,都喜欢用自己行业的专属软件工作,互联网发展到这个时候,人们已经发现离不开了互联网。新技术的产生,往往能解决一些老技术的弊端问题。因为传统商品销售信息管理难度大,容错率低,管理人员处理数据费工费时,所以专门为解决这个难题开发了一个农商对接系统,可以解决许多问题。

农商对接系统可以实现商品信息管理,订单信息管理,订单追踪管理,售后信息管理,售后处理管理,在线交流管理,在线回复管理等功能。该系统采用了Mysql数据库,Java语言,Spring Boot框架等技术进行编程实现。

农商对接系统可以提高商品销售信息管理问题的解决效率,优化商品销售信息处理流程,保证商品销售信息数据的安全,它是一个非常可靠,非常安全的应用程序。

4.2 功能结构设计
图4.1即为设计的管理员功能结构,管理员权限操作的功能包括管理卖家,管理用户,管理订单和订单追踪信息,管理售后信息,管理售后处理信息,管理用户与卖家的交流信息等。
在这里插入图片描述
图4.2即为设计的卖家功能结构,卖家权限操作的功能包括对订单商品进行交货,处理订单商品的售后信息,管理商品,回复用户咨询商品的交流信息等。
在这里插入图片描述
图4.3即为设计的用户功能结构,用户权限操作的功能包括预定商品,咨询商品,支付订单商品,对订单商品申请售后,查看售后处理信息等。
在这里插入图片描述

开发环境

编程语言:Java
数据库 :Mysql
系统架构:B/S
后端框架:SpringBoot
编译工具:idea或者eclipse,jdk1.8,maven
支持定做:java/php/python/android/小程序vue/爬虫/c#/asp.net

系统实现

5.1 管理员功能实现
5.1.1 卖家管理
图5.1 即为编码实现的卖家管理界面,卖家信息有电话,卖家姓名,账号,性别等信息,管理员查询卖家,更改卖家信息,新增卖家,删除卖家等。
在这里插入图片描述

图5.1 卖家管理界面

5.1.2 用户管理
图5.2 即为编码实现的用户管理界面,用户的头像,邮箱,姓名,手机等信息也能让管理员更改和登记新用户信息,查询用户,删除用户等。
在这里插入图片描述

图5.2 用户管理界面

5.1.3 售后信息管理
图5.3 即为编码实现的售后信息管理界面,管理员查看售后信息,包括售后信息的状态,用户姓名,卖家姓名,商品等信息都能够查看,管理员也能更改,删除,查询售后信息。
在这里插入图片描述

图5.3 售后信息管理界面

5.2 卖家功能实现
5.2.1 商品信息管理
图5.4 即为编码实现的商品信息管理界面,卖家对商品价格,卖家姓名,电话,商品图片等信息进行修改,可以查询商品,新增商品等。
在这里插入图片描述

图5.4 商品信息管理界面

5.2.2 订单信息管理
图5.5 即为编码实现的订单信息管理界面,卖家根据订单约定的交货时间进行交货,可以查看订单明细信息,主要是交货时间,总价格,下单时间,商品名称,用户姓名,手机等信息,卖家可以查询订单。
在这里插入图片描述

图5.5 订单信息管理界面

5.2.3 订单追踪管理
图5.6 即为编码实现的订单追踪管理界面,卖家查看用户姓名,商品名称,交接时间,卖家姓名等信息,可以更改订单追踪信息,查询订单追踪信息等。
在这里插入图片描述

图5.6 订单追踪管理界面

5.2.4 在线交流管理
图5.7 即为编码实现的在线交流管理界面,卖家对用户咨询商品的信息进行查看和回复,可以删除用户与卖家的交流信息。
在这里插入图片描述

图5.7 在线交流管理界面

5.3 用户功能实现
5.3.1 商品信息
图5.8 即为编码实现的商品信息界面,用户在前台的商品信息界面对展示的商品信息进行查看后,可以收藏商品,预定商品,如果用户想了解更多关于商品的信息,可以点击交流按钮向卖家咨询,同时可以在商品信息界面下方的评论区域发布对商品的评论等。
在这里插入图片描述

图5.8 商品信息界面

5.3.2 资讯信息
图5.9 即为编码实现的资讯信息界面,用户查询资讯信息,需要在查询框中编辑资讯标题才可以查询资讯,可以查看资讯信息界面展示的各种资讯信息。
在这里插入图片描述

图5.9 资讯信息界面

5.3.3 订单信息管理
图5.10 即为编码实现的订单信息管理界面,用户预定商品,需要在订单信息管理界面支付。
在这里插入图片描述

图5.10 订单信息管理界面

5.3.4 订单追踪管理
图5.11 即为编码实现的订单追踪管理界面,卖家交货之后,用户发现订单商品存在问题,可以申请对订单商品进行售后。
在这里插入图片描述

图5.11 订单追踪管理界面

核心代码

package com.controller;

import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Calendar;
import java.util.Map;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Date;
import java.util.List;
import javax.servlet.http.HttpServletRequest;

import com.utils.ValidatorUtils;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.format.annotation.DateTimeFormat;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.baomidou.mybatisplus.mapper.Wrapper;
import com.annotation.IgnoreAuth;

import com.entity.ShangpinxinxiEntity;
import com.entity.view.ShangpinxinxiView;

import com.service.ShangpinxinxiService;
import com.service.TokenService;
import com.utils.PageUtils;
import com.utils.R;
import com.utils.MD5Util;
import com.utils.MPUtil;
import com.utils.CommonUtil;
import java.io.IOException;
import com.service.StoreupService;
import com.entity.StoreupEntity;

/**
 * 商品信息
 * 后端接口
 * @author 
 * @email 
 * @date 
 */
@RestController
@RequestMapping("/shangpinxinxi")
public class ShangpinxinxiController {
    @Autowired
    private ShangpinxinxiService shangpinxinxiService;

    @Autowired
    private StoreupService storeupService;

    


    /**
     * 后端列表
     */
    @RequestMapping("/page")
    public R page(@RequestParam Map<String, Object> params,ShangpinxinxiEntity shangpinxinxi,
		HttpServletRequest request){
		String tableName = request.getSession().getAttribute("tableName").toString();
		if(tableName.equals("maijia")) {
			shangpinxinxi.setZhanghao((String)request.getSession().getAttribute("username"));
		}
        EntityWrapper<ShangpinxinxiEntity> ew = new EntityWrapper<ShangpinxinxiEntity>();
		PageUtils page = shangpinxinxiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, shangpinxinxi), params), params));

        return R.ok().put("data", page);
    }
    
    /**
     * 前端列表
     */
	@IgnoreAuth
    @RequestMapping("/list")
    public R list(@RequestParam Map<String, Object> params,ShangpinxinxiEntity shangpinxinxi, 
		HttpServletRequest request){
        EntityWrapper<ShangpinxinxiEntity> ew = new EntityWrapper<ShangpinxinxiEntity>();
		PageUtils page = shangpinxinxiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, shangpinxinxi), params), params));
        return R.ok().put("data", page);
    }

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

	 /**
     * 查询
     */
    @RequestMapping("/query")
    public R query(ShangpinxinxiEntity shangpinxinxi){
        EntityWrapper< ShangpinxinxiEntity> ew = new EntityWrapper< ShangpinxinxiEntity>();
 		ew.allEq(MPUtil.allEQMapPre( shangpinxinxi, "shangpinxinxi")); 
		ShangpinxinxiView shangpinxinxiView =  shangpinxinxiService.selectView(ew);
		return R.ok("查询商品信息成功").put("data", shangpinxinxiView);
    }
	
    /**
     * 后端详情
     */
    @RequestMapping("/info/{id}")
    public R info(@PathVariable("id") Long id){
        ShangpinxinxiEntity shangpinxinxi = shangpinxinxiService.selectById(id);
        return R.ok().put("data", shangpinxinxi);
    }

    /**
     * 前端详情
     */
	@IgnoreAuth
    @RequestMapping("/detail/{id}")
    public R detail(@PathVariable("id") Long id){
        ShangpinxinxiEntity shangpinxinxi = shangpinxinxiService.selectById(id);
        return R.ok().put("data", shangpinxinxi);
    }
    



    /**
     * 后端保存
     */
    @RequestMapping("/save")
    public R save(@RequestBody ShangpinxinxiEntity shangpinxinxi, HttpServletRequest request){
    	shangpinxinxi.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
    	//ValidatorUtils.validateEntity(shangpinxinxi);
        shangpinxinxiService.insert(shangpinxinxi);
        return R.ok();
    }
    
    /**
     * 前端保存
     */
    @RequestMapping("/add")
    public R add(@RequestBody ShangpinxinxiEntity shangpinxinxi, HttpServletRequest request){
    	shangpinxinxi.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
    	//ValidatorUtils.validateEntity(shangpinxinxi);
        shangpinxinxiService.insert(shangpinxinxi);
        return R.ok();
    }

    /**
     * 修改
     */
    @RequestMapping("/update")
    public R update(@RequestBody ShangpinxinxiEntity shangpinxinxi, HttpServletRequest request){
        //ValidatorUtils.validateEntity(shangpinxinxi);
        shangpinxinxiService.updateById(shangpinxinxi);//全部更新
        return R.ok();
    }
    

    /**
     * 删除
     */
    @RequestMapping("/delete")
    public R delete(@RequestBody Long[] ids){
        shangpinxinxiService.deleteBatchIds(Arrays.asList(ids));
        return R.ok();
    }
    
    /**
     * 提醒接口
     */
	@RequestMapping("/remind/{columnName}/{type}")
	public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request, 
						 @PathVariable("type") String type,@RequestParam Map<String, Object> map) {
		map.put("column", columnName);
		map.put("type", type);
		
		if(type.equals("2")) {
			SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
			Calendar c = Calendar.getInstance();
			Date remindStartDate = null;
			Date remindEndDate = null;
			if(map.get("remindstart")!=null) {
				Integer remindStart = Integer.parseInt(map.get("remindstart").toString());
				c.setTime(new Date()); 
				c.add(Calendar.DAY_OF_MONTH,remindStart);
				remindStartDate = c.getTime();
				map.put("remindstart", sdf.format(remindStartDate));
			}
			if(map.get("remindend")!=null) {
				Integer remindEnd = Integer.parseInt(map.get("remindend").toString());
				c.setTime(new Date());
				c.add(Calendar.DAY_OF_MONTH,remindEnd);
				remindEndDate = c.getTime();
				map.put("remindend", sdf.format(remindEndDate));
			}
		}
		
		Wrapper<ShangpinxinxiEntity> wrapper = new EntityWrapper<ShangpinxinxiEntity>();
		if(map.get("remindstart")!=null) {
			wrapper.ge(columnName, map.get("remindstart"));
		}
		if(map.get("remindend")!=null) {
			wrapper.le(columnName, map.get("remindend"));
		}

		String tableName = request.getSession().getAttribute("tableName").toString();
		if(tableName.equals("maijia")) {
			wrapper.eq("zhanghao", (String)request.getSession().getAttribute("username"));
		}

		int count = shangpinxinxiService.selectCount(wrapper);
		return R.ok().put("count", count);
	}
	







}

论文参考

在这里插入图片描述

目 录
1 前言 1
1.1 课题背景 1
1.2 课题意义 1
1.3 研究内容 1
2 开发环境与技术 3
2.1 Java语言 3
2.2 MYSQL数据库 3
2.3 IDEA开发工具 3
2.4 Spring Boot框架 4
3 系统分析 5
3.1 可行性分析 5
3.1.1 技术可行性 5
3.1.2 经济可行性 5
3.1.3 操作可行性 5
3.2 系统流程 5
3.2.1 操作流程 5
3.2.2 登录流程 6
3.2.3 删除信息流程 7
3.2.4 添加信息流程 7
3.3 性能需求 8
3.4 功能需求 9
4 系统设计 13
4.1 系统设计思想 13
4.2 功能结构设计 14
4.3 数据库设计 16
4.3.1 数据库概念设计 16
4.3.2 数据库物理设计 18
5 系统实现 23
5.1 管理员功能实现 23
5.1.1 卖家管理 23
5.1.2 用户管理 23
5.1.3 售后信息管理 23
5.2 卖家功能实现 24
5.2.1 商品信息管理 24
5.2.2 订单信息管理 24
5.2.3 订单追踪管理 25
5.2.4 在线交流管理 25
5.3 用户功能实现 26
5.3.1 商品信息 26
5.3.2 资讯信息 26
5.3.3 订单信息管理 27
5.3.4 订单追踪管理 27
6 系统测试 29
6.1 功能测试 29
6.1.1 登录功能测试 29
6.1.2 修改密码功能测试 30
6.2 系统测试结果 31
结论 32
参考文献 33
致谢 34

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值