JavaWeb学习笔记-spring-01-概述(实例)

简介

  • 模块
    • Core Container//核心容器
    • Core 基本核心工具类
    • Beans 访问文件配置,创建管理bean,IOC/DI
    • Context Beans扩展
    • Expression Language 查询、操作对象的语言模块
  • Data Access/Integration
    • JDBC JDBC
    • ORM 关系-对象映射
    • OXM OBJECT/XML映射
    • JMS 制造和消费消息
    • Transaction 支持编程和声明式事务
  • web
    • web web集成特性
    • web-servlet springMVC
    • web-struts struts支持
    • web-porlet porlet&web-servlet MVC实现
  • AOP//面向切面
    • Aspects Aspectj支持
    • Instrumentation 特定服务器使用
  • Test//junit和testNG测试

容器简单实例

//定义bean
public class MyTestBean {
    private String testStr = "testStr";

    public String getTestStr() {
        return testStr;
    }

    public void setTestStr(String testStr) {
        this.testStr = testStr;
    }
}

<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
       http://www.springframework.org/schema/beans/spring-beans.xsd">

    <bean id="myTestBean" class="spring.MyTestBean"/>

beans>

创建库表

mysql -uroot -proot
drop database if exists sampledb;
create database sampledb default characterset utf8;
use sampledb;

create table t_user(
    user_id int auto_increment primary key,
    user_name varchar(30),
    password varchar(32),
    last_visit datetime,
    last_ip varchar(32)
)engine=innodb;
###创建用户登录日志表
create table t_login_log(
    login_log_id int auto_increment primary key,
    user_id int,
    ip varchar(23),
    login_datetime datetime
)engine=innodb;

插入初始化数据

insert into t_user (user_name,password) values('admin','123456');
commit;

pom.xml

<properties>
    <file.encoding>UTF-8file.encoding>
    <java.version>1.6java.version>
    <org.springframework.version>3.1.1.RELEASEorg.springframework.version>
    <mysql>5.1.6mysql>
    <commons-dbcp.version>1.4commons-dbcp.version>
properties>

<dependency>
    <groupId>org.springframeworkgroupId>
    <artifactId>spring-beansartifactId>
    <version>${org.springframework.version}version>
dependency>
<dependency>
    <groupId>org.springframeworkgroupId>
    <artifactId>spring-jdbcartifactId>
    <version>${org.springframework.version}version>
dependency>
<dependency>
    <groupId>org.springframeworkgroupId>
    <artifactId>spring-webartifactId>
    <version>${org.springframework.version}version>
dependency>
<dependency>
    <groupId>org.springframeworkgroupId>
    <artifactId>spring-webmvcartifactId>
    <version>${org.springframework.version}version>
dependency>

<dependency>
    <groupId>mysqlgroupId>
    <artifactId>mysql_connector-javaartifactId>
    <version>${mysql.version}version>
dependency>

<dependency>
    <groupId>commons-dbcpgroupId>
    <artifactId>commons-dbcpartifactId>
    <version>${commons-dbcp.version}version>
dependency>
<dependency>
    <groupId>org.aspectjgroupId>
    <artifactId>aspectjweaverartifactId>
    <version>${aspectweaver.version}version>
dependency>
<dependency>
    <groupId>org.apache.commonsgroupId>
    <artifactId>com.springsource.org.apache.commons.loggingartifactId>
    <version>${apache.commons.version}version>
dependency>
<dependency>
    <groupId>fakepathgroupId>
    <artifactId>com.springsource.net.sf.cglibartifactId>
    <version>1.1.3verison>
dependency>

<dependency>
    <groupId>javax.servlet.jspgroupId>
    <artifactId>jsp-apiartifactId>
    <version>${jsp-api.version}version>
    <scope>providedscope>
dependency>
<dependency>
    <groupId>taglibsgroupId>
    <artifactId>standardartifactId>
    <version>${standard.version}version>
    <scope>runtimescope>
dependency>
<dependency>
    <groupId>javax.servletgroupId>
    <artifactId>servelt-apiartifactId>
    <version>${servlet-api.version}verison>
dependency>
<dependency>
    <groupId>javax.servletgroupId>    
    <artifactId>jstlartifactId>
    <version>${jstl.version}version>
dependency>
//User
public class User implements Serializable {
    private int userId;
    private String userName;
    private String password;
    private String lastIp;
    private Date lastVisit;

    public int getUserId() {
        return userId;
    }

    public void setUserId(int userId) {
        this.userId = userId;
    }

    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 getLastIp() {
        return lastIp;
    }

    public void setLastIp(String lastIp) {
        this.lastIp = lastIp;
    }

    public Date getLastVisit() {
        return lastVisit;
    }

    public void setLastVisit(Date lastVisit) {
        this.lastVisit = lastVisit;
    }
}
//LoginLog
public class LoginLog implements Serializable{
    private int loginLogId;
    private int userId;
    private String ip;
    private Date loginDate;

    public int getLoginLogId() {
        return loginLogId;
    }

    public void setLoginLogId(int loginLogId) {
        this.loginLogId = loginLogId;
    }

    public int getUserId() {
        return userId;
    }

    public void setUserId(int userId) {
        this.userId = userId;
    }

    public String getIp() {
        return ip;
    }

    public void setIp(String ip) {
        this.ip = ip;
    }

    public Date getLoginDate() {
        return loginDate;
    }

    public void setLoginDate(Date loginDate) {
        this.loginDate = loginDate;
    }
}
@Repository
public class UserDao {
    @Autowired
    private JdbcTemplate jdbcTemplate;

    public int getMatchCount(String userName,String password){
        String sqlStr = " select count(*) from t_user where user_naem = ? and password = ?";
        return jdbcTemplate.queryForInt(sqlStr, new Object[]{userName, password});
    }
    public User findUserByUserName(final String userName){
        String sqlStr = "select user_id,user_name from t_user where user_name = ?";
        final User user = new User();
        jdbcTemplate.query(sqlStr, new Object[]{userName}, new RowCallbackHandler() {
            public void processRow(ResultSet rs) throws SQLException {
                user.setUserId(rs.getInt("user_id"));
                user.setUserName(userName);
            }
        });
        return user;
    }
    public void updateLoginInfo(User user){
        String sqlStr = "update user set last_visit = ? ,last_ip = ? where user_id = ?";
        jdbcTemplate.update(sqlStr,new Object[]{user.getLastVisit(),user.getLastIp(),user.getUserId()});
    }

}
@Repository
public class LoginLogDao {
    @Autowired
    private JdbcTemplate jdbcTemplate;
    public void insertLoginLog(LoginLog loginLog){
        String sqlStr = "insert into t_login_log(suer_id,login_datetime) values(?,?)";
        Object[] args = {loginLog.getUserId(),loginLog.getIp(),loginLog.getLoginDate()};
        jdbcTemplate.update(sqlStr,args);
    }
}

<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:p="http://www.springframework.org/schema/p"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
       http://www.springframework.org/schema/beans/spring-beans.xsd
       http://www.springframework.org/schema/context
       http://www.springframework.org/schema/spring-context.xsd">

    
    <context:component-scan base-package="spring.dao"/>
    
    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
            destroy-method="close" 
            p:driverClassName="com.mysql.jdbc.Driver"
            p:url="jdbc:mysql://localhost:3309/sample"
            p:username="root"
            p:password="root"/>
    
    <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"
            p:dataSource-ref="dataSource"/>    


    
    <bean id="myTestBean" class="spring.MyTestBean"/>

beans>
@Service
public class UserService {
    @Autowired
    private UserDao userDao;

    @Autowired
    private LoginLogDao loginLogDao;

    public boolean hasMatchUser(String userName,String password){
        int matchCount = userDao.getMatchCount(userName,password);
        return matchCount>0;
    }
    public User findUserByUserName(String userName){
        return userDao.findUserByUserName(userName);
    }
    public void loginSuccess(User user){
        LoginLog loginLog = new LoginLog();
        loginLog.setUserId(user.getUserId());
        loginLog.setIp(user.getLastIp());
        loginLog.setLoginDate(user.getLastVisit());
        loginLogDao.insertLoginLog(loginLog);
    }
}


<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:p="http://www.springframework.org/schema/p"
       xmlns:aop="http://www.springframework.org/schema/aop"
       xmlns:tx="http://www.springframework.org/schema/tx"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
       http://www.springframework.org/schema/beans/spring-beans.xsd
       http://www.springframework.org/schema/context
       http://www.springframework.org/schema/spring-context.xsd
       http://www.springframework.org/schema/aop
       http://www.springframework.org/schema/spring-aop.xsd
       http://www.springframework.org/schema/tx
       http://www.springframework.org/schema/spring-tex.xsd">



    
    <context:component-scan base-package="spring.dao"/>
    <context:component-scan base-package="spring.service"/>
    
    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
            destroy-method="close"
            p:driverClassName="com.mysql.jdbc.Driver"
            p:url="jdbc:mysql://localhost:3309/sample"
            p:username="root"
            p:password="root"/>
    
    <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"
            p:dataSource-ref="dataSource"/>

    
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"
            p:dataSource-ref="dataSource"/>
    
    <aop:config proxy-target-class="true">
        <aop:pointcut id="serviceMethod" expression="execution(* spring.service..*(..))"/>
        <aop:advisor advice-ref="txAdvice" pointcut-ref="serviceMethod"/>
    aop:config>
    <tx:advice id="txAdvice" transaction-manager="transactionManager">
        <tx:attributes>
            <tx:method name="*"/>
        tx:attributes>
    tx:advice>

    
    <bean id="myTestBean" class="spring.MyTestBean"/>

beans>
@ContextConfiguration(locations = "application-context.xml")
public class UserServiceTest extends AbstractTestNGSpringContextTests {

    @Autowired
    private UserService userService;

    @Test
    public void hashMatchUser(){
        boolean b1 = userService.hasMatchUser("admin","123456");
        boolean b2 = userService.hasMatchUser("admin","111");
        Assert.assertTrue(b1);
        Assert.assertTrue(!b2);
    }

    @Test
    public void findUserByUserName(){
        User user = userService.findUserByUserName("admin");
        Assert.assertEquals(user.getUserName(),"admin");
    }
}

<web-app version="2.5"
         xmlns="http://java.sun.com/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
         http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
  <display-name>Archetype Created Web Applicationdisplay-name>
    
    <context-param>
        <param-name>contextConfigLocationparam-name>
        <param-value>classpath:application-context.xmlparam-value>
    context-param>
    
    <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListenerlistener-class>
    listener>

    
    <servlet>
        <servlet-name>viewspaceservlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServletservlet-class>
        <load-on-startup>2load-on-startup>
    servlet>
    <servlet-mapping>
        <servlet-name>viewspaceservlet-name>
        <url-pattern>*.htmlurl-pattern>
    servlet-mapping>
web-app>
@Controller
@RequestMapping(value = "/admin")
public class LoginController {
    @Autowired
    private UserService userService;

    @RequestMapping("/login.html")
    private String loginPage(){
        return "login";
    }

    @RequestMapping("/loginCheck.html")
    private ModelAndView loginCheck(HttpServletRequest request,LoginCommand loginCommand){
        boolean isVaidUser = userService.hasMatchUser(loginCommand.getUserName(),loginCommand.getPassword());
        if(!isVaidUser){
            return new ModelAndView("login","error","用户名或密码错误");
        }else{
            User user = userService.findUserByUserName(loginCommand.getUserName());
            user.setLastIp(request.getRemoteAddr());
            user.setLastVisit(new Date());
            userService.loginSuccess(user);
            request.getSession().setAttribute("user",user);
            return new ModelAndView("main");
        }
    }
}


<beans xmlns="http://www.springframework.org/schema/beans"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xmlns:p="http://www.springframework.org/schema/p"
        xmlns:context="http://www.springframework.org/schema/context"
        xsi:schemaLocation="http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context.xsd">

    
    <context:component-scan base-package="spring.control"/>
    
    
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"
          p:viewClass="org.springframework.web.servlet.view.JstlView"
          p:prefix="/WEB-INF/jsp/"
          p:suffix=".jsp"/>
beans>

WEB-INF/jsp/main.jsp

<%@ page language="java" contentType="text/html;charset=UTF-8" pageEncoding="UTF-8" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html;charset=ISO-8859-1">
        <title>景区后台管理主页面title>
    head>
    <bdoy>
        ${user.userName},欢迎您进入景区后台管理!
    bdoy>
html>

WEB-INF/jsp/login.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" pageEncoding="UTF-8" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<html>
<head>
    <title>景区网站登录title>
head>
<body>
  <c:if test="${!empty error}">
    <font color="red">
      <c:out value="${error}"/>
    font>
    <form action="loginCheck.html"/>" method="post" >
      用户名:<input type="text" name="userName"><br/>
      密码:<input type="password" name="password"><br/>
      <input type="submit" value="登录">
      <input type="reset" value="重置">
    form>
body>
html>
<build>
    <finalName>myspringfinalName>
    <plugins>
      
      <plugin>
        <groupId>org.mortbay.jettygroupId>
        <artifactId>maven-jetty-pluginartifactId>
        <version>6.1.5version>
        <configuration>
          <webAppSourceDirectory>src/mian/webappwebAppSourceDirectory>
          <scanIntervalSeconds>3scanIntervalSeconds>
          <contextPath>/contextPath>
          <connectors>
            <connector implementation="org.mortbay.jetty.nio.SelectChannelConnector">
              <port>8080port>
            connector>
          connectors>
        configuration>
      plugin>
    plugins>
  build>

你可能感兴趣的:(javaweb,spring)