用java编写商品购买系统_Java简易商品管理系统 SSM实现 源码下载

本文介绍了一个基于SSM(Spring+SpringMVC+MyBatis)实现的Java简易商品管理系统。系统使用Maven、Boostrap、MySQL,并通过PageHelper实现分页显示,涉及商品信息和种类表的关联查询。文章详述了系统功能,包括数据的增删改查,并讲解了JSR303验证、前端页面搭建和RESTful API设计。此外,还提供了源码下载链接。
摘要由CSDN通过智能技术生成

这是一个基于SSM实现的Java简易商品管理系统。

一个简单的商品管理的系统,使用的技术有:Maven+Spring+SpringMVC+MyBatis,前端框架boostrap。数据库使用mysql。

用到两个表:一个商品信息表,一个种类表。使用外键关联将两个表联结起来。

## 实现的功能

利用PageHelper插件分页显示数据

新增商品数据

其中商品名、货号需要检测格式是否符合要求以及数据库中是否存在,这里用到js正则表达式、JSR303。

修改商品信息

修改需要根据欲修改的商品'id'从数据库中查找,返回相应的信息

删除

删除可以删除单条商品数据,也可以多选删除

代码介绍

SSM整合

pom.xml文件管理项目依赖的jar包,各个包的作用见注释。

web.xml配置Spring、前端控制器、过滤器等。前端控制器的init-param属性指定SpringMVC配置文件的位置,可以删除(不指定),此时需在web.xml统计目录创建名为servlet-name属性值-servlet(如:dispatcherServlet-servlet.xml)的配置文件。

dispatcherServlet-servlet.xmlSpringMVC的配置文件,扫描注释为@controller的控制器,配置视图解析器等。

applicationContext.xmlSpring配置文件,配置数据库,与MyBatis整合,配置事务等,需扫描除控制器之外的文件。

mybatis-config.xml也可放在Spring的bean里。

MyBatis逆向工程

首先,在MySQL中新建数据库,然后建表,sql脚本也放在了项目中了。

新建一个generatorConfig.xml官方文档中有示例可直接复制过来,然后进行一些配置修改。

采用Java结合配置文件进行生成的方法,Java执行示例链接里面的代码可以直接拿过来,改下配置文件的路径、名字,直接运行即可。

完成后刷新,可看到文件已生成。

修改dao层文件

使用mybatis生成的文件不一定就能满足我们的需求,可以在其基础上进行更改,实现需要的功能。

此项目中,在查询商品时需要将种类表的信息也查询出来,这样才是完整信息。但是逆向工程只是生成单表操作,所以需要自己添加查询语句。

bean文件Products.java中添加种类字段信息private Category category;,并生成getter和setter

在ProductsMapper.java接口中添加两个方法selectByExampleWithCate和selectByPrimaryKeyWithCate,表示同时查询种类信息。

修改映射文件ProductsMapper.xml添加联表查询sql语句,详细代码见github仓库,比较简单,不必细说。

**需要注意的就是:**最一开始我没有在查询信息时排序,导致在页面插入商品时在最后找不到,仔细看了下,是插在了中间。也就是说没有按主键id排序,所以添加了如下代码:

order by e.pro_id

1

2

3

4

orderbye.pro_id

dao层测试

在com.nian.test包下新建一个类MapperTest.java,注解@RunWith(SpringJUnit4ClassRunner.class)表示是在Spring上下文中进行测试,@ContextConfiguration找到Spring配置文件

直接用@Autowired注入一个CategoryMapper。

再调用其方法insertSelective插入种类数据(为方便初始化数据,可以在bean里添加有参构造器,但同时要写上无参构造器)。

此时可以去数据库中查看是否已将数据添加,来检验到目前为止的工作是否正确。

成功显示数据。

插入商品数据测试:

利用for循环批量插入,使用UUID设置货号信息,保证随机性。

可以在Spring配置文件中配置一个批量执行任务的sqlSession,然后通过@Autowired注入。

页面搭建

使用boostrap框架的栅格系统,快速搭建好一个大致轮廓,根据使用手册慢慢弄,我写前端就是多试,多调,不断查看效果,满意为止。

前端的内容就不具体说明了,框架使用很简单。

功能实现

使用RESTful(表现层状态转化)风格的URI,将页面普通的post请求转为指定的delete或者put请求。

HTTP协议,是一个无状态协议。这意味着,所有的状态都保存在服务器端。因此,如果客户端想要操作服务器,必须通过某种手段,让服务器端发生"状态转化"(State Transfer)。而这种转化是建立在表现层之上的,所以就是"表现层状态转化"。

客户端用到的手段,只能是HTTP协议。具体来说,就是HTTP协议里面,四个表示操作方式的动词:GET、POST、PUT、DELETE。它们分别对应四种基本操作:GET用来查询商品数据,POST用来新建资源(也可以用于更新资源),PUT用来修改数据,DELETE用来删除商品。

页面获取数据的形式:客户端(浏览器等)向服务器发送ajax请求,然后服务端返回一个JSON,利用js解析JSON就可以获得我们需要的数据。下面详细说明

查询

查询时,首先访问index.jsp页面,页面会发送ajax请求查询数据,ProductsController接受请求,查出数据,转化为JSON格式传到页面,页面进行解析展示。

分页使用pageHelper插件,使用文档。

index.jsp发送ajax请求进行数据查询,服务端返回JSON,解析之后使用dom将数据填充到页面中或改变页面。

新建一个控制器ProductsController.java,编写方法

@RequestMapping("/pros")

@ResponseBody

public Msg getProductsWithJson(

@RequestParam(value = "pn", defaultValue = "1") Integer pn) {

// 利用PageHelper插件进行分页查询

// 输入页码以及每页的数据量

PageHelper.startPage(pn, 7);

// 这里顺序是不能乱的,必须先调用方法startPage然后在查询

List pros = productsService.getAll();

// 用pageInfo封装查询结果,然后将其传给页面

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值