SSM整合
1. 登录案例
1.1 创建实体类
@Repository public class User { private Integer uid; private String userName; private String password; private String realName; public Integer getUid() { return uid; } public void setUid(Integer uid) { this.uid = uid; } public String getUserName() { return userName; } public void setUserName(String userName) { this.userName = userName; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } public String getRealName() { return realName; } public void setRealName(String realName) { this.realName = realName; } }
1.2 编写Dao层接口
public interface UserDao { //登录 public User Login(@Param("userName") String userName, @Param("password") String password); }
1.3 编写小配置文件
<mapper namespace="com.invoicing.dao.UserDao"> <select id="Login" resultType="com.invoicing.entity.User"> select * from users where userName=#{userName} and password=#{password} </select> </mapper>
1.4 编写application-mybatis.xml文件
<!--加载属性文件--> <bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="locations" > <array> <value>classpath*:*.properties</value> </array> </property> </bean> <!--DataSource--> <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <property name="driverClassName" value="${jdbc.driver}"></property> <property name="url" value="${jdbc.url}"></property> <property name="username" value="${jdbc.username}"></property> <property name="password" value="${jdbc.password}"></property> </bean> <!--SessionFactory--> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource"></property> <!-- <property name="mapperLocations" value="classpath*:com/invoicing/dao/*.xml"></property>--> <property name="configLocation" value="classpath:config.xml"></property> </bean> <!--包扫描--> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="com.invoicing.dao"></property> </bean> <!--事务管理器--> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource"></property> </bean> <!--开启事务注解配置--> <tx:annotation-driven/> <context:annotation-config/> <context:component-scan base-package="com.invoicing"></context:component-scan>
1.5 编写Config.xml文件
<settings> <setting name="logImpl" value="LOG4J"/> </settings> <!-- 引入 pageHelper插件 --> <!--注意这里要写成PageInterceptor, 5.0之前的版本都是写PageHelper, 5.0之后要换成PageInterceptor--> <plugins> <plugin interceptor="com.github.pagehelper.PageHelper"></plugin> </plugins> <mappers> <package name="com.invoicing.dao"/> </mappers>
1.6 编写jdbc.properties
jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://localhost:3306/invoicingsystem?useUniCode=true&characterEncoding=utf-8 jdbc.username=root jdbc.password=123
1.7编写Spring-mvc.xml文件
<!--推荐使用注解方式--> <!--配置视图解析器 --> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/jsp/"></property> <!--return "index"======>/jsp/index.jsp--> <property name="suffix" value=".jsp"></property> </bean> <!--开启MVC的注解配置--> <mvc:annotation-driven/> <!--包扫描器:扫描 MVC中的注解--> <context:component-scan base-package="com.invoicing"/> <mvc:default-servlet-handler/>
1.7 编写web.xml文件
<servlet> <servlet-name>SpringMVC</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <!--读取spring-mvc.xml文件--> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:spring-mvc.xml</param-value> </init-param> </servlet> <servlet-mapping> <servlet-name>SpringMVC</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> <!--spring和MyBatis整合的核心配置--> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath*:application-*.xml</param-value> </context-param> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener>
1.8 编写Service层接口
public interface UserService { //登录 public User Login(@Param("userName") String userName, @Param("password") String password); }
1.9 编写Service层接口实现类
@Service("userService") public class UserServiceImpl implements UserService { @Autowired UserDao userDao; @Override public User Login(String userName, String password) { return userDao.Login(userName,password); } }
1.10 编写Contrller层
@Controller @RequestMapping("/user") public class UserController { @Resource UserService userService; @RequestMapping("/login") @ResponseBody public ModelAndView login(String userName, String password, HttpServletResponse respones,HttpServletRequest request, ModelAndView mv){ System.out.println(userName+"\t"+password); User login = userService.Login(userName, password); if (login!=null){ System.out.println("登陆成功"); request.getSession().setAttribute("login",login); mv.setViewName("index"); }else { mv.setViewName("login"); } return mv; } }
1.11 编写过滤器实现非法拦截
@WebFilter(urlPatterns = {"/*"}) public class LoginFilter implements Filter { @Override public void init(FilterConfig filterConfig) throws ServletException { } @Override public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException { System.out.println("======过滤器===="); HttpServletRequest request=(HttpServletRequest) servletRequest; if(request.getRequestURI().equals("/user/login")){ filterChain.doFilter(servletRequest,servletResponse); } Object login = request.getSession().getAttribute("login"); if (login==null){ request.getRequestDispatcher("/jsp/login.jsp").forward(servletRequest,servletResponse); }else{ filterChain.doFilter(servletRequest,servletResponse); } } @Override public void destroy() { } }