基于ssm写一个外卖后台管理系统
时间: 2023-12-07 19:03:12 浏览: 159
好的,下面是基于SSM框架的外卖后台管理系统的搭建步骤:
1.环境准备
- JDK 1.8+
- MySQL 5.6+
- Maven 3.0+
- Tomcat 7+
2.创建项目
在Eclipse中创建一个Maven项目,选择Web应用类型,然后勾选上Create a simple project(不需要生成web.xml文件)。
3.添加依赖
在pom.xml文件中添加以下依赖:
```
<!-- Spring -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>4.3.10.RELEASE</version>
</dependency>
<!-- Spring MVC -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>4.3.10.RELEASE</version>
</dependency>
<!-- MyBatis -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.4.1</version>
</dependency>
<!-- MySQL -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.47</version>
</dependency>
<!-- JSTL -->
<dependency>
<groupId>jstl</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<!-- Servlet API -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
<scope>provided</scope>
</dependency>
<!-- JSP API -->
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.0</version>
<scope>provided</scope>
</dependency>
```
4.配置数据库
在src/main/resources目录下创建一个名为jdbc.properties的文件,用于存储数据库连接信息:
```
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/food_delivery?useUnicode=true&characterEncoding=utf8
jdbc.username=root
jdbc.password=123456
```
其中jdbc.url的连接地址需要根据自己的数据库信息进行修改。
5.配置Spring
在src/main/resources目录下创建一个名为applicationContext.xml的文件,用于配置Spring的相关信息:
```
<!-- 数据源配置 -->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="${jdbc.driver}" />
<property name="url" value="${jdbc.url}" />
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
</bean>
<!-- MyBatis配置 -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="mapperLocations" value="classpath*:com/xxx/mapper/*.xml" />
</bean>
<!-- 扫描Mapper接口 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.xxx.mapper" />
</bean>
```
6.配置Spring MVC
在src/main/resources目录下创建一个名为springmvc-servlet.xml的文件,用于配置Spring MVC的相关信息:
```
<!-- 开启Spring MVC注解 -->
<mvc:annotation-driven />
<!-- 静态资源访问 -->
<mvc:resources mapping="/static/**" location="/static/" />
<!-- 视图解析器 -->
<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/views/" />
<property name="suffix" value=".jsp" />
</bean>
<!-- 扫描Controller -->
<context:component-scan base-package="com.xxx.controller" />
```
7.创建实体类
在src/main/java目录下创建一个名为com.xxx.entity的包,用于存放实体类。例如,可以创建一个名为Food的实体类:
```
public class Food {
private int id;
private String name;
private double price;
// 省略getter和setter方法
}
```
8.创建Mapper接口
在src/main/java目录下创建一个名为com.xxx.mapper的包,用于存放Mapper接口。例如,可以创建一个名为FoodMapper的接口:
```
public interface FoodMapper {
List<Food> findAllFoods();
Food findFoodById(int id);
void insertFood(Food food);
void updateFood(Food food);
void deleteFood(int id);
}
```
9.创建Mapper映射文件
在src/main/resources目录下创建一个名为com/xxx/mapper的包,用于存放Mapper映射文件。例如,可以创建一个名为FoodMapper.xml的文件:
```
<mapper namespace="com.xxx.mapper.FoodMapper">
<select id="findAllFoods" resultType="com.xxx.entity.Food">
select * from food
</select>
<select id="findFoodById" parameterType="int" resultType="com.xxx.entity.Food">
select * from food where id = #{id}
</select>
<insert id="insertFood" parameterType="com.xxx.entity.Food">
insert into food(name, price) values(#{name}, #{price})
</insert>
<update id="updateFood" parameterType="com.xxx.entity.Food">
update food set name = #{name}, price = #{price} where id = #{id}
</update>
<delete id="deleteFood" parameterType="int">
delete from food where id = #{id}
</delete>
</mapper>
```
10.创建Controller
在src/main/java目录下创建一个名为com.xxx.controller的包,用于存放Controller。例如,可以创建一个名为FoodController的Controller:
```
@Controller
@RequestMapping("/food")
public class FoodController {
@Autowired
private FoodMapper foodMapper;
@RequestMapping("/list")
public String list(Model model) {
List<Food> foods = foodMapper.findAllFoods();
model.addAttribute("foods", foods);
return "food/list";
}
@RequestMapping("/toAdd")
public String toAdd() {
return "food/add";
}
@RequestMapping("/add")
public String add(Food food) {
foodMapper.insertFood(food);
return "redirect:/food/list";
}
@RequestMapping("/toEdit")
public String toEdit(int id, Model model) {
Food food = foodMapper.findFoodById(id);
model.addAttribute("food", food);
return "food/edit";
}
@RequestMapping("/edit")
public String edit(Food food) {
foodMapper.updateFood(food);
return "redirect:/food/list";
}
@RequestMapping("/delete")
public String delete(int id) {
foodMapper.deleteFood(id);
return "redirect:/food/list";
}
}
```
11.创建JSP页面
在WebContent/WEB-INF/views目录下创建JSP页面。例如,可以创建一个名为list.jsp的页面:
```
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
<title>Food List</title>
</head>
<body>
<h1>Food List</h1>
<table>
<tr>
<th>ID</th>
<th>Name</th>
<th>Price</th>
<th>操作</th>
</tr>
<c:forEach items="${foods}" var="food">
<tr>
<td>${food.id}</td>
<td>${food.name}</td>
<td>${food.price}</td>
<td>
<a href="${pageContext.request.contextPath}/food/toEdit?id=${food.id}">编辑</a>
<a href="${pageContext.request.contextPath}/food/delete?id=${food.id}">删除</a>
</td>
</tr>
</c:forEach>
</table>
<br />
<a href="${pageContext.request.contextPath}/food/toAdd">添加</a>
</body>
</html>
```
12.运行项目
将项目部署到Tomcat中,启动Tomcat,访问http://localhost:8080/项目名/food/list即可看到外卖后台管理系统的列表页面。
阅读全文