Java项目:82 springboot飘香水果购物网站的设计与实现

本文主要是介绍Java项目:82 springboot飘香水果购物网站的设计与实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

作者主页:源码空间codegym

简介:Java领域优质创作者、Java项目、学习资料、技术互助

文中获取源码

项目介绍

本水果购物网站管理员、用户两个角色。

管理员功能有,个人中心管理,用户管理,会员管理,会员卡管理,开通会员记录管理,积分管理,水果管理,购买水果订单管理,积分兑换管理,积分兑换记录管理,加积分记录管理,减积分记录管理。

用户可以注册登录,在首页开通会员卡,查看水果,购买水果,查看水果信息,以及个人中心修改个人资料,在自己的后台查看自己的购买记录等。

环境要求

1.运行环境:最好是java jdk1.8,我们在这个平台上运行的。其他版本理论上也可以。

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

3.tomcat环境:Tomcat7.x,8.X,9.x版本均可

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

5.是否Maven项目:是;查看源码目录中是否包含pom.xml;若包含,则为maven项目,否则为非maven.项目

6.数据库:MySql5.7/8.0等版本均可;

技术栈

运行环境:jdk8 + tomcat9 + mysql5.7 + windows10

服务端技术:SpringBoot + MyBatis + Vue + Bootstrap + jQuery

使用说明

1.使用Navicati或者其它工具,在mysql中创建对应sq文件名称的数据库,并导入项目的sql文件;

2.使用IDEA/Eclipse/MyEclipse导入项目,修改配置,运行项目;

3.将项目中config-propertiesi配置文件中的数据库配置改为自己的配置,然后运行;

运行指导

idea导入源码空间站顶目教程说明(Vindows版)-ssm篇:

http://mtw.so/5MHvZq

源码地址:http://codegym.top

运行截图

文档截图

img

img

项目截图

前台

1

2

3

4

5

后台

6

7

8

<template><div style="backgroundImage: url('/yiliaozonghefuwu/img/back-img-bg.jpg');background-size:cover;"><div class="container"><div class="login-form" style="backgroundColor:rgba(183, 174, 174, 0.5);borderRadius:22px"><h1 class="h1" style="color:#000;fontSize:28px;">妇幼健康管理系统注册</h1><el-form class="rgs-form" label-width="120px"><el-form-item label="账号" class="input"><el-input v-model="ruleForm.username" autocomplete="off" placeholder="账号"  /></el-form-item><el-form-item label="密码" class="input"><el-input type="password" v-model="ruleForm.password" autocomplete="off" show-password/></el-form-item><el-form-item label="重复密码" class="input"><el-input type="password" v-model="ruleForm.repetitionPassword" autocomplete="off" show-password/></el-form-item><el-form-item label="医生姓名" class="input" v-if="tableName=='yisheng'"><el-input v-model="ruleForm.yishengName" autocomplete="off" placeholder="医生姓名"  /></el-form-item><el-form-item label="医生手机号" class="input" v-if="tableName=='yisheng'"><el-input v-model="ruleForm.yishengPhone" autocomplete="off" placeholder="医生手机号"  /></el-form-item><el-form-item label="医生身份证号" class="input" v-if="tableName=='yisheng'"><el-input v-model="ruleForm.yishengIdNumber" autocomplete="off" placeholder="医生身份证号"  /></el-form-item><el-form-item label="电子邮箱" class="input" v-if="tableName=='yisheng'"><el-input v-model="ruleForm.yishengEmail" autocomplete="off" placeholder="电子邮箱"  /></el-form-item><el-form-item label="用户姓名" class="input" v-if="tableName=='yonghu'"><el-input v-model="ruleForm.yonghuName" autocomplete="off" placeholder="用户姓名"  /></el-form-item><el-form-item label="用户手机号" class="input" v-if="tableName=='yonghu'"><el-input v-model="ruleForm.yonghuPhone" autocomplete="off" placeholder="用户手机号"  /></el-form-item><el-form-item label="用户身份证号" class="input" v-if="tableName=='yonghu'"><el-input v-model="ruleForm.yonghuIdNumber" autocomplete="off" placeholder="用户身份证号"  /></el-form-item><el-form-item label="电子邮箱" class="input" v-if="tableName=='yonghu'"><el-input v-model="ruleForm.yonghuEmail" autocomplete="off" placeholder="电子邮箱"  /></el-form-item><div style="display: flex;flex-wrap: wrap;width: 100%;justify-content: center;"><el-button class="btn" type="primary" @click="login()">注册</el-button><el-button class="btn close" type="primary" @click="close()">取消</el-button></div></el-form></div></div></div>
</template>
<script>export default {data() {return {ruleForm: {},tableName:"",rules: {},sexTypesOptions : [],};},mounted(){let table = this.$storage.get("loginTable");this.tableName = table;//级联表的下拉框查询},methods: {// 获取uuidgetUUID () {return new Date().getTime();},close(){this.$router.push({ path: "/login" });},// 注册login() {if((!this.ruleForm.username)){this.$message.error('账号不能为空');return}if((!this.ruleForm.password)){this.$message.error('密码不能为空');return}if((!this.ruleForm.repetitionPassword)){this.$message.error('重复密码不能为空');return}if(this.ruleForm.repetitionPassword != this.ruleForm.password){this.$message.error('密码和重复密码不一致');return}if((!this.ruleForm.yishengName)&& 'yisheng'==this.tableName){this.$message.error('医生姓名不能为空');return}if('yisheng' == this.tableName && this.ruleForm.yishengPhone&&(!this.$validate.isMobile(this.ruleForm.yishengPhone))){this.$message.error('手机应输入手机格式');return}if((!this.ruleForm.yishengIdNumber)&& 'yisheng'==this.tableName){this.$message.error('医生身份证号不能为空');return}if('yisheng' == this.tableName && this.ruleForm.yishengEmail&&(!this.$validate.isEmail(this.ruleForm.yishengEmail))){this.$message.error("邮箱应输入邮件格式");return}if((!this.ruleForm.yonghuName)&& 'yonghu'==this.tableName){this.$message.error('用户姓名不能为空');return}if('yonghu' == this.tableName && this.ruleForm.yonghuPhone&&(!this.$validate.isMobile(this.ruleForm.yonghuPhone))){this.$message.error('手机应输入手机格式');return}if((!this.ruleForm.yonghuIdNumber)&& 'yonghu'==this.tableName){this.$message.error('用户身份证号不能为空');return}if('yonghu' == this.tableName && this.ruleForm.yonghuEmail&&(!this.$validate.isEmail(this.ruleForm.yonghuEmail))){this.$message.error("邮箱应输入邮件格式");return}this.$http({url: `${this.tableName}/register`,method: "post",data:this.ruleForm}).then(({ data }) => {if (data && data.code === 0) {this.$message({message: "注册成功,请登录后在个人中心页面补充个人数据",type: "success",duration: 1500,onClose: () => {this.$router.replace({ path: "/login" });}});} else {this.$message.error(data.msg);}});}}};
</script>
<style lang="scss" scoped>.el-radio__input.is-checked .el-radio__inner {border-color: #00c292;background: #00c292;}.el-radio__input.is-checked .el-radio__inner {border-color: #00c292;background: #00c292;}.el-radio__input.is-checked .el-radio__inner {border-color: #00c292;background: #00c292;}.el-radio__input.is-checked+.el-radio__label {color: #00c292;}.el-radio__input.is-checked+.el-radio__label {color: #00c292;}.el-radio__input.is-checked+.el-radio__label {color: #00c292;}.h1 {margin-top: 10px;}body {padding: 0;margin: 0;}// .container {//    min-height: 100vh;//    text-align: center;//    // background-color: #00c292;//    padding-top: 20vh;//    background-image: url(../assets/img/bg.jpg);//    background-size: 100% 100%;//    opacity: 0.9;//  }// .login-form:before {// 	vertical-align: middle;// 	display: inline-block;// }// .login-form {// 	max-width: 500px;// 	padding: 20px 0;// 	width: 80%;// 	position: relative;// 	margin: 0 auto;// 	.label {// 		min-width: 60px;// 	}// 	.input-group {// 		max-width: 500px;// 		padding: 20px 0;// 		width: 80%;// 		position: relative;// 		margin: 0 auto;// 		display: flex;// 		align-items: center;// 		.input-container {// 			display: inline-block;// 			width: 100%;// 			text-align: left;// 			margin-left: 10px;// 		}// 		.icon {// 			width: 30px;// 			height: 30px;// 		}// 		.input {// 			position: relative;// 			z-index: 2;// 			float: left;// 			width: 100%;// 			margin-bottom: 0;// 			box-shadow: none;// 			border-top: 0px solid #ccc;// 			border-left: 0px solid #ccc;// 			border-right: 0px solid #ccc;// 			border-bottom: 1px solid #ccc;// 			padding: 0px;// 			resize: none;// 			border-radius: 0px;// 			display: block;// 			width: 100%;// 			height: 34px;// 			padding: 6px 12px;// 			font-size: 14px;// 			line-height: 1.42857143;// 			color: #555;// 			background-color: #fff;// 		}// 	}// }.nk-navigation {margin-top: 15px;a {display: inline-block;color: #fff;background: rgba(255, 255, 255, .2);width: 100px;height: 50px;border-radius: 30px;text-align: center;display: flex;align-items: center;margin: 0 auto;justify-content: center;padding: 0 20px;}.icon {margin-left: 10px;width: 30px;height: 30px;}}.register-container {margin-top: 10px;a {display: inline-block;color: #fff;max-width: 500px;height: 50px;border-radius: 30px;text-align: center;display: flex;align-items: center;margin: 0 auto;justify-content: center;padding: 0 20px;div {margin-left: 10px;}}}.container {height: 100vh;background-position: center center;background-size: cover;background-repeat: no-repeat;.login-form {right: 50%;top: 50%;height: auto;transform: translate3d(50%, -50%, 0);border-radius: 10px;background-color: rgba(255,255,255,.5);width: 420px;padding: 30px 30px 40px 30px;font-size: 14px;font-weight: 500;.h1 {margin: 0;text-align: center;line-height: 54px;font-size: 24px;color: #000;}.rgs-form {display: flex;flex-direction: column;justify-content: center;align-items: center;.input {width: 100%;& /deep/ .el-form-item__label {line-height: 40px;color: rgba(17, 16, 16, 1);font-size: #606266;}& /deep/ .el-input__inner {height: 40px;color: rgba(23, 24, 26, 1);font-size: 14px;border-width: 1px;border-style: solid;border-color: #606266;border-radius: 22px;background-color: #fff;}}.btn {margin: 0 10px;width: 88px;height: 44px;color: #fff;font-size: 14px;border-width: 1px;border-style: solid;border-color: #409EFF;border-radius: 22px;background-color: #409EFF;}.close {margin: 0 10px;width: 88px;height: 44px;color: #409EFF;font-size: 14px;border-width: 1px;border-style: solid;border-color: #409EFF;border-radius: 22px;background-color: #FFF;}}}}
</style>

这篇关于Java项目:82 springboot飘香水果购物网站的设计与实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

Java判断多个时间段是否重合的方法小结

《Java判断多个时间段是否重合的方法小结》这篇文章主要为大家详细介绍了Java中判断多个时间段是否重合的方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录判断多个时间段是否有间隔判断时间段集合是否与某时间段重合判断多个时间段是否有间隔实体类内容public class D

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

Java中ArrayList和LinkedList有什么区别举例详解

《Java中ArrayList和LinkedList有什么区别举例详解》:本文主要介绍Java中ArrayList和LinkedList区别的相关资料,包括数据结构特性、核心操作性能、内存与GC影... 目录一、底层数据结构二、核心操作性能对比三、内存与 GC 影响四、扩容机制五、线程安全与并发方案六、工程

部署Vue项目到服务器后404错误的原因及解决方案

《部署Vue项目到服务器后404错误的原因及解决方案》文章介绍了Vue项目部署步骤以及404错误的解决方案,部署步骤包括构建项目、上传文件、配置Web服务器、重启Nginx和访问域名,404错误通常是... 目录一、vue项目部署步骤二、404错误原因及解决方案错误场景原因分析解决方案一、Vue项目部署步骤

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2