校园二手平台的开发与设计.docx
新疆大学软件学院本科毕业论文(设计)目 录1 绪论11.1 课题研究背景11.2 研究意义11.3 研究的目标22 系统技术选型32.1 数据库选择32.2 开发工具的选择32.3 后端框架选择32.4 前端框架选择33 系统需求和可行性分析43.1 总体设计原则43.2 需求分析43.3 可行性分析53.3.1 技术可行性53.3.2 经济可行性63.3.3 操作可行性64 系统设计74.1 概要设计74.2 页面设计74.3 数据库设计74.3.1 数据库概念结构设计74.3.2 数据库逻辑结构设计85 系统实现115.1 网站前台设计与实现115.1.1 用户登录模块115.1.2 用户注册模块125.1.3 商品模块135.1.4 用户订单模块145.1.5 用户购物车模块165.1.6 申请商家模块185.1.7 个人信息模块195.2 网站后台设计与实现205.2.1 商品管理模块205.2.2 用户管理模块216 系统调试与测试236.1 测试概述236.2 测试内容236.3 测试结果236.4 本章小结257 总结与展望267.1 总结267.2 展望27参考文献28致 谢29III1 绪论1.1 课题研究背景在科技和生产力的快速发展下,各个行业都在蓬勃发展,互联网购物这样一个新型产业也在不断壮大,当代大学生作为网上购物的一个群体,在消费的时候大学生购买的物品有的时候利用率很低,有的甚至只用一次,造成了物品的闲置和浪费1。在一个在科技飞速发展的现在,电子产品更换周期短。一直这样下去不仅仅是对资源的一种浪费,关键还浪费了大学生很多的资金。并且在每年的毕业季,对于我亲身经历或许也是大多数的在校大学生所经历到的,有的学生会在校园内摆上小地摊来出售自己的闲置物品,这样的情况虽然是很好的,但是无形之间给校园内部的交通带来了压力,而且对于这样的现象也是没有一个规范化的管理。这样的情况下,一个规范的只通用在校园内部的平台就非常必要了。而这个平台的范围只是在校园中的学生之间,让在校大学生当商家,坐在电脑前就可以把自己的闲置物品卖出去,让学生们的闲置物品流动起来,更好的运用商品的用途。而且在校园内的学生们都是通过注册学生信息来使用的,比起现在网上二手物品交易平台,更加便捷,实用性更强,其中所含信息量具体,发展前景十分明朗。现在很多大学都有校园二手交易的活动,这种交易方式已经进入了广大群众的视野,正是在现在这种包容的大环境之下,有很多有关于我们大学生的二手物品交易平台被大多数学生所期待,它可以使学生之间快速的联系起来,满足一些学生的需求,也帮助一些学生处理自己的物品,也可以让用户选择自己真正喜欢的商品2。对于现在经常网购的大学生来说,如何能够将平台开发好,更好地便利人们的生活,让平台上的商品更加物美价廉,是我们眼前第一个要解决的问题。1.2 研究意义建立这个平台我们的本意是完成大学生在校内的闲置物品出售,利用了大学生闲置物品循环,让同学们自己做卖家,既能处理掉自己的闲置物品,也能获取到自己想要的东西。借助网络技术,开发这样的web端网站,目的是为了能够将校园里面的商品交易做的更加规范,更好管理,更加便利。与此同时也能将同学们的个性发扬出来,而且我们所做的网站功能齐全,操作使用起来一点都不复杂,十分方便,我相信它可以成为大学生处理闲置物品的有力工具。基于SpringBoot的校园二手交易平台,有效地拉近了同学们之间的距离,有效降低了运行所需的成本,使得学校二手交易更加规范,有效保证了学生们的消费者权利,让同学们日常交易更加方便和高效。1.3 研究的目标我们对这个方向进行研究是基于将校园交易与互联网管理进行有机结合,把二者结合到一起,其中我们最具特色的功能便是可以实现用户发布商品和发布需求的功能,实现了校内闲置物品的流动。本平台中可以对多方面信息进行管理,例如商户的有关信息,商户所卖商品的有关信息和消费者的有关信息等等。用户可以在本平台上实名认证之后申请成为商户,商户可以在个人中心发布自己不在使用或者搁置的物品。以上申请直接转到管理员的信息中心。管理员有处置申请通过和不通过的权限。从而达到在校大学生合理处置安排自己的闲置物品。本平台实现了线上以及线下沟通交易。在保证安全交易的情况下更大限度的给大学生处置物品的自由。302 系统技术选型本人所设计的校园交易平台不仅具有交易平台所需要的基本功能,而且操作起来没有任何难度,对用户们十分友好,不仅满足了各种各样用户的需求,同时我们在安全性方面也做了十足的考虑,从保障用户安全的方面进行考虑选择的操作系统。2.1 数据库选择所有在平台登记的商品和登记的用户的信息都在数据库中进行储存,而且对于事务来说其一致性是必须被确保的,以此来确保各方的权益,所以选择关系数据库更加合适,因此选择数据库,这种数据库是当下潮流最流行的而且其更加稳定,更加可靠,并且可以进行可视化操作4。对于后期调试和测试帮助很大,并且在大学期间我曾系统的学习过该数据库,掌握其基本知识。2.2 开发工具的选择在市面上有许许多多的开发工具,人们所用到比较多的无非就是这几款,就像是等,开发工具的选择必须要重视,因为如果选择的开发工具不可使,极有可能会造成事倍功半,工作效率大幅降低,达不到我们的预期效果,我所选择的开发工具是,理由如下;1.其具有自动提示的功能,并且能自动导包,2.代码重构,代码的重构功能也很聪明智能。能帮助你在代码书写过程中发现并且提示代码冗余地方。3.使用起来十分流畅,相比于其他的开发工具,他不会出现卡顿的情况,这是它所具有的优势之一。2.3 后端框架选择后端框架的选择是至关重要的,我选择作为我的开发框架,因为这种开发框架去油其他开发框架所不具有的有点。SpringBoot框架可以非常方便的集成其他相关技术。为项目配置提供了强大的支持6。而且相比其他还具有操作简便的优点。2.4 前端框架选择我们所创建的这个校园交易平台不仅有一定客户端,还有电脑端,前端框架的选择也是十分重要的,因此必须慎重,现在市面上最流行的是。可以选择这个前端框架。Spring 官方推荐使用Thymeleaf模板引擎功能强大,完全代替了jsp中的EL表达式7。这里面包含着很多的资源,基于此所以我们最后选择 +Thymeleaf模板引擎和前端框架。3 系统需求和可行性分析3.1 总体设计原则我们秉持着要给消费者提供最方便的服务和最舒适的用户体验的目的,要将校园交易平台设计得功能尽可能完善,操作最简化,同时保证平台上商品的质量,保证消费者权益,我们应当在开发时候遵循表3.1。系统的数据吞吐力很高,在有较多用户同时进行数据查询更新操作时系统依然可以保持运行的平稳实现系统时使用开源、通用的相关技术手段系统需要满足:全面的功能、便捷的操作、友好的接口、美观的UI设计 针对实际使用中不同需求的用户,系统都应当尽力满足,现有功能模块要有继续扩展的空间,且保持外部接口不变确保代码具有规范性及较强的可读性,严格按照DRY原则进行编写,对相关代码进行合理的注释系统的组成上,要对相关权限进行明确的划分、严格限制部分敏感操作,最大程度上保证服务器的平稳安全3.2 需求分析最开始我们需要对市场所需的东西进行有效分析,设计调查问卷对其进行相关调研,了解到我们所设计的平台应该具有哪些功能,经过这些步骤就可以得到这个平台的逻辑模型,在经过一定方式的转化,便可实现对于相关需求的满足。首先我们需要将所需的系统构架出来。我们所设计的平台追求的不仅仅是基本功能齐全,我们更加追求的是消费者良好的体验,因此简洁美观的界面是必不可少的,只要能够将页面设计成功,呢就是向整体成功迈出了一大步,归根结底我们设计的是校园交易平台,要能满足小于交易的各种需求,我们要进行结构化设计,现将整个平台根据不同的特性分为几个模块,然后再将每个模块细分,从而进行相关的设计和有关的调整。将平台进行模块划分过程中,我们是根据不同模块的特性和功能来进行划分的,这样做可以有效地降低在开发过程中的复杂度,并且能使开发者的思路很明确,可以在很短的时间内完成任务9。网站功能如下:(1)首页:商城首页展示了平台所售商品的一切相关信息,让用户可以全面了解商品情况。(2)新用户进行注册:在新用户进行注册的过程中填写个人信息,并且使用手机接收验证码,校验用户的信息是否属实,并对其真实身份进行有效验证,一旦出现问题则不予注册。(3)用户进行登录:如果该用户曾经注册过本平台账号,可以进行登录操作,保存登录信息。(4)商品展示模块:商品展示区域展示当前平台的所有上架的商品信息。包含商品名、价格等,可以实现分类别查看展示和搜索展示信息。(5)商品详情展示:展示当前商品的全部信息,罗列到页面上,多表联查商家信息和评论信息。(6)订单模块:对于用户进行购买操作时直接生成订单,用户在个人中心可以查看自己的订单,对未付款的订单执行付款操作,对其余订单可以进行删除操作。(7)管理员登录:管理员使用同一配发的账号进行登录操作。在后台模块管理员账号是不可注册,只能进行一并发放。(8)商品进行管理:本平台所出售的所有商品都由我们平台的管理员进行统一管理,商品的注册,出库,派发都是由其负责。(9)对本网站的所有用户进行管理:所有经过注册的用户的信息都有备份,管理员可以查看相关的账号信息,并且在发现账号信息异常的时候可以执行锁定功能。系统整体设计框架图如图3-1所示:图3-1 系统整体设计架构图3.3 可行性分析3.3.1 技术可行性创建校园交易平台对其进行技术可行性分析研究,其主要有两个难点,主要是前期对相关软件进行开发和创建平台后的维护两点,在对相关软件进行开发的过程中,模式是其主要的模式,对其进行分层所使用的是设计模式。为了能够更好地控制版本,本地和远程仓库的部署采用的是不同的管理模式,这样可以使得管理起来更加高效,合理。创建平台后对其维护的时候,管理员可以通过后台管理的接口进入平台,从而对平台进行维护。除此以外,管理员还可以通过服务器进入数据库。实现以上要求主要使用了等相关技术。3.3.2 经济可行性创建校园交易平台对其进行经济可行性分析研究,经济所用部分主要可以分为三个部分,其分别是软件在前期进行开发,所需要的硬件设施和后期的运行维护。11。软件在前期进行开发:全部过程都由一个人进行操作,计划出每天的工作量然后按照计划完成,人工费可以降至最低,而且技术上无需任何第三方的帮助,也不需要任何费用。所需要的硬件设施:必须要有一台性能可以保证相关测试能顺利进行的电脑。系统所需后期的运行维护:当系统成功上线后,独立的域名和服务器主机都是必不可少的,这些都必须要进行购买。对相关所需成本进行大致估算,各个部分所需的预算如下表所示:3.3.3 操作可行性本平台采用的是服务器和网站的架构,对于刚使用该平台的人员,熟悉电脑操作即可,并且在开发完成之后会附增使用说明,让用户和管理者更加快捷使用。4 系统设计4.1 概要设计我们所设计的这个校园交易平台在其结构上进行分类大体上可以分为两个部分,分别是用户所用的客户端和管理员所使用的后台,这两方面中客户端是较为主要的,在这个的基础上进行各方面的延伸,路由接口的设计,网站的页面的设计和数据库的设计是最主要的三个方面,我们将从这三个方面进行概述。(1) 在对平台路由的设计过程中,经过慎重考虑,我们所选择的是RESTful的 设计风格,主要是因为其简洁明了的设计,能够让用户有更好的体验感。(2) 归根到底平台最主要的目的就是为用户提供便利,以实用为主,UI设计简洁,让人焕然一样,同时彰显自己的特色风格。(3) 是我们所选用的管理系统,在不同情况下建立不同的数据库。4.2 页面设计我们所设计平台的初衷是给用户提供各种方便的服务,让用户有更好地用户体验,因此前端设计是十分重要的,是影响用户体验感十分重要的一个环节,基于以上要求进行综合考虑,我们最后决定使用这一项技术。4.3 数据库设计4.3.1 数据库概念结构设计数据概念结构设计对于整个数据库是来说是十分重要的,因此我们必须对其十分重视,通过各种各样的方式对用户所有的需求进行归纳总结统一,只有经过这样的处理我们才能更加深刻全面的了解用户需求,才能更好地满足各种各样的用户不同的需求。对平台进行分类是十分重要的一步,业界都将其称为平台的逻辑结构,平台会被其分类成为好几部分,分类后的部分各有各的功能,最后我们依据得到的ER图来确定平台的数据模型,将实体之间的关系关联转换成为数据库中的数据模型。图4-1 系统数据库概念设计图4.3.2 数据库逻辑结构设计本平台所选用的系统是,与此同时可以根据相关的数据库,由此可以有效地避免数据库被不良数据污染,为了避免这种情况,有些原则是必须要遵循的:在对数据库的结构进行分析的工程中,表的设计是特别重要的,切记不可使用过于冗长的字段,否则表与表之间会出现耦合的现象,这是一个非常不好的现象。13在对表设计的过程中,我是亲力亲为的,在对表设计的过程中我取得了三个重要的结论,呢就是可以通过添加一些无关的语句段落,这样可以有效地降低设计过程中的复杂度。14数据库的表结构如下:U_EMAILvarchar(32)NULLU_addressvarchar(200)NULLU_postalcodeInt(11)NULLU_codetypevarchar(10)NULLU_codenumbervarchar(50)NULLU_PUESITIONvarchar(100)NULLU_ISLOCKintNULLU_CODENAMEvarchar(32)NULL表4.2 商品信息表C_SUBTITLEvarchar(200)NULLC_MAINIMAGEvarchar(500)NULLC_IMAGESvarchar(500)NOT NULLC_DETAILvarchar(1000)NULLisdelvarchar(20)NULLC_ORIGINALDecimal(20)NULLC_PRICEDecimal(20)NULLC_DEGREEvarchar(32)NULLC_STOCKvarchar(11)NULLC_STATUSint(6)NULL表4.3 订单信息表U_USERNAMEvarchar(32)NULLU_PHONEvarchar(11)NULLU_addressvarchar(200)NULLO_NUMBERint(11)NULLO_PRICEdecima(20)NULLO_PAYMENTvarchar(32)NULLO_PAYMETHODvarchar(32)NULLO_PAYTIMEdatetimeNULLO_ORDERNUMvarchar(32)NULLR_ADDCITYvarchar(50)NULLR_ADDRESSvarchar(255)NULLR_ISDEFAULTint(11)NULLR_DATEFLAGint(11)NULLR_CREATETIMEdate(0)NULLR_ADDAREAvarchar(50)NULLD_CONTENTvarchar(255)NULLD_FATHERIDint(11)NULLD_SONIDint(11)NULLD_RELTIMEdatetimeNULLADMIN_PHONEvarchar(32)NULLADMIN_QUESITIONvarchar(100)NULLADMIN_ANSWERvarchar(100)NULL5 系统实现本章节为论文的第五部分,主要对本次设计的系统进行全面解释,侧重于实现过程与实现方法,并对整个网站的各个功能模块进行对应说明。5.1 网站前台设计与实现本次设计的网站运用了的相关知识及功能,并以此为基础完成网页的设计实现,总体架构采用的是模式,这是一种分层架构模式。首先,我对本系统的网站前台进行了设计实现。网页前台主要是负责面向用户实现功能呈现,其中包括:注册、登录等,在整个系统中网页前台划分在系统用户模块。除此之外,网页前台还要为用户提供:商品展示(分类、详情)、购物车、下单、实时互动交流、用户间分享等多种功能。5.1.1 用户登录模块实现了网页前台的设计,就可以进一步完善用户登录模块的实现。一般来说,网页用户想要进行登陆操作都要进行以下这些操作:一是确认用户向网页中输入的整体内容是否准确无误,即验证信息是否存在;二是借助编写好的相关程序对用户输入的信息进行传输,确保后台能够准确接收到用户信息;三是后台程序接受到用户信息后,根据关键信息查询用户数据库。如果能够找到与用户信息完全相同的数据,就将用户密码进行比对,如果密码正确无误就返回成功,并且实现用户的登陆操作,向用户显示个人主页界面,如果没有在用户数据库中查找到输入的用户数据,直接返回错误,并向用户显示账号密码错误的界面。图5-1就是登录界面。图5-1用户登录界面网站主要采用响应式布局的方式,使用ajax异步请求,实现了用户登录的反馈信息。核心代码如下:RequestMapping(value = "login.action") public String login(RequestParam("U_PHONE") String U_PHONE,RequestParam("U_PASSWORD") String U_PASSWORD, User user, HttpServletRequest request, HttpSession session,Model model) String u_phone = request.getParameter("U_PHONE"); user.setU_PHONE(u_phone); user.setU_PASSWORD(u_password); user = this.userService.dologin(user); if (user !=null) session.setAttribute("user",user); return "forward:/" else System.out.println("未查询到信息!"); model.addAttribute("errorMSG","账号错误或密码错误!请重新输入"); return "forward:/login" 5.1.2 用户注册模块用户注册时首先填写个人基本信息,之后同意条款后平台向用户手机发送用户注册的验证码,通过验证后验证用户的身份信息,并完成注册。完成注册的账号才能使用该平台。在注册的过程中,平台首先对比用户的手机信息,如果与数据库中的手机号匹配,则改手机号已被其他用户注册,则不可以在进行注册操作。图5-2显示的就是注册界面。注册功能的实现使用了阿里云短信功能支撑,当用户在注册时收到短信后,输入正确的验证码才可以入驻本平台。核心代码如下:public static String getCode() StringBuilder sb = new StringBuilder(); for (int i = 0; sb.length() < 6; i+) int num = new Random().nextInt(10); sb.append(num); return sb.toString(); RequestMapping(value = "/checkPhoneCode") public Integer checkPhoneCode(RequestParam("verifyCode") String verifyCode,HttpSession session) System.out.println(verifyCode); System.out.println(session.getAttribute("Checkphonecode"); if (verifyCode.equals(session.getAttribute("Checkphonecode") System.out.println("相等!"); return 1; else System.out.println("不相等!"); return 0; 5.1.3 商品模块商品显示信息时的控制层代码是先通过服务层方法findAll ()访问持久层,并通过该操作对全部的信息列表进行搜寻,接下来借助域对象在用户页面循环展示查找到相关商品的数据信息。图5-3显示的就是用户浏览商品信息时的界面。商品信息展示部分包括两个小模块,即:用户操作使用的模块和管理员操作使用的模块。在用户操作使用模块中,商品按照瀑布流模式展示出来。商品展示页面中的商品均是商户们上传的商品信息、管理员上传的商品信息。商户上传的商品必须由管理员审核后方可上架,如果商品审核不通过则给商户反馈信息,商户可以进行删除和重新上架申请。核心代码如下:/ 查询商品表格所有数据 RequestMapping("/AllProduct") ResponseBody public String AllProduct() JSONObject jsonObject = new JSONObject(); List<Product> AllProduct = productService.tofindAllProduct(); jsonObject.put("rows",AllProduct); return jsonObject.toJSONString(); / 添加商品信息 RequestMapping("/addProduct") public ModelAndView addProduct(RequestParam("file") MultipartFile file,HttpServletRequest request,HttpSession session) throws IOException ModelAndView mav = new ModelAndView(); Admin admin = (Admin) session.getAttribute("admin"); Product product = new Product(); int i =productService.toAddProduct(product); mav.setViewName("Back-stageManagement/CommodityManagement"); return mav; / 更新商品信息 RequestMapping("/updateProduct") public ModelAndView SelectOne(ModelAttribute("product") Product product,HttpServletRequest request) int success = productService.doUpdateByPrimaryKey(product); mav.setViewName("Back-stageManagement/CommodityManagement"); return mav; / 所有商品 / 审核的商品页面跳转 / 审核通过 RequestMapping("/ExaminePass") public ModelAndView ExaminePass(RequestParam("c_ID") Integer C_ID,Product product) int success = productService.doexaminePass(product); mav.setViewName("Back-stageManagement/ExamineProduct"); return mav; 5.1.4 用户订单模块用户只要在平台中购物就会产生一个订单信息,并且存储到数据库中,Dion用户可以在个人中心查看自己的订单信息,在卖家处也会生成一个订单,该订单则是购买产品的用户信息,卖家根据自己的订单发货,最终完成商品交易。图5-4所显示的就是用户浏览订单信息的界面。用户登陆后可以访问个人中心,里面会包含有订单详情,这里显示的是全部的用户订单,其中包括已付款和未付款,未付款订单点击可以继续付款。已付款商品则跳转至订单详情页面,查看订单的详细信息。核心代码如下:Model model, Integer CID = Integer.valueOf(C_ID); if (session.getAttribute("user") = null) mav.setViewName("login"); else / 查询收货地址 List<UserAddress> userAddresses = userAddressService.findUserAddress(U_USERID); model.addAttribute("UserAddress", userAddresses);/ 从商品表中查询商品信息 model.addAttribute("Product", product); mav.setViewName("CHpay"); return mav; / 用户全部订单查询 页面跳转 并且查询所有信息 List<OrderDetail> orderDetails=orderTableService.toOrderAndPro(U_USERID) model.addAttribute("orderDetails", orderDetails); mav.setViewName("PersonInfo/Allorders"); return mav; / 查询用户当前的所有订单信息 public String AllOrdersTable(HttpSession session) JSONObject jsonObject = new JSONObject(); = user.getU_USERID(); List<Ordertables> ordertables = orderTableService.tofindAllOrders(userid) jsonObject.put("rows", ordertables); return jsonObject.toJSONString(); 5.1.5 用户购物车模块平台中的购物车功能实现,用户可以在商品详细情况页面把商品加入购物车,如果商品库存不够,会提示用户商品暂时缺货,在为缺货的状态下点击结算跳转支付页面。用户购物车页面如下图5-5所示。图5-5 用户购物车界面5.1.6 需求广场模块用户在需求广场模块可以查阅其他用户发布的需求告知,也可以对其他用户的需求进行回复,回复之后发布需求者可以查看到评论内容。可以针对相应的需求发布商品。有效的利用自己的闲置物品。同样用户在进行登录完成后可以在需求广场上发布自己的所需告示。在我的需求中可以对自己发布过的需求文档进行删除操作。需求广场如下图5-6所示。图5-6 需求广场界面需求广场的加入能更加贴近大学生们的生活,通过供求关系来达成闲置物品的交易。能解决相对于盲目上线商品的问题。核心代码如下:/ 当前用户发布需求 RequestMapping("/addDemand") ResponseBody public int AddDemand(HttpSession session, HttpServletRequest request, Demand demand) = user.getU_USERID(); String UserName = user.getU_USERNAME(); String DemandContent =request.getParameter("DemandContent"); int success = demandService.addDemand(demand); return 1; / 我发布的需求 RequestMapping("/MyDemand") Integer userid = user.getU_USERID(); List<Demand> demands = demandService.tofindByUserID(userid); model.addAttribute("demands",demands); mav.setViewName("/Demand/MyDemand"); return mav; / 回复评论 RequestMapping("/ReplyComments") ResponseBody public int ReplyComments(RequestParam("D_FATHERID") String USERNAME = user.getU_USERNAME(); int success = demandService.addDemand(demand); return success; 5.1.7 申请商家模块用户在注册平台账号之后,可以通过个人中心的申请为商家向平台申请上架商品的权限。在本过程中预保留了学生认证的接口来实现学生认证。学生需填写对应的姓名和学生证号来认证自己的学生信息。后台管理员在用户管理的商户管理下可以查看对应账号申请的个人信息。通过后即可使用商家功能实现商品的上传。申请为商家模块如下图5-7所示。图5-7 申请为商家界面用户在该模块实现了自己也可以上传商品信息,并且通过审核后直接上架到平台上面。商品如被购买,金钱直接流入平台账上,买家确认收货后可以将金钱转至用户的账户上。相关代码:/ 申请为商家 ApplyMer(RequestParam("E_USERID") Integer E_USERID) ModelAndView mav = new ModelAndView();/ 查询是否正在申请商家 如果不是 则显示/PersonInfo/ApplyMer 如果是 则显示 管理员正在审核请稍后 如果已经是商家了 则再个人中心显示为 商家服务再说 List<Examine> success = examineService.forExitApply(E_USERID); System.out.println(success); if (success.size()!=0)/ 就是正在申请 mav.setViewName("/PersonInfo/InProcessing"); else / 就是没有申请 mav.setViewName("/PersonInf