基于springboot生鲜到家农产品商城APP源码

【565】基于springboot生鲜到家农产品商城APP源码和论文导入教程和演示

生鲜到家APP是一种供用户在手机端下单生鲜,从而配送生鲜到家的一个APP,在这个信息与技术快速发展的时代,人们足不出户即可买到商品已形成常态,如今,人们物质生活已经得到了极大的提高,送菜上门服务是大势所趋, 随着电子商务和物流行业的迅速发展,送菜上门服务在国内许多城市都日渐红火发展,从而推出一款可以在手机下单生鲜,送货到家的APP是十分必要了。

本系统综合线下与线下的实际需求,做出更便捷的APP功能管理,更具市场现状而开发设计的。可实现用户登录注册功能、商品分类管理功能、商品详情功能、搜索生鲜功能、购物车管理功能、订单管理功能、商品公告功能、收货地址管理功能、支付功能、配送功能、评价功能、售后退款功能。

本课题的设计与实现,可以有助于生鲜的网上销售,对目前生鲜市场的销售有很大的帮助,提高销量,增加盈利,课题的实现也给我们的专业学习带来积极意义,考核对我们专业学习的掌握程度。

    生鲜到家APP,旨在帮助商家和用户之间建立一个互相之间的信息交换平台,方便用户下单,评论,享受相关的优惠等,同时方便商家发布信息,接单,送货上门等。APP包括两个部分,商家的后台管理系统和用户的客户端。商家在自己的后台管理系统中,进行商品的添加,上架、下架、修改等操作,修改完的数据保存在服务器的数据库中。用户在手机客户端选择想要的商品,加入购物车,提交订单,进行结账。在提交订单时,客户端把用户的信息,订单的信息传递给服务器端进行处理。服务器将订单信息传送到商家,商家通过订单信息,对用户配送相关商品。客户可以通过在安卓手机端进行注册,在注册成功之后可以进行登录,到了登陆界面,就可以来购买商品。通过使用生鲜到家APP,商家就省下店铺成本,而且也可以使销量增加,客户则可以足不出户,购买到自己心仪的 生鲜产品,无论是对于商家,还是对于用户,都有很多好处。   

本文介绍的就是这样一款C/S结构的生鲜到家APP,用户通过自己安卓手机端的软件选择相关商品添加到购物车并进行结算,商家通过服务器传递来的信息对订单进行处理,从而安排配送,并可以按照自己的需要对网上发布的商品进行修改等操作。实现本系统,客户端选取了目前最流行的移动手机操作系统安卓系统,在安卓平台上进行生鲜到家APP的开发。服务器端采用了JavaEE技术,并采用了目前较为流行Mybatis+Springboot框架进行设计。服务器与客户端通过Json进行数据的传输,安卓系统端主要是内容的展示和网络通信的功能。同时后台是采用B/S架构的Web系统,商家的后台管理系统主要是对商品等信息进行管理等功能,在浏览器操作,数据库采用目前较为流行的Mysql数据库进行设计。

<template>
	<view>
		<!-- 地址 -->
		<navigator url="/pages/address/address?source=1" class="address-section">
			<view class="order-content">
				<text class="yticon icon-shouhuodizhi"></text>
				<view class="cen" v-if="addressData.id">
					<view class="top">
						<text class="name">{{addressData.name}}</text>
						<text class="mobile">{{addressData.mobile}}</text>
					</view>
					<text class="address">{{addressData.address}} {{addressData.area}}</text>
				</view>
				<view class="cen" v-else>
					没有收货地址(去编辑)
				</view>
				<text class="yticon icon-you"></text>
			</view>

			<image class="a-bg" src=""></image>
		</navigator>

		<view class="goods-section">
			<!-- <view class="g-header b-b">
				<image class="logo" src="http://duoduo.qibukj.cn/./Upload/Images/20190321/201903211727515.png"></image>
				<text class="name">西城小店铺</text>
			</view> -->
			<!-- 商品列表 -->
			<view class="g-item" v-for="item in goodsData" :key="item.id">
				<image :src="http+item.product.image"></image>
				<view class="right">
					<text class="title clamp">{{item.product.title}}</text>
					<!-- <text class="spec">春装款 L</text> -->
					<view class="price-box">
						<text class="price">¥{{item.product.shopPrice}}</text>
						<text class="number">x {{item.count}}</text>
					</view>
				</view>
			</view>
		
		</view>

		<!-- 优惠明细 -->
