`

03 整合IDEA+Maven+SSM框架的高并发的商品秒杀项目之web层

 
阅读更多

Github:https://github.com/nnngu
项目源代码:https://github.com/nnngu/nguSeckill


前端交互流程设计

对于一个系统,需要产品经理、前端工程师和后端工程师的参与,产品经理将用户的需求做成一个开发文档交给前端工程师和后端工程师,前端工程师为系统完成页面的开发,后端工程师为系统完成业务逻辑的开发。对于我们这个秒杀系统,它的前端交互流程设计如下图:

这个流程图就告诉了我们详情页的流程逻辑,前端工程师根据这个流程图设计页面,而我们后端工程师根据这个流程图开发我们对应的代码。前端交互流程是系统开发中很重要的一部分,接下来进行Restful接口设计的学习。

Restful接口设计学习

什么是Restful?它就是一种优雅的URL表述方式,用来设计我们资源的访问URL。通过这个URL的设计,我们就可以很自然的感知到这个URL代表的是哪种业务场景或者什么样的数据或资源。基于Restful设计的URL,对于我们接口的使用者、前端、web系统或者搜索引擎甚至是我们的用户,都是非常友好的。关于Restful的了解大家去网上一搜一大把,我这里就不再做介绍了。下面看看我们这个秒杀系统的URL设计:

接下来基于上述资源接口来开始对Spring MVC框架的使用。

配置Spring MVC框架

web.xml文件里面引入DispatcherServlet

web.xml里面的代码请参照项目的源代码。

添加 applicationContext-web.xml

添加 applicationContext-web.xml,在下图所示的位置。

applicationContext-web.xml里面的代码请参照项目的源代码。

这样我们便完成了Spring MVC的相关配置(即将Spring MVC框架整合到了我们的项目中),接下来就要基于Restful接口进行我们项目的控制器 SeckillController 的开发工作了。

编写 SeckillController

控制器中的每一个方法都对应我们系统中的一个资源URL,其设计应该遵循Restful接口的设计风格。

创建控制器SeckillController.java,如下图:

SeckillController.java里面的代码请参照项目的源代码。

SeckillController.java中的方法完全是对照Service接口方法进行开发的,第一个方法用于访问我们商品的列表页,第二个方法访问商品的详情页,第三个方法用于返回一个json数据,数据中封装了我们商品的秒杀地址,第四个方法用于封装用户是否秒杀成功的信息,第五个方法用于返回系统当前时间。代码中涉及到一个将返回秒杀商品地址封装为json数据的类,即SeckillResult,在dto包中创建它,如下:

建立一个全局ajax请求返回类,返回json

创建SeckillResult.java,如下图:

SeckillResult.java里面的代码请参照项目的源代码。

到此,控制器的开发任务完成,接下来进行我们的页面开发。

页面的编写

项目的前端页面是由Bootstrap开发的,所以我们要先去下载Bootstrap或者是使用在线CDN。

使用在线CDN的方法:

<!-- Bootstrap 核心 CSS 文件 -->
<link rel="stylesheet" href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">

<!-- 可选的 Bootstrap 主题文件(一般不用引入) -->
<link rel="stylesheet" href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap-theme.min.css" integrity="sha384-rHyoN1iRsVXV4nD0JutlnGaslCJuC7uwjduW9SVrLvRYooPp2bWYgmgJQIXwl/Sp" crossorigin="anonymous">

<!-- Bootstrap 核心 JavaScript 文件 -->
<script src="https://cdn.bootcss.com/bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha384-Tc5IQib027qvyjSMfHjOMaLkfuWVxZxUPnCJA7l2mCWNIpG9mGCD8wGNIcPD7Txa" crossorigin="anonymous"></script>

为了方便我们本地调试,我在项目里使用的是本地的Bootstrap

步骤:

  1. 下载JQuery,因为Bootstrap就是依赖JQuery

  2. 下载Bootstrap

  3. 下载一个倒计时插件jquery.countdown.min.js ,再下载一个操作Cookie插件jquery.cookie.min.js 如图放置:

  1. 编写一个公共的头部jsp文件,位于WEB-INF/jsp/common下的head.jsp,如下图:

head.jsp里面的代码请参照项目的源代码。

  1. 编写一个公共的jstl标签库文件tag.jsp,在下图所示的位置。

tag.jsp里面的代码请参照项目的源代码。

  1. 编写列表页面list.jsp,在下图所示的位置。

list.jsp里面的代码请参照项目的源代码。

  1. 编写秒杀详情页面detail.jsp,在下图所示的位置。

detail.jsp里面的代码请参照项目的源代码。

添加 seckill.js 文件

添加 seckill.js 文件,在下图所示的位置。

seckill.js 里面的代码请参照项目的源代码。

运行项目

运行项目,部署到tomcat,在浏览器地址栏输入 http://localhost:8080/seckill/list,敲回车,即可看到如下图的界面:

点击相应商品后面的详情页链接即可查看该商品是否开启秒杀、以及秒杀该商品等活动。

到此,我们成功完成了web层的开发。但一个秒杀系统,往往是会有成千上万的人进行参与,我们目前的系统是抗不起多少高并发操作的,所以后面我们会对本系统进行高并发的优化。请查看我的下一篇文章。

下一篇:04 Java高并发秒杀项目之高并发优化

0
1
分享到:
评论

相关推荐

    基于IDEA+Maven+SSM框架+mysql的高并发的商品秒杀项目.zip

    基于IDEA+Maven+SSM框架+mysql的高并发的商品秒杀项目.zip基于IDEA+Maven+SSM框架+mysql的高并发的商品秒杀项目.zip基于IDEA+Maven+SSM框架+mysql的高并发的商品秒杀项目.zip基于IDEA+Maven+SSM框架+mysql的高并发的...

    整合IDEA+Maven+SSM框架商品秒杀项目

    【标题】"整合IDEA+Maven+SSM框架商品秒杀项目"是一个基于Java的电商项目,旨在演示如何在IntelliJ IDEA(IDEA)集成开发环境中,使用Maven构建工具以及Spring、SpringMVC和MyBatis(SSM)经典企业级开发框架来实现...

    SpringMVC精品资源-- 整合IDEA+Maven+SSM框架的高并发的商品秒杀项目.zip

    【SpringMVC精品资源——整合IDEA+Maven+SSM框架的高并发商品秒杀项目】 本资源包是针对SpringMVC框架的深入学习,它涵盖了如何在IntelliJ IDEA(IDEA)中整合Maven构建工具以及Spring、SpringMVC、MyBatis(SSM)...

    基于IDEA+Maven+SSM框架+mysql的高并发商品秒杀项目源码+数据库+项目说明.zip

    1、基于IDEA+Maven+SSM框架+mysql的高并发商品秒杀项目源码+数据库+项目说明.zip 2、该资源包括项目的全部源码,下载可以直接使用! 3、本项目适合作为计算机、数学、电子信息等专业的课程设计、期末大作业和毕设...

    整合IDEA+Maven+SSM框架的高并发的商品秒杀项目.zip

    SSM框架学习宝典:入门、进阶、精通,全方位代码项目资 一、探索SSM的无限可能 SSM(Spring + Spring MVC + MyBatis)框架作为Java开发中的黄金组合,为开发者提供了强大的技术支持和丰富的功能。本系列资料将带您...

    基于IDEA+Maven+SSM框架+mysql的高并发的商品秒杀项目

    毕设课题:基于IDEA+Maven+SSM框架+mysql的高并发的商品秒杀项目 本资源中的源码都是经过本地编译过可运行的,下载后按照文档配置好环境就可以运行。资源项目源码系统完整,内容都是经过专业老师审定过的,基本...

    idea+maven+空SSM框架

    总结起来,使用IDEA和Maven创建SSM框架涉及了项目创建、依赖管理、框架配置、目录结构设计、各层代码编写等多个环节。了解并掌握这些步骤,可以为Java Web开发打下坚实的基础。而SSO的实现则需要进一步学习相关认证...

    IDEA+MAVEN+SSM框架 超市管理系统

    【标题】"IDEA+MAVEN+SSM框架 超市管理系统"涉及的主要知识点是Java开发中的集成开发环境IntelliJ IDEA、项目构建工具Maven以及Spring、SpringMVC和MyBatis(SSM)这三大核心框架的集成与应用。这个超市管理系统是一...

    基于IDEA+MySQL+Maven实现SSM框架整合

    基于IDEA+MySQL+Maven实现SSM框架整合,实现了多条件分页查询、新增、事务、自定义消息转换器、自定义编辑器、拦截器等功能 1. 数据库版本: mysql8.0.26 2. IDEA版本: idea2020 3. JDK版本: jdk1.8.1 4. Tomcat...

    IDEA+MAVEN+ssm框架的数据库增删查改以及用户登录

    IDEA+MAVEN基于ssm框架的数据库增删查改以及用户登录 详情可见博文:https://blog.csdn.net/weixin_42493072/article/details/94403204 开发工具:IntelliJ IDEA 2018、JDK1.8、tomcat 7.0.79、Mysql 5.0、Maven ...

    idea+maven+ssm

    以上就是关于"idea+maven+ssm"的详细知识点,涵盖了框架选择、项目构建、主要组件功能、集成开发环境的使用以及关键功能的实现。理解并熟练掌握这些知识点,将有助于提升Java web开发的效率和质量。

    idea+maven搭建SSM框架

    idea基于maven搭建SSM框架 JDK1.8 自带逆向生成 自带部分本人使用工具类,如MD5加密 对接安卓返回状态信息等 有问题欢迎密我 QQ 1916172575

    使用maven搭建的ssm框架

    SSM框架是由Spring、Spring MVC和MyBatis三个开源项目组成的集成框架,是Java Web开发中的主流选择。本文将详细讲解如何使用Maven构建工具来搭建一个基于SSM的项目。 首先,我们需要理解SSM框架的各个组成部分: 1...

    基于IDEA+Maven+SSM框架+mysql的高并发商品秒杀项目完整源码+数据库+说明.zip

    2、适用人群:主要针对计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、数学、电子信息等)的同学或企业员工下载使用,具有较高的学习借鉴价值。 3、不仅适合小白学习实战练习,也...

    idea+maven+ssm环境整合Demo

    在这个"idea+maven+ssm环境整合Demo"项目中,我们将探讨如何在IntelliJ IDEA(Idea)集成开发环境中,利用Maven构建工具来管理依赖,并实现SSM框架的集成与配置。 1. **Spring框架**:Spring是Java领域的一个全功能...

Global site tag (gtag.js) - Google Analytics