根据D49中所述,接下来的ssm整合都会用到父子模块。
注意事项:
service模块的pom.xml文件中需要导入
<dependency>
<groupId>com.zsl</groupId>
<artifactId>dao_ssm</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
</dependencies>
同理, web模块也需要导入service模块的相关信息。
目的: 依赖传递。service模块可以使用dao模块的信息,web模块可以使用service模块的信息。
搭建环境
web.xml
<!--编写编码过滤器-->
<filter>
<filter-name>characterEncodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>utf-8</param-value>
</init-param>
<init-param>
<param-name>forceEncoding</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>characterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<!--配置前端控制器-->
<servlet>
<servlet-name>dispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring-mvc.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>dispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
spring配置文件(在web.xml中)
<!--dao层开始-->
<!--配置spring的监听器-->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!---->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applicationContext.xml</param-value>
</context-param>
<!--dao层结束-->
spring-mvc.xml
<!--组件扫描-->
<context:component-scan base-package="com.zsl.controller"/>
<!--mvc注解支持-->
<mvc:annotation-driven />
<!--视图解析器-->
<bean id="internalResourceViewResolver"
class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/pages/"/>
<property name="suffix" value=".jsp"/>
</bean>
<!--是否静态资源-->
<mvc:default-servlet-handler/>
工程的目录结构
代码(一部分)
controller:
@RequestMapping(): 请求路径
@Autowired: 依赖注入(spring-mvc的组件扫描,会扫描到这里)
@Controller
@RequestMapping("/product")
public class ProductController {
@Autowired
private ProductService productService;
@RequestMapping("/findAll")
public String findAll(Model model) {
List<Product> list = productService.findAll();
System.out.println(11);
//把model放入到request域中
model.addAttribute("list", list);
System.out.println(list);
//指定视图
return "product-list";
}
ServiceImpl
@Service: 写在类上,将自动注册到Spring容器,不需要再在applicationContext.xml文件定义bean了
@Transactional: 开启事务的注解
@Service
@Transactional //开启事务的注解
public class ProductServiceImpl implements ProductService {
@Autowired
private ProductDao productDao;
@Override
public List<Product> findAll() {
System.out.println(111111);
return productDao.findAll();
}
dao层
@RequestMapping
public interface ProductDao {
@Select("select * from product")
List<Product> findAll();
}
日期的显示处理
处理方式
方式一【在页面上处理】
方式二:在后台处理
- 凡是日期或者状态等需要转换的字段,一般在pojo对象中都有提供两个属性,一个做数据库操作,一个做页面显示。
- 后台
product实体中
public String getDepartureTimeStr(){
return departureTime==null? "暂无出发时间":
new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(departureTime);
}
//用来显示状态
public String getProductStatusStr(){
return productStatus!=null && productStatus ==1 ? "开启":"关闭" ;
}
- 前台页面
释放静态资源
方式一
在springmvc的配置文件中
<!--是否静态资源-->
<mvc:default-servlet-handler/>
方式二
在springmvc的配置文件中配置
<mvc:resources mapping="" location="" />
方式三
在springmvc的配置文件中什么都不配置,
在web.xml中的前端控制器拦截的地址配置**.do** 或者**.action**
对日期进行特殊处理
方式一
springmvc默认只能解析2018/01/01 格式的日期,对2018-01-01格式的不能正常解析。
- 在pojo对象中添加注解
方式二
在处理器中添加日期特殊处理
@InitBinder
public void initBinder(WebDataBinder binder){
binder.registerCustomEditor(Date.class,new PropertyValuesEditor(){
/**
* @param text 需要转换的字符串
* @throws IllegalArgumentException
*/
public void setAsText(@Nullable String text) throws IllegalArgumentException {
Date date=null;
try {
date = new SimpleDateFormat("yyyy-MM-dd HH:mm").parse(text);
} catch (ParseException e) {
e.printStackTrace();
}
setValue(date);
}
});
}
路径问题
/*
在html中../表示当前路径的上一级,
在html中./和不写表示当前路径
在html中“${pageContext.request.contextPath}”
==java中的的第一个“/”
==java中的“http://localhost:8080/项目名”
return "redirect:/product/findAll";
*/
return "redirect:findAll";
批量删除
思路分析
让springmvc直接封装一个java数组到后台。
注意: 如果是form表单内的submit按钮, 点击后 表单直接就提交了,在这之前无法做 验证操作。此刻需要一个单独的按钮,点击按钮,先验证,在手动提交表单。
先把id放入一个from表单中
<form id="listForem"
action="${pageContext.request.contextPath}/product/delete">
给批量删除按钮绑定点击事件
<button type="button" class="btn btn-default" title="删除" onclick=formClick()>
<i class="fa fa-trash-o"></i> 删除
</button>
<script type="text/javascript">
function formClick() {
//获取当前复选框
var checkList = $("#dataList td input[type='checkbox']:checked");
//判断复选框的状态
if (checkList.size() > 0) {
if (confirm("你确认要删除吗?")) {
$("#listForem").submit();
}
} else {
alert("请选择你要删除的数据")
}
}
</script>
确认复选框是有值的
后台代码
编写处理器
@RequestMapping("/delete")
public String delete(String[] ids){
productService.delete(ids);
return "redirect:findAll";
}
编写service
@Override
public void delete(String[] ids) {
for (String id : ids) {
productDao.delete(id);
}
编写dao
@Delete("delete from product where id = #{id}")
void delete(String id);