<!-- 		<view class="yt-list">
			<view class="yt-list-cell b-b" @click="toggleMask('show')">
				<view class="cell-icon">
					券
				</view>
				<text class="cell-tit clamp">优惠券</text>
				<text class="cell-tip active">
					选择优惠券
				</text>
				<text class="cell-more wanjia wanjia-gengduo-d"></text>
			</view>
			<view class="yt-list-cell b-b">
				<view class="cell-icon hb">
					减
				</view>
				<text class="cell-tit clamp">商家促销</text>
				<text class="cell-tip disabled">暂无可用优惠</text>
			</view>
		</view> -->
		<!-- 金额明细 -->
		<view class="yt-list">
			<view class="yt-list-cell b-b">
				<text class="cell-tit clamp">商品金额</text>
				<text class="cell-tip">¥{{goodsPrice}}</text>
			</view>
			
			<view class="yt-list-cell b-b">
				<text class="cell-tit clamp">运费</text>
				<text class="cell-tip">免运费</text>
			</view>
			<view class="yt-list-cell desc-cell">
				<text class="cell-tit clamp">备注</text>
				<input class="desc" type="text" v-model="desc" placeholder="请填写备注信息" placeholder-class="placeholder" />
			</view>
		</view>
		
		<!-- 底部 -->
		<view class="footer">
			<view class="price-content">
				<text>实付款</text>
				<text class="price-tip">¥</text>
				<text class="price">{{goodsPrice}}</text>
			</view>
			<text class="submit" @click="now?buyNow():submit()">提交订单</text>
		</view>
		
		<!-- 优惠券面板 -->
		<view class="mask" :class="maskState===0 ? 'none' : maskState===1 ? 'show' : ''" @click="toggleMask">
			<view class="mask-content" @click.stop.prevent="stopPrevent">
				<!-- 优惠券页面,仿mt -->
				<view class="coupon-item" v-for="(item,index) in couponList" :key="index">
					<view class="con">
						<view class="left">
							<text class="title">{{item.title}}</text>
							<text class="time">有效期至2019-06-30</text>
						</view>
						<view class="right">
							<text class="price">{{item.price}}</text>
							<text>满30可用</text>
						</view>
						
						<view class="circle l"></view>
						<view class="circle r"></view>
					</view>
					<text class="tips">限新用户使用</text>
				</view>
			</view>
		</view>

	</view>
</template>

<script>
	import {
	    mapState,mapMutations
	} from 'vuex';  
	export default {
		data() {
			return {
				http:"",
				maskState: 0, //优惠券面板显示状态
				desc: '', //备注
				payType: 2, //1微信 2支付宝
				goodsData:[],	
				goodsPrice:"",
				now:false,
				couponList: [
					{
						title: '新用户专享优惠券',
						price: 5,
					},
					{
						title: '庆五一发一波优惠券',
						price: 10,
					},
					{
						title: '优惠券优惠券优惠券优惠券',
						price: 15,
					}
				],
				addressData: {}
			}
		},
		computed: {
			...mapState(['hasLogin'])
		},
		onShow() {
			console.log(this.hasLogin)
			if(!this.hasLogin){
				uni.navigateTo({
				url:'/pages/public/login'
				})
			return;	
			}		
			let that =this;
			uni.getStorage({
				key:'goodsData',
				success: (ret) => {
				that.goodsData = ret.data;
			    that.goodsPrice=0;
			//合计
			let len = this.goodsData.length;
			for(let i=0;i<len;i++){
				that.goodsPrice = that.goodsPrice + (that.goodsData[i].count*that.goodsData[i].product.shopPrice);
			}}
			});
			
		},
		onLoad(e){
		
			if(Boolean(e.now)){
				this.now=Boolean(e.now);
			}
			
			this.http = this.$http;
			this.getAddress();
					
		},
		methods: {
			//显示优惠券面板
			// toggleMask(type){
			// 	let timer = type === 'show' ? 10 : 300;
			// 	let	state = type === 'show' ? 1 : 0;
			// 	this.maskState = 2;
			// 	setTimeout(()=>{
			// 		this.maskState = state;
			// 	}, timer)
			// },
			// numberChange(data) {
			// 	this.number = data.number;
			// },
			changePayType(type){
				this.payType = type;
			},
			getAddress(){
				let that=this;
				uni.showLoading();
				this.$request.get('/user/address/one.do').then(res => {
					 uni.hideLoading();
					 if(res.message=='success'){
						  that.addressData=res.data;
					 }
			        
				}).catch(e => {uni.hideLoading();})
			},
			submit(){
				
				let paymentOrder = [];
				let goodsid=[];
				let len = this.goodsData.length;
				for(let i=0;i<len;i++){
					paymentOrder.push(this.goodsData[i].id);
				
				}
				if(paymentOrder.length==0){
					uni.showToast({title:'订单信息有误,请重新购买',icon:'none'});
					return ;
				}
				let that=this;
				uni.showLoading();
				this.$request.post('/order/sumbit.do',{
					buylist:paymentOrder ,
					note:that.desc,
				    freight:0,
					address:that.addressData.id
				}).then(res => {
					if(res.message=='success'){
					uni.redirectTo({
						url: '/pages/money/pay?id='+res.data
					})
					}else{
						uni.showToast({
							title:res.data,
						})
					}
					
				
					uni.hideLoading();
				}).catch(e => {uni.hideLoading();})
			
			},
			buyNow(){
				let that=this;
				let paymentOrder = this.goodsData[0];
		   console.log(paymentOrder)
				this.$request.post('/order/buyNow.do',{
					productId:paymentOrder.productId,
				    count:paymentOrder.count,
					note:that.desc,
				    freight:0,
					address:that.addressData.id
				}).then(res => {
					if(res.message=='success'){
					uni.redirectTo({
						url: '/pages/money/pay?id='+res.data
					})
					}else{
						uni.showToast({
							title:res.data,
						})
					}
					uni.hideLoading();
				}).catch(e => {uni.hideLoading();})
			},
			stopPrevent(){}
		}
	}
</script>

<style lang="scss">
	page {
		background: $page-color-base;
		padding-bottom: 100upx;
	}

	.address-section {
		padding: 30upx 0;
		background: #fff;
		position: relative;

		.order-content {
			display: flex;
			align-items: center;
		}

		.icon-shouhuodizhi {
			flex-shrink: 0;
			display: flex;
			align-items: center;
			justify-content: center;
			width: 90upx;
			color: #888;
			font-size: 44upx;
		}

		.cen {
			display: flex;
			flex-direction: column;
			flex: 1;
			font-size: 28upx;
			color: $font-color-dark;
		}

		.name {
			font-size: 34upx;
			margin-right: 24upx;
		}

		.address {
			margin-top: 16upx;
			margin-right: 20upx;
			color: $font-color-light;
		}

		.icon-you {
			font-size: 32upx;
			color: $font-color-light;
			margin-right: 30upx;
		}

		.a-bg {
			position: absolute;
			left: 0;
			bottom: 0;
			display: block;
			width: 100%;
			height: 5upx;
		}
	}

	.goods-section {
		margin-top: 16upx;
		background: #fff;
		padding-bottom: 1px;

		.g-header {
			display: flex;
			align-items: center;
			height: 84upx;
			padding: 0 30upx;
			position: relative;
		}

		.logo {
			display: block;
			width: 50upx;
			height: 50upx;
			border-radius: 100px;
		}

		.name {
			font-size: 30upx;
			color: $font-color-base;
			margin-left: 24upx;
		}

		.g-item {
			display: flex;
			margin: 20upx 30upx;

			image {
				flex-shrink: 0;
				display: block;
				width: 140upx;
				height: 140upx;
				border-radius: 4upx;
			}

			.right {
				flex: 1;
				padding-left: 24upx;
				overflow: hidden;
			}

			.title {
				font-size: 30upx;
				color: $font-color-dark;
			}

			.spec {
				font-size: 26upx;
				color: $font-color-light;
			}

			.price-box {
				display: flex;
				align-items: center;
				font-size: 32upx;
				color: $font-color-dark;
				padding-top: 10upx;

				.price {
					margin-bottom: 4upx;
				}
				.number{
					font-size: 26upx;
					color: $font-color-base;
					margin-left: 20upx;
				}
			}

			.step-box {
				position: relative;
			}
		}
	}
	.yt-list {
		margin-top: 16upx;
		background: #fff;
	}

	.yt-list-cell {
		display: flex;
		align-items: center;
		padding: 10upx 30upx 10upx 40upx;
		line-height: 70upx;
		position: relative;

		&.cell-hover {
			background: #fafafa;
		}

		&.b-b:after {
			left: 30upx;
		}

		.cell-icon {
			height: 32upx;
			width: 32upx;
			font-size: 22upx;
			color: #fff;
			text-align: center;
			line-height: 32upx;
			background: #f85e52;
			border-radius: 4upx;
			margin-right: 12upx;

			&.hb {
				background: #ffaa0e;
			}

			&.lpk {
				background: #3ab54a;
			}

		}

		.cell-more {
			align-self: center;
			font-size: 24upx;
			color: $font-color-light;
			margin-left: 8upx;
			margin-right: -10upx;
		}

		.cell-tit {
			flex: 1;
			font-size: 26upx;
			color: $font-color-light;
			margin-right: 10upx;
		}

		.cell-tip {
			font-size: 26upx;
			color: $font-color-dark;

			&.disabled {
				color: $font-color-light;
			}

			&.active {
				color: $base-color;
			}
			&.red{
				color: $base-color;
			}
		}

		&.desc-cell {
			.cell-tit {
				max-width: 90upx;
			}
		}

		.desc {
			flex: 1;
			font-size: $font-base;
			color: $font-color-dark;
		}
	}
	
	/* 支付列表 */
	.pay-list{
		padding-left: 40upx;
		margin-top: 16upx;
		background: #fff;
		.pay-item{
			display: flex;
			align-items: center;
			padding-right: 20upx;
			line-height: 1;
			height: 110upx;	
			position: relative;
		}
		.icon-weixinzhifu{
			width: 80upx;
			font-size: 40upx;
			color: #6BCC03;
		}
		.icon-alipay{
			width: 80upx;
			font-size: 40upx;
			color: #06B4FD;
		}
		.icon-xuanzhong2{
			display: flex;
			align-items: center;
			justify-content: center;
			width: 60upx;
			height: 60upx;
			font-size: 40upx;
			color: $base-color;
		}
		.tit{
			font-size: 32upx;
			color: $font-color-dark;
			flex: 1;
		}
	}
	
	.footer{
		position: fixed;
		left: 0;
		bottom: 0;
		z-index: 995;
		display: flex;
		align-items: center;
		width: 100%;
		height: 90upx;
		justify-content: space-between;
		font-size: 30upx;
		background-color: #fff;
		z-index: 998;
		color: $font-color-base;
		box-shadow: 0 -1px 5px rgba(0,0,0,.1);
		.price-content{
			padding-left: 30upx;
		}
		.price-tip{
			color: $base-color;
			margin-left: 8upx;
		}
		.price{
			font-size: 36upx;
			color: $base-color;
		}
		.submit{
			display:flex;
			align-items:center;
			justify-content: center;
			width: 280upx;
			height: 100%;
			color: #fff;
			font-size: 32upx;
			background-color: $base-color;
		}
	}
	
	/* 优惠券面板 */
	.mask{
		display: flex;
		align-items: flex-end;
		position: fixed;
		left: 0;
		top: var(--window-top);
		bottom: 0;
		width: 100%;
		background: rgba(0,0,0,0);
		z-index: 9995;
		transition: .3s;
		
		.mask-content{
			width: 100%;
			min-height: 30vh;
			max-height: 70vh;
			background: #f3f3f3;
			transform: translateY(100%);
			transition: .3s;
			overflow-y:scroll;
		}
		&.none{
			display: none;
		}
		&.show{
			background: rgba(0,0,0,.4);
			
			.mask-content{
				transform: translateY(0);
			}
		}
	}

	/* 优惠券列表 */
	.coupon-item{
		display: flex;
		flex-direction: column;
		margin: 20upx 24upx;
		background: #fff;
		.con{
			display: flex;
			align-items: center;
			position: relative;
			height: 120upx;
			padding: 0 30upx;
			&:after{
				position: absolute;
				left: 0;
				bottom: 0;
				content: '';
				width: 100%;
				height: 0;
				border-bottom: 1px dashed #f3f3f3;
				transform: scaleY(50%);
			}
		}
		.left{
			display: flex;
			flex-direction: column;
			justify-content: center;
			flex: 1;
			overflow: hidden;
			height: 100upx;
		}
		.title{
			font-size: 32upx;
			color: $font-color-dark;
			margin-bottom: 10upx;
		}
		.time{
			font-size: 24upx;
			color: $font-color-light;
		}
		.right{
			display: flex;
			flex-direction: column;
			justify-content: center;
			align-items: center;
			font-size: 26upx;
			color: $font-color-base;
			height: 100upx;
		}
		.price{
			font-size: 44upx;
			color: $base-color;
			&:before{
				content: '¥';
				font-size: 34upx;
			}
		}
		.tips{
			font-size: 24upx;
			color: $font-color-light;
			line-height: 60upx;
			padding-left: 30upx;
		}
		.circle{
			position: absolute;
			left: -6upx;
			bottom: -10upx;
			z-index: 10;
			width: 20upx;
			height: 20upx;
			background: #f3f3f3;
			border-radius: 100px;
			&.r{
				left: auto;
				right: -6upx;
			}
		}
	}

</style>

① 系统环境:Windows/Mac ② 开发语言:Java ③ 框架:SpringBoot ④ 架构:B/S、MVC ⑤ 开发环境:IDEA、JDK、Maven、Mysql ⑥ JDK版本:JDK1.8 ⑦ Maven包:Maven3.6 ⑧ 数据库:mysql 5.7 ⑨ 服务平台:Tomcat 8.0/9.0 ⑩ 数据库工具:SQLyog/Navicat ⑪ 开发软件:eclipse/myeclipse/idea ⑫ 浏览器:谷歌浏览器/微软edge/火狐 ⑬ 技术栈:Java、Mysql、Maven、Springboot、Mybatis、Ajax、Vue等 2、适用人群:计算机,电子信息工程等专业的学习者等, 高分毕业设计项目,也可作为课程设计和期末大作业。本资源仅是代码的压缩包,该代码适合毕业设计、课程设计作业,所有源码均经过严格测试,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答! 3、解压说明:本资源需要电脑端使用WinRAR、7zip、Bandizip等解压工具进行解压 4、最新计算机软件毕业设计选题大全 https://blog.csdn.net/weixin_45630258/article/details/135901374 5、系统的实现说明 摘 要 I 目 录 III 第1章 绪论 1 1.1选题动因 1 1.2背景与意义 1 第2章 相关技术介绍 3 2.1 MySQL数据库 3 2.2 Vue前端技术 3 2.3 B/S架构模式 4 2.4 ElementUI介绍 4 第3章 系统分析 5 3.1 可行性分析 5 3.1.1技术可行性 5 3.1.2经济可行性 5 3.1.3运行可行性 6 3.2 系统流程 6 3.2.1 操作信息流程 6 3.2.2 登录信息流程 6 3.2.3 删除信息流程 7 3.3 性能需求 7 第4章 系统设计 8 4.1系统整体结构 8 4.2系统功能设计 9 4.3数据库设计 9 第5章 系统的实现 20 5.1用户信息管理 20 5.2 图片素材管理 20 5.3视频素材管理 21 5.1公告信息管理 22 第6章 系统的测试 24 6.1软件测试 24 6.2测试环境 24 6.3测试测试用例 24 6.4测试结果 25
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序猿毕业分享网

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值