美文网首页
Day01:SSM 环境搭建与产品操作

Day01:SSM 环境搭建与产品操作

作者: GXD_小男孩 | 来源:发表于2019-06-09 15:14 被阅读0次

    一.数据库(Oracle)环境搭建

    1.我将数据库放在了虚拟机里,XP系统.

    安装Oracle注意事项:
    1.如果是 win7 或者 win10 系统右键点击 setup.exe 选择兼容性,以 xp 方式,并且以管理员方式运行,以及其他所有用户都按着此规则如图


    图一
    图二

    2.检查先决条件,选中红框所示的选择框,如下图:


    image.png
    3.完成后,出现“口令管理”界面,点击“口令管理”,如下图:
    口令管理
    4.将 SCOTT 和 HR 用户的勾去掉(解锁这两个账户),如下图所示,点击“确定”: 解锁用户

    5.测试是否安装成功
    运行 cmd 进入命令行
    Sqlplus 用户名/密码@ip 地址:1521/orcl [as sysdba]


    测试成功

    2.配置网络:使虚拟机和本机在同一局域网,这样本机就能通过IP地址来访问虚拟机的Oracle数据库了.

    注意事项
    1.配置时使用同一个虚拟机网卡.


    使用同一个
    设置虚拟机网卡

    2.虚拟机中的网络配置和主机子网要在同一个网段


    同一个网段
    3.修 改 oracle 的两个核心文件中的IP地址为XP的IP,之后记得重启服务.
    修改核心文件
    重启服务

    3.客户端连接oracle

    工具:
    1.instantclient_12_1


    官方连接工具
    2.安装 PLSQL Developer 配置官方连接
    3.设置环境变量 TNS_ADMIN
    这样就可以用这个登录
    4.解决中文乱码问题

    1>查看服务器端编码select userenv('language') from dual;
    我实际查到的结果为:AMERICAN_AMERICA.ZHS16GBK
    2>执行语句 select * from V$NLS_PARAMETERS
    查看第一行中PARAMETER项中为NLS_LANGUAGE 对应的VALUE项中是否和第一步得到的值一样。如果不是,需要设置环境变量.否则PLSQL客户端使用的编码和服务器端编码不一致,插入中文时就会出现乱码.
    3>设置环境变量
    计算机->属性->高级系统设置->环境变量->新建
    设置变量名:NLS_LANG,变量值:第1步查到的值, 我的是AMERICAN_AMERICA.ZHS16GBK
    4>重新启动PLSQL,插入数据正常

    5.创建用户ssm及授权 授权

    二.建表

    CREATE TABLE product(
    id varchar2(32) default SYS_GUID() PRIMARY KEY,
    productNum VARCHAR2(50) NOT NULL,
    productName VARCHAR2(50),
    cityName VARCHAR2(50),
    DepartureTime timestamp,
    productPrice Number,
    productDesc VARCHAR2(500),
    productStatus INT,
    CONSTRAINT product UNIQUE (id, productNum)
    )
    insert into PRODUCT (id, productnum, productname, cityname, departuretime, productprice,
    productdesc, productstatus)
    values ('676C5BD1D35E429A8C2E114939C5685A', 'gxd-002', '北京三日游', '北京', to_timestamp('10-
    10-2018 10:10:00.000000', 'dd-mm-yyyy hh24:mi:ss.ff'), 1200, '不错的旅行', 1);
    insert into PRODUCT (id, productnum, productname, cityname, departuretime, productprice,
    productdesc, productstatus)
    values ('12B7ABF2A4C544568B0A7C69F36BF8B7', 'gxd-003', '上海五日游', '上海', to_timestamp('25-
    04-2018 14:30:00.000000', 'dd-mm-yyyy hh24:mi:ss.ff'), 1800, '魔都我来了', 0);
    insert into PRODUCT (id, productnum, productname, cityname, departuretime, productprice,
    productdesc, productstatus)
    values ('9F71F01CB448476DAFB309AA6DF9497F', 'gxd-001', '北京三日游', '北京', to_timestamp('10-
    10-2018 10:10:00.000000', 'dd-mm-yyyy hh24:mi:ss.ff'), 1200, '不错的旅行', 1);
    

    三.maven工程搭建

    1.子父工程目录


    目录结构

    2.父pom文件内容

    <?xml version="1.0" encoding="UTF-8"?>
    <project xmlns="http://maven.apache.org/POM/4.0.0"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0</modelVersion>
    
        <groupId>com.gxd.gxd-ssm</groupId>
        <artifactId>gxd-ssm</artifactId>
        <packaging>pom</packaging>
        <version>1.0-SNAPSHOT</version>
    
        <properties>
            <spring.version>5.0.2.RELEASE</spring.version>
            <slf4j.version>1.6.6</slf4j.version>
            <log4j.version>1.2.12</log4j.version>
            <oracle.version>10.2.0.4.0</oracle.version>
            <mybatis.version>3.4.5</mybatis.version>
            <spring.security.version>5.0.1.RELEASE</spring.security.version>
        </properties>
    
        <dependencies>        <!-- spring -->
            <dependency>
                <groupId>org.aspectj</groupId>
                <artifactId>aspectjweaver</artifactId>
                <version>1.6.8</version>
            </dependency>
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-aop</artifactId>
                <version>${spring.version}</version>
            </dependency>
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-context</artifactId>
                <version>${spring.version}</version>
            </dependency>
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-context-support</artifactId>
                <version>${spring.version}</version>
            </dependency>
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-web</artifactId>
                <version>${spring.version}</version>
            </dependency>
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-orm</artifactId>
                <version>${spring.version}</version>
            </dependency>
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-beans</artifactId>
                <version>${spring.version}</version>
            </dependency>
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-core</artifactId>
                <version>${spring.version}</version>
            </dependency>
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-test</artifactId>
                <version>${spring.version}</version>
            </dependency>
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-webmvc</artifactId>
                <version>${spring.version}</version>
    
            </dependency>
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-tx</artifactId>
                <version>${spring.version}</version>
            </dependency>
            <dependency>
                <groupId>junit</groupId>
                <artifactId>junit</artifactId>
                <version>4.12</version>
                <scope>test</scope>
            </dependency>
    
            <dependency>
                <groupId>javax.servlet</groupId>
                <artifactId>javax.servlet-api</artifactId>
                <version>3.1.0</version>
                <scope>provided</scope>
            </dependency>
            <dependency>
                <groupId>javax.servlet.jsp</groupId>
                <artifactId>jsp-api</artifactId>
                <version>2.0</version>
                <scope>provided</scope>
            </dependency>
            <dependency>
                <groupId>jstl</groupId>
                <artifactId>jstl</artifactId>
                <version>1.2</version>
            </dependency>        <!-- log start -->
            <dependency>
                <groupId>log4j</groupId>
                <artifactId>log4j</artifactId>
                <version>${log4j.version}</version>
            </dependency>
            <dependency>
                <groupId>org.slf4j</groupId>
                <artifactId>slf4j-api</artifactId>
                <version>${slf4j.version}</version>
            </dependency>
            <dependency>
                <groupId>org.slf4j</groupId>
                <artifactId>slf4j-log4j12</artifactId>
                <version>${slf4j.version}</version>
            </dependency>        <!-- log end -->
    
            <dependency>
                <groupId>org.mybatis</groupId>
                <artifactId>mybatis</artifactId>
                <version>${mybatis.version}</version>
            </dependency>
            <dependency>
                <groupId>org.mybatis</groupId>
                <artifactId>mybatis-spring</artifactId>
                <version>1.3.0</version>
            </dependency>
            <dependency>
                <groupId>c3p0</groupId>
                <artifactId>c3p0</artifactId>
                <version>0.9.1.2</version>
                <type>jar</type>
                <scope>compile</scope>
            </dependency>
            <dependency>
                <groupId>com.github.pagehelper</groupId>
                <artifactId>pagehelper</artifactId>
                <version>5.1.2</version>
            </dependency>
            <dependency>
                <groupId>org.springframework.security</groupId>
                <artifactId>spring-security-web</artifactId>
                <version>${spring.security.version}</version>
            </dependency>
            <dependency>
                <groupId>org.springframework.security</groupId>
                <artifactId>spring-security-config</artifactId>
                <version>${spring.security.version}</version>
            </dependency>
            <dependency>
                <groupId>org.springframework.security</groupId>
                <artifactId>spring-security-core</artifactId>
                <version>${spring.security.version}</version>
            </dependency>
            <dependency>
                <groupId>org.springframework.security</groupId>
                <artifactId>spring-security-taglibs</artifactId>
                <version>${spring.security.version}</version>
            </dependency>
            <dependency>
                <groupId>com.oracle</groupId>
                <artifactId>ojdbc14</artifactId>
                <version>${oracle.version}</version>
            </dependency>
    
        </dependencies>
        <build>
            <pluginManagement>
                <plugins>
                    <plugin>
                        <groupId>org.apache.maven.plugins</groupId>
                        <artifactId>maven-compiler-plugin</artifactId>
                        <version>3.2</version>
                        <configuration>
                            <source>1.8</source>
                            <target>1.8</target>
                            <encoding>UTF-8</encoding>
                            <showWarnings>true</showWarnings>
                        </configuration>
                    </plugin>
                </plugins>
            </pluginManagement>
        </build>
    
        <modules>
            <module>gxd-ssm-domain</module>
            <module>gxd-ssm-service</module>
            <module>gxd-ssm-dao</module>
            <module>gxd-ssm-utils</module>
            <module>gxd-ssm-web</module>
        </modules>
    
    
    </project>
    
    3.各类配置文件 配置文件位置

    0>

    <?xml version="1.0" encoding="UTF-8"?>
    <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xmlns="http://xmlns.jcp.org/xml/ns/javaee"
             xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
             version="3.1">
      <!-- 配置加载类路径的配置文件 -->
      <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>classpath*:applicationContext.xml,classpath*:spring-security.xml</param-value>
      </context-param>
    
      <!-- 配置监听器 -->
      <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
      </listener>
      <!-- 前端控制器(加载classpath:springmvc.xml 服务器启动创建servlet) -->
      <servlet>
        <servlet-name>dispatcherServlet</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <!-- 配置初始化参数,创建完DispatcherServlet对象,加载springmvc.xml配置文件 -->
        <init-param>
          <param-name>contextConfigLocation</param-name>
          <param-value>classpath:spring-mvc.xml</param-value>
        </init-param>
        <!-- 服务器启动的时候,让DispatcherServlet对象创建 -->
        <load-on-startup>1</load-on-startup>
      </servlet>
      <servlet-mapping>
        <servlet-name>dispatcherServlet</servlet-name>
        <url-pattern>*.do</url-pattern>
      </servlet-mapping>
    
      <!-- 解决中文乱码过滤器 -->
      <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>
      </filter>
      <filter-mapping>
        <filter-name>characterEncodingFilter</filter-name>
        <url-pattern>/*</url-pattern>
      </filter-mapping>
      <!--权限管理的监听器-->
      <filter>
        <filter-name>springSecurityFilterChain</filter-name>
        <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
      </filter>
      <filter-mapping>
        <filter-name>springSecurityFilterChain</filter-name>
        <url-pattern>/*</url-pattern>
      </filter-mapping>
    
      <welcome-file-list>
        <welcome-file>index.html</welcome-file>
        <welcome-file>index.htm</welcome-file>
        <welcome-file>index.jsp</welcome-file>
        <welcome-file>default.html</welcome-file>
        <welcome-file>default.htm</welcome-file>
        <welcome-file>default.jsp</welcome-file>
      </welcome-file-list>
    </web-app>
    
    

    1>applicationContext.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <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: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/context/spring-context.xsd
        http://www.springframework.org/schema/aop
        http://www.springframework.org/schema/aop/spring-aop.xsd
        http://www.springframework.org/schema/tx
        http://www.springframework.org/schema/tx/spring-tx.xsd">
        <!-- 开启注解扫描,管理service和dao -->
        <context:component-scan base-package="com.gxd.ssm.service">
        </context:component-scan>
        <context:component-scan base-package="com.gxd.ssm.dao">
        </context:component-scan>
    
        <context:property-placeholder location="classpath:db.properties"/>
        <!-- 配置连接池 -->
        <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
            <property name="driverClass" value="${jdbc.driver}" />
            <property name="jdbcUrl" value="${jdbc.url}" />
            <property name="user" value="${jdbc.username}" />
            <property name="password" value="${jdbc.password}" />
        </bean>
        <!-- 把交给IOC管理 SqlSessionFactory -->
        <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
            <property name="dataSource" ref="dataSource" />
            <!--&lt;!&ndash; 传入PageHelper的插件 &ndash;&gt;-->
            <!--<property name="plugins">-->
                <!--<array>-->
                    <!--&lt;!&ndash; 传入插件的对象 &ndash;&gt;-->
                    <!--<bean class="com.github.pagehelper.PageInterceptor">-->
                        <!--<property name="properties">-->
                            <!--<props>-->
                                <!--<prop key="helperDialect">mysql</prop>-->
                                <!--<prop key="reasonable">true</prop>-->
                            <!--</props>-->
                        <!--</property>-->
                    <!--</bean>-->
                <!--</array>-->
            <!--</property>-->
        </bean>
        <!-- 扫描dao接口 -->
        <bean id="mapperScanner" class="org.mybatis.spring.mapper.MapperScannerConfigurer">
            <property name="basePackage" value="com.gxd.ssm.dao"/>
        </bean>
        <!-- 配置Spring的声明式事务管理 -->
        <!-- 配置事务管理器 -->
        <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
            <property name="dataSource" ref="dataSource"/>
        </bean>
    
        <tx:annotation-driven transaction-manager="transactionManager"/>
    </beans>
    

    2>db.properties

    jdbc.driver=oracle.jdbc.driver.OracleDriver
    jdbc.url=jdbc:oracle:thin:@192.168.107.10:1521:orcl
    jdbc.username=ssm
    jdbc.password=gxd
    

    3>spring-mvc.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
           xmlns:mvc="http://www.springframework.org/schema/mvc"
           xmlns:context="http://www.springframework.org/schema/context"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
           xmlns:aop="http://www.springframework.org/schema/aop"
           xsi:schemaLocation="
               http://www.springframework.org/schema/beans
               http://www.springframework.org/schema/beans/spring-beans.xsd
               http://www.springframework.org/schema/mvc
               http://www.springframework.org/schema/mvc/spring-mvc.xsd
               http://www.springframework.org/schema/context
               http://www.springframework.org/schema/context/spring-context.xsd
               http://www.springframework.org/schema/aop
            http://www.springframework.org/schema/aop/spring-aop.xsd
               ">
        <!-- 扫描controller的注解,别的不扫描 -->
        <context:component-scan base-package="com.gxd.ssm.controller">
        </context:component-scan>
    
        <!-- 配置视图解析器 -->
        <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
            <!-- JSP文件所在的目录 -->
            <property name="prefix" value="/pages/" />
            <!-- 文件的后缀名 -->
            <property name="suffix" value=".jsp" />
        </bean>
    
        <!-- 设置静态资源不过滤 -->
        <mvc:resources location="/css/" mapping="/css/**" />
        <mvc:resources location="/img/" mapping="/img/**" />
        <mvc:resources location="/js/" mapping="/js/**" />
        <mvc:resources location="/plugins/" mapping="/plugins/**" />
    
        <!-- 开启对SpringMVC注解的支持 -->
        <mvc:annotation-driven />
    
        <!--
            支持AOP的注解支持,AOP底层使用代理技术
            JDK动态代理,要求必须有接口
            cglib代理,生成子类对象,proxy-target-class="true" 默认使用cglib的方式
        -->
        <aop:aspectj-autoproxy proxy-target-class="true"/>
    </beans>
    

    4.编写Dao层

    public interface IProductDao {
        @Select("select * from product")
        List<Product> findAll() throws Exception;
    }
    

    5.编写实体层

    package com.gxd.ssm.domain;
    
    import com.gxd.ssm.utils.DateUtils;
    
    import java.util.Date;
    
    public class Product {
        private String id; // 主键
        private String productNum; // 编号 唯一
        private String productName; // 名称
        private String cityName; // 出发城市
        private Date departureTime; // 出发时间
        private String departureTimeStr;
        private double productPrice; // 产品价格
        private String productDesc; // 产品描述
        private Integer productStatus; // 状态 0 关闭 1 开启
        private String productStatusStr;
    
        public String getId() {
            return id;
        }
    
        public void setId(String id) {
            this.id = id;
        }
    
        public String getProductNum() {
            return productNum;
        }
    
        public void setProductNum(String productNum) {
            this.productNum = productNum;
        }
    
        public String getProductName() {
            return productName;
        }
    
        public void setProductName(String productName) {
            this.productName = productName;
        }
    
        public String getCityName() {
            return cityName;
        }
    
        public void setCityName(String cityName) {
            this.cityName = cityName;
        }
    
        public Date getDepartureTime() {
            return departureTime;
        }
    
        public void setDepartureTime(Date departureTime) {
            this.departureTime = departureTime;
        }
    
        public String getDepartureTimeStr() {
            if (departureTime!=null)
            {
                departureTimeStr = DateUtils.date2String(departureTime,"yyyy-MM-dd HH:mm:ss");
            }
            return departureTimeStr;
        }
    
        public void setDepartureTimeStr(String departureTimeStr) {
            this.departureTimeStr = departureTimeStr;
        }
    
        public double getProductPrice() {
            return productPrice;
        }
    
        public void setProductPrice(double productPrice) {
            this.productPrice = productPrice;
        }
    
        public String getProductDesc() {
            return productDesc;
        }
    
        public void setProductDesc(String productDesc) {
            this.productDesc = productDesc;
        }
    
        public Integer getProductStatus() {
            return productStatus;
        }
    
        public void setProductStatus(Integer productStatus) {
            this.productStatus = productStatus;
        }
    
        public String getProductStatusStr() {
            if(productStatus != null)
            {
                if(productStatus==0)
                {
                    productStatusStr="关闭";
                }
                if(productStatus==1)
                {
                    productStatusStr="开启";
                }
            }
            return productStatusStr;
        }
    
        public void setProductStatusStr(String productStatusStr) {
            this.productStatusStr = productStatusStr;
        }
    }
    

    6.编写service层

    @Service
    @Transactional
    public class ProductServiceImpl implements IProductService {
        @Autowired
        IProductDao productDao;
        @Override
        public List<Product> findAll() throws Exception {
            return productDao.findAll();
        }
    }
    

    接口

    public interface IProductService {
        List<Product> findAll() throws Exception;
    }
    

    7.编写utils层

    public class DateUtils {
        //日期转换成字符串
        public static String date2String(Date date, String patt)
        {
            SimpleDateFormat sdf = new SimpleDateFormat(patt);
            String format = sdf.format(date);
            return format;
        }
        //字符串转换成日期
        public static Date String2Date(String str,String patt) throws ParseException {
            SimpleDateFormat sdf = new SimpleDateFormat(patt);
            Date date = sdf.parse(str);
            return date;
        }
    
    }
    

    8.编写web层(我用AdminLTE框架)
    1>控制器

    @Controller
    @RequestMapping("/product")
    public class ProductController {
        @Autowired
        IProductService productService;
    
        @RequestMapping("/findAll.do")
        public ModelAndView findAll() throws Exception {
            ModelAndView mv = new ModelAndView();
            List<Product> ps = productService.findAll();
            mv.addObject("productList",ps);
            mv.setViewName("product-list");
            return mv;
        }
    }
    

    2>前端


    前端

    3>pom配置服务器插件

            <plugins>
                <plugin>
                    <groupId>org.apache.tomcat.maven</groupId>
                    <artifactId>tomcat7-maven-plugin</artifactId>
                    <configuration>
                        <port>8888</port>
                    </configuration>
                    <version>2.2</version>
                </plugin>
            </plugins>
    

    效果


    商品展示

    9.添加商品
    问题一:spring MVC日期类型转换问题
    解决:@DateTimeFormat(pattern="yyyy-MM-dd HH:mm")

    控制层:

    @RequestMapping("/save.do")
        public String save(Product product)
        {
            productService.save(product);
            return "redirect:findAll.do";
        }
    

    业务层:

    //接口
    void save(Product product);
    //实现类
    @Override
        public void save(Product product) {
            productDao.save(product);
        }
    

    数据访问层:

    @Insert("insert into product(productNum,productName,cityName,departureTime,productPrice,productDesc,productStatus) values(#{productNum},#{productName},#{cityName},#{departureTime},#{productPrice},#{productDesc},#{productStatus})")
        void save(Product product);
    

    相关文章

      网友评论

          本文标题:Day01:SSM 环境搭建与产品操作

          本文链接:https://www.haomeiwen.com/subject/cjuwxctx.html