成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

SSM框架整合

lanffy / 1647人閱讀

摘要:環(huán)境工具數(shù)據(jù)庫連接工具準(zhǔn)備工作步驟新建項(xiàng)目建好基本目錄,按住配置目錄,如下圖新建幾個(gè)包,如下圖包名名稱作用數(shù)據(jù)訪問層接口與數(shù)據(jù)操作有關(guān)的都放在這里實(shí)體類一般與數(shù)據(jù)庫的表相對(duì)應(yīng),封裝層取出來的數(shù)據(jù)為一個(gè)對(duì)象,也就是我們常說的,一般只在層與層之

環(huán)境

Windows10

JDK1.8

MySql5.5

工具

Maven3.5

IDEA2017

Navicat(數(shù)據(jù)庫連接工具)

準(zhǔn)備工作 步驟 1、新建Maven webapp項(xiàng)目



建好基本目錄,按住 Ctrl+Alt+Shift+s配置目錄,如下圖

新建幾個(gè)包,如下圖:

包名 名稱 作用
dao 數(shù)據(jù)訪問層(接口 與數(shù)據(jù)操作有關(guān)的都放在這里
entity 實(shí)體類 一般與數(shù)據(jù)庫的表相對(duì)應(yīng),封裝dao層取出來的數(shù)據(jù)為一個(gè)對(duì)象,也就是我們常說的pojo,一般只在dao層與service層之間傳輸
dto 數(shù)據(jù)傳輸層 用于service層與web層之間傳輸,相當(dāng)于vo
service 業(yè)務(wù)邏輯(接口) 寫我們的業(yè)務(wù)邏輯,在設(shè)計(jì)業(yè)務(wù)接口時(shí)候應(yīng)該站在“使用者”的角度。
serviceImpl 業(yè)務(wù)邏輯(實(shí)現(xiàn)) 實(shí)現(xiàn)我們業(yè)務(wù)接口,一般事務(wù)控制是寫在這里,沒什么好說的。
controller 控制器 springmvc就是在這里發(fā)揮作用的
2、配置文件

配置完成的目錄如下:

pom.xml


  4.0.0
  com.messchx
  ssmdemo
  war
  1.0-SNAPSHOT
  ssmdemo Maven Webapp
  http://maven.apache.org

  
    ssmdemo

    
      
        org.mortbay.jetty
        maven-jetty-plugin
        6.1.7
        
          
            
              8888
              30000
            
          
          ${project.build.directory}/${pom.artifactId}-${pom.version}
          
          /
        
      

      
      
        org.mybatis.generator
        mybatis-generator-maven-plugin
        1.3.2
      

      
        org.apache.maven.plugins
        maven-compiler-plugin
        
          
          1.8
          1.8
        
      
    
    
    
      
        
        src/main/java
        
        
          **/*.xml
          **/*.properties
        
      
      
        
        src/main/resources
        
        
          **/*.xml
          **/*.properties
        
      

    
  

  
    
    UTF-8
    UTF-8
    
    4.3.5.RELEASE
    
    3.4.1
  
  
    
    
      javax
      javaee-api
      7.0
    

    
    
      junit
      junit
      4.12
    

    
    
      ch.qos.logback
      logback-classic
      1.2.2
    

    
    
      com.fasterxml.jackson.core
      jackson-databind
      2.8.7
    


    
    
      mysql
      mysql-connector-java
      5.1.41
      runtime
    

    
    
      com.mchange
      c3p0
      0.9.5.2
    

    
    
      org.mybatis
      mybatis
      ${mybatis.version}
    

    
    
      org.mybatis
      mybatis-spring
      1.3.1
    

    
    
      org.springframework
      spring-core
      ${spring.version}
    
    
      org.springframework
      spring-beans
      ${spring.version}
    
    
      org.springframework
      spring-context
      ${spring.version}
    
    
      org.springframework
      spring-jdbc
      ${spring.version}
    
    
      org.springframework
      spring-tx
      ${spring.version}
    
    
      org.springframework
      spring-web
      ${spring.version}
    
    
      org.springframework
      spring-webmvc
      ${spring.version}
    
    
      org.springframework
      spring-test
      ${spring.version}
    
  

spring配置文件,主要是dao、service、controller

spring-dao.xml



    
    
    

    
    
        
        
        
        
        

        
        
        
        
        
        
        
        
        
    

    
    
        
        
        
        
        
        
        
        
    

    
    
        
        
        
        
    
    

jdbc.properties

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/ssm?useUnicode=true&characterEncoding=utf8
jdbc.username=root
jdbc.password=root    

提示:配置文件中的jdbc.username,如果寫成username,可能會(huì)與系統(tǒng)環(huán)境中的username變量沖突,所以到時(shí)候真正連接數(shù)據(jù)庫的時(shí)候,用戶名就被替換成系統(tǒng)中的用戶名(有得可能是administrator),那肯定是連接不成功的

mybatis-config.xml




    
    
        
        

        
        

        
        
    

spring-service.xml



    
    

    
    
        
        
    

    
    

spring-controller.xml



    
    
    
    

    
    

    
    
        
        
        
    

    
    

web.xml


  
  
  
    dispatcherServlet
    org.springframework.web.servlet.DispatcherServlet
    
    
      contextConfigLocation
      classpath:spring/spring-*.xml
    
    1
  
  
    dispatcherServlet
    
    /
    

logback.xml(日志)



    
        
        
            %d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n
        
    

    
        
    

generatorConfig.xml,mybatis逆向工程,生成dao(即mapper)和model(即po),這里先不用





    
    

    
    

    

        
        
            
            
        

        
        
        


        
        
            
        


        
        

            
            
            
            
            
            
            
            
        

        
        
            
        

        
        
            
        

        
        

到這里基本的配置都完了,剩下的就是寫代碼。

3、代碼,應(yīng)用實(shí)例(圖書管理系統(tǒng))

mysql數(shù)據(jù)文件:

SET FOREIGN_KEY_CHECKS=0;

-- ----------------------------
-- Table structure for appointment
-- ----------------------------
DROP TABLE IF EXISTS `appointment`;
CREATE TABLE `appointment` (
  `book_id` bigint(20) NOT NULL COMMENT "圖書ID",
  `student_id` bigint(20) NOT NULL COMMENT "學(xué)號(hào)",
  `appoint_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT "預(yù)約時(shí)間",
  PRIMARY KEY (`book_id`,`student_id`),
  KEY `idx_appoint_time` (`appoint_time`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT="預(yù)約圖書表";

-- ----------------------------
-- Records of appointment
-- ----------------------------
INSERT INTO `appointment` VALUES ("1000", "12345678910", "2018-01-16 15:44:36");
INSERT INTO `appointment` VALUES ("1001", "12345678910", "2018-01-16 15:58:02");

-- ----------------------------
-- Table structure for book
-- ----------------------------
DROP TABLE IF EXISTS `book`;
CREATE TABLE `book` (
  `book_id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT "圖書ID",
  `name` varchar(100) NOT NULL COMMENT "圖書名稱",
  `number` int(11) NOT NULL COMMENT "館藏?cái)?shù)量",
  PRIMARY KEY (`book_id`)
) ENGINE=InnoDB AUTO_INCREMENT=1004 DEFAULT CHARSET=utf8 COMMENT="圖書表";

-- ----------------------------
-- Records of book
-- ----------------------------
INSERT INTO `book` VALUES ("1000", "Java程序設(shè)計(jì)", "9");
INSERT INTO `book` VALUES ("1001", "數(shù)據(jù)結(jié)構(gòu)", "9");
INSERT INTO `book` VALUES ("1002", "設(shè)計(jì)模式", "10");
INSERT INTO `book` VALUES ("1003", "編譯原理", "10");
3.1 dao層

在entity包中添加圖書實(shí)體Book.java和預(yù)約圖書實(shí)體Appointment.java
Book.java

public class Book {

    private long bookId;// 圖書ID

    private String name;// 圖書名稱

    private int number;// 館藏?cái)?shù)量

    // 省略構(gòu)造方法,getter和setter方法,toString方法

}

Appointment.java

   /**預(yù)約圖書實(shí)體*/
public class Appointment {

    private long bookId;// 圖書ID

    private long studentId;// 學(xué)號(hào)

    private Date appointTime;// 預(yù)約時(shí)間

    // 多對(duì)一的復(fù)合屬性
    private Book book;// 圖書實(shí)體
    
    // 省略構(gòu)造方法,getter和setter方法,toString方法

}

在dao包新建接口BookDao.java和Appointment.java
BookDao.java

public interface BookDao {

    /**
     * 通過ID查詢單本圖書
     *
     * @param id
     * @return
     */
    Book queryById(long id);

    /**
     * 查詢所有圖書
     *
     * @param offset 查詢起始位置
     * @param limit 查詢條數(shù)
     * @return
     */
    List queryAll(@Param("offset") int offset, @Param("limit") int limit);

    /**
     * 減少館藏?cái)?shù)量
     *
     * @param bookId
     * @return 如果影響行數(shù)等于>1,表示更新的記錄行數(shù)
     */
    int reduceNumber(long bookId);
}

AppointmentDao.java

public interface AppointmentDao {

    /**
     * 插入預(yù)約圖書記錄
     *
     * @param bookId
     * @param studentId
     * @return 插入的行數(shù)
     */
    int insertAppointment(@Param("bookId") long bookId, @Param("studentId") long studentId);

    /**
     * 通過主鍵查詢預(yù)約圖書記錄,并且攜帶圖書實(shí)體
     *
     * @param bookId
     * @param studentId
     * @return
     */
    Appointment queryByKeyWithBook(@Param("bookId") long bookId, @Param("studentId") long studentId);

}

提示:這里為什么要給方法的參數(shù)添加@Param注解呢?是因?yàn)樵摲椒ㄓ袃蓚€(gè)或以上的參數(shù),一定要加,不然mybatis識(shí)別不了。上面的BookDao接口的queryById方法和reduceNumber方法只有一個(gè)參數(shù)book_id,所以可以不用加 @Param注解,當(dāng)然加了也無所謂~
我們不需要實(shí)現(xiàn)dao接口, mybatis會(huì)動(dòng)態(tài)實(shí)現(xiàn),但是我們需要編寫相應(yīng)的mapper。在mapper目錄里新建兩個(gè)文件BookDao.xml和ppointmentDao.xml,分別對(duì)應(yīng)上面兩個(gè)dao接口。

BookDao.xml




    
    

    

    
        UPDATE book
        SET number = number - 1
        WHERE
        book_id = #{bookId}
        AND number > 0
    

AppointmentDao.xml




    
        
        INSERT ignore INTO appointment (book_id, student_id)
        VALUES (#{bookId}, #{studentId})
    

    

mapper總結(jié):namespace是該xml對(duì)應(yīng)的接口全名,select和update中的id對(duì)應(yīng)方法名,resultType是返回值類型,parameterType是參數(shù)類型(這個(gè)其實(shí)可選),最后#{...}中填寫的是方法的參數(shù),還有一個(gè)小技巧要交給大家,就是在返回Appointment對(duì)象包含了一個(gè)屬性名為book的Book對(duì)象,那么可以使用"book.屬性名"的方式來取值,看上面queryByKeyWithBook方法的sql。

測(cè)試:在測(cè)試分支建立相應(yīng)的包,測(cè)試前需要讓程序讀入spring-dao和mybatis等配置文件,所以我這里就抽離出來一個(gè)BaseTest類,只要是測(cè)試方法就繼承它即可。
BaseTest.java

/**
* 配置spring和junit整合,junit啟動(dòng)時(shí)加載springIOC容器 spring-test,junit
*/
@RunWith(SpringJUnit4ClassRunner.class)
// 告訴junit spring配置文件
@ContextConfiguration({ "classpath:spring/spring-dao.xml", "classpath:spring/spring-service.xml" })
public class BaseTest {

}

新建BookDaoTest.java和AppointmentDaoTest.java兩個(gè)dao測(cè)試文件
BookDaoTest.java

public class BookDaoTest extends BaseTest {
    @Autowired
    private BookDao bookDao;

    @Test
    public void testQueryById() throws Exception {
        long bookId = 1000;
        Book book = bookDao.queryById(bookId);
        System.out.println(book);
    }

    @Test
    public void testQueryAll() throws Exception {
        List books = bookDao.queryAll(0, 4);
        for (Book book : books) {
            System.out.println(book);
        }
    }

    @Test
    public void testReduceNumber() throws Exception {
        long bookId = 1000;
        int update = bookDao.reduceNumber(bookId);
        System.out.println("update=" + update);
    }

}

BookDaoTest測(cè)試結(jié)果,testQueryById

testQueryAll

testReduceNumber

AppointmentDaoTest.java

public class AppointmentDaoTest extends BaseTest{
    @Autowired
    private AppointmentDao appointmentDao;

    @Test
    public void testInsertAppointment() throws Exception {
        long bookId = 1000;
        long studentId = 12345678910L;
        int insert = appointmentDao.insertAppointment(bookId, studentId);
        System.out.println("insert=" + insert);
    }

    @Test
    public void testQueryByKeyWithBook() throws Exception {
        long bookId = 1000;
        long studentId = 12345678910L;
        Appointment appointment = appointmentDao.queryByKeyWithBook(bookId, studentId);
        System.out.println(appointment);
        System.out.println(appointment.getBook());
    }

}

AppointmentDaoTest測(cè)試結(jié)果,testInsertAppointment

testQueryByKeyWithBook

3.2 servic層

我們先定義幾個(gè)預(yù)約圖書操作返回碼的數(shù)據(jù)字典,也就是我們要返回給客戶端的信息。我們這類使用枚舉類

返回碼 說明
1 預(yù)約成功
0 庫存不足
-1 重復(fù)預(yù)約
-2 系統(tǒng)異常

AppointStateEnum.java

package com.messchx.ssm.enums;

/**
 * 使用枚舉表述常量數(shù)據(jù)字典
 */
public enum AppointStateEnum {
    SUCCESS(1, "預(yù)約成功"), NO_NUMBER(0, "庫存不足"), REPEAT_APPOINT(-1, "重復(fù)預(yù)約"), INNER_ERROR(-2, "系統(tǒng)異常");

    private int state;

    private String stateInfo;

    private AppointStateEnum(int state, String stateInfo) {
        this.state = state;
        this.stateInfo = stateInfo;
    }

    public int getState() {
        return state;
    }

    public String getStateInfo() {
        return stateInfo;
    }

    public static AppointStateEnum stateOf(int index) {
        for (AppointStateEnum state : values()) {
            if (state.getState() == index) {
                return state;
            }
        }
        return null;
    }

}

在dto包下新建AppointExecution.java用來存儲(chǔ)我們執(zhí)行預(yù)約操作的返回結(jié)果。
AppointExecution.java

/**
* 封裝預(yù)約執(zhí)行后結(jié)果
*/
public class AppointExecution {

    // 圖書ID
    private long bookId;

    // 秒殺預(yù)約結(jié)果狀態(tài)
    private int state;

    // 狀態(tài)標(biāo)識(shí)
    private String stateInfo;

    // 預(yù)約成功對(duì)象
    private Appointment appointment;

    public AppointExecution() {
    }

    // 預(yù)約失敗的構(gòu)造器
    public AppointExecution(long bookId, AppointStateEnum stateEnum) {
        this.bookId = bookId;
        this.state = stateEnum.getState();
        this.stateInfo = stateEnum.getStateInfo();
    }

    // 預(yù)約成功的構(gòu)造器
    public AppointExecution(long bookId, AppointStateEnum stateEnum, Appointment appointment) {
        this.bookId = bookId;
        this.state = stateEnum.getState();
        this.stateInfo = stateEnum.getStateInfo();
        this.appointment = appointment;
    }
    
    // 省略getter和setter方法,toString方法

}

在exception包下新建三個(gè)文件NoNumberException.java RepeatAppointException.java AppointException.java預(yù)約業(yè)務(wù)異常類(都需要繼承RuntimeException),分別是無庫存異常、重復(fù)預(yù)約異常、預(yù)約未知錯(cuò)誤異常,用于業(yè)務(wù)層非成功情況下的返回(即成功返回結(jié)果,失敗拋出異常)。
NoNumberException.java

/**
* 庫存不足異常
*/
public class NoNumberException extends RuntimeException {

    public NoNumberException(String message) {
        super(message);
    }

    public NoNumberException(String message, Throwable cause) {
        super(message, cause);
    }

}

RepeatAppointException.java

/**
* 重復(fù)預(yù)約異常
*/
public class RepeatAppointException extends RuntimeException {

    public RepeatAppointException(String message) {
        super(message);
    }

    public RepeatAppointException(String message, Throwable cause) {
        super(message, cause);
    }

}

AppointException.java

/**
* 預(yù)約業(yè)務(wù)異常
*/
public class AppointException extends RuntimeException {

    public AppointException(String message) {
        super(message);
    }

    public AppointException(String message, Throwable cause) {
        super(message, cause);
    }

}

在service包下新建BookService.java圖書業(yè)務(wù)接口
BookService.java

/**
* 業(yè)務(wù)接口:站在"使用者"角度設(shè)計(jì)接口 三個(gè)方面:方法定義粒度,參數(shù),返回類型(return 類型/異常)
*/
public interface BookService {

    /**
     * 查詢一本圖書
     *
     * @param bookId
     * @return
     */
    Book getById(long bookId);

    /**
     * 查詢所有圖書
     *
     * @return
     */
    List getList();

    /**
     * 預(yù)約圖書
     *
     * @param bookId
     * @param studentId
     * @return
     */
    AppointExecution appoint(long bookId, long studentId);

}

在service.impl包下新建BookServiceImpl.java使用BookService接口,并實(shí)現(xiàn)里面的方法。
BookServiceImpl

@Service
public class BookServiceImpl implements BookService {

    private Logger logger = LoggerFactory.getLogger(this.getClass());

    // 注入Service依賴
    @Autowired
    private BookDao bookDao;

    @Autowired
    private AppointmentDao appointmentDao;


    @Override
    public Book getById(long bookId) {
        return bookDao.queryById(bookId);
    }

    @Override
    public List getList() {
        return bookDao.queryAll(0, 1000);
    }

    @Override
    @Transactional
    /**
     * 使用注解控制事務(wù)方法的優(yōu)點(diǎn): 1.開發(fā)團(tuán)隊(duì)達(dá)成一致約定,明確標(biāo)注事務(wù)方法的編程風(fēng)格
     * 2.保證事務(wù)方法的執(zhí)行時(shí)間盡可能短,不要穿插其他網(wǎng)絡(luò)操作,RPC/HTTP請(qǐng)求或者剝離到事務(wù)方法外部
     * 3.不是所有的方法都需要事務(wù),如只有一條修改操作,只讀操作不需要事務(wù)控制
     */
    public AppointExecution appoint(long bookId, long studentId) {
        try {
            // 減庫存
            int update = bookDao.reduceNumber(bookId);
            if (update <= 0) {// 庫存不足
                //return new AppointExecution(bookId, AppointStateEnum.NO_NUMBER);//錯(cuò)誤寫法                
                throw new NoNumberException("no number");
            } else {
                // 執(zhí)行預(yù)約操作
                int insert = appointmentDao.insertAppointment(bookId, studentId);
                if (insert <= 0) {// 重復(fù)預(yù)約
                    //return new AppointExecution(bookId, AppointStateEnum.REPEAT_APPOINT);//錯(cuò)誤寫法
                    throw new RepeatAppointException("repeat appoint");
                } else {// 預(yù)約成功
                    Appointment appointment = appointmentDao.queryByKeyWithBook(bookId, studentId);
                    return new AppointExecution(bookId, AppointStateEnum.SUCCESS, appointment);
                }
            }
        // 要先于catch Exception異常前先catch住再拋出,不然自定義的異常也會(huì)被轉(zhuǎn)換為AppointException,導(dǎo)致控制層無法具體識(shí)別是哪個(gè)異常
        } catch (NoNumberException e1) {
            throw e1;
        } catch (RepeatAppointException e2) {
            throw e2;
        } catch (Exception e) {
            logger.error(e.getMessage(), e);
            // 所有編譯期異常轉(zhuǎn)換為運(yùn)行期異常
            //return new AppointExecution(bookId, AppointStateEnum.INNER_ERROR);//錯(cuò)誤寫法
            throw new AppointException("appoint inner error:" + e.getMessage());
        }
    }

}

測(cè)試一下業(yè)務(wù)代碼
BookServiceImplTest.java

public class BookServiceImplTest extends BaseTest {

    @Autowired
    private BookService bookService;

    @Test
    public void testAppoint() throws Exception {
        long bookId = 1001;
        long studentId = 12345678910L;
        AppointExecution execution = bookService.appoint(bookId, studentId);
        System.out.println(execution);
    }

}

BookServiceImplTest測(cè)試結(jié)果

首次執(zhí)行是“預(yù)約成功”,如果再次執(zhí)行的話,應(yīng)該會(huì)出現(xiàn)“重復(fù)預(yù)約”

在dto包里新建一個(gè)封裝json返回結(jié)果的類Result.java,設(shè)計(jì)成泛型
Result.java

/**
* 封裝json對(duì)象,所有返回結(jié)果都使用它
*/
public class Result {

    private boolean success;// 是否成功標(biāo)志

    private T data;// 成功時(shí)返回的數(shù)據(jù)

    private String error;// 錯(cuò)誤信息

    public Result() {
    }

    // 成功時(shí)的構(gòu)造器
    public Result(boolean success, T data) {
        this.success = success;
        this.data = data;
    }

    // 錯(cuò)誤時(shí)的構(gòu)造器
    public Result(boolean success, String error) {
        this.success = success;
        this.error = error;
    }

    // 省略getter和setter方法
}
3.3 controller層

BookController.java

@Controller
@RequestMapping("/book") // url:/模塊/資源/{id}/細(xì)分 /seckill/list
public class BookController {

    private Logger logger = LoggerFactory.getLogger(this.getClass());

    @Autowired
    private BookService bookService;

    @RequestMapping(value = "/list", method = RequestMethod.GET)
    private String list(Model model) {
        List list = bookService.getList();
        model.addAttribute("list", list);
        // list.jsp + model = ModelAndView
        return "list";// WEB-INF/jsp/"list".jsp
    }

    @RequestMapping(value = "/{bookId}/detail", method = RequestMethod.GET)
    private String detail(@PathVariable("bookId") Long bookId, Model model) {
        if (bookId == null) {
            return "redirect:/book/list";
        }
        Book book = bookService.getById(bookId);
        if (book == null) {
            return "forward:/book/list";
        }
        model.addAttribute("book", book);
        return "detail";
    }

    //ajax json
    @RequestMapping(value = "/{bookId}/appoint", method = RequestMethod.POST, produces = {
            "application/json; charset=utf-8" })
    @ResponseBody
    private Result appoint(@PathVariable("bookId") Long bookId, @RequestParam("studentId") Long studentId) {
        if (studentId == null || studentId.equals("")) {
            return new Result<>(false, "學(xué)號(hào)不能為空");
        }
        //AppointExecution execution = bookService.appoint(bookId, studentId);//錯(cuò)誤寫法,不能統(tǒng)一返回,要處理異常(失?。┣闆r
        AppointExecution execution = null;
        try {
            execution = bookService.appoint(bookId, studentId);
        } catch (NoNumberException e1) {
            execution = new AppointExecution(bookId, AppointStateEnum.NO_NUMBER);
        } catch (RepeatAppointException e2) {
            execution = new AppointExecution(bookId, AppointStateEnum.REPEAT_APPOINT);
        } catch (Exception e) {
            execution = new AppointExecution(bookId, AppointStateEnum.INNER_ERROR);
        }
        return new Result(true, execution);
    }

}

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/68261.html

相關(guān)文章

  • 從零開始搭建SSM框架(Spring + Spring MVC + Mybatis)

    摘要:打開,,選中,然后再選中,輸入項(xiàng)目的和,指定等配置,修改,打開項(xiàng)目,添加一些必要的目錄,最終項(xiàng)目框架目錄圖如下修改文件,指定各依賴和插件的版本等信息在標(biāo)簽里面管理各依賴的版本號(hào)添加項(xiàng)目依賴管理依賴配置好之后,開始整合。 最近在回顧和總結(jié)一些技術(shù),想到了把之前比較火的 SSM 框架重新搭建出來,作為一個(gè)小結(jié),同時(shí)也希望本文章寫出來能對(duì)大家有一些幫助和啟發(fā),因本人水平有限,難免可能會(huì)有一些...

    MiracleWong 評(píng)論0 收藏0
  • Maven多模塊項(xiàng)目搭建+整合SSM框架

    摘要:繼承作用就是避免配置重復(fù),對(duì)于子項(xiàng)目來說應(yīng)該關(guān)心父項(xiàng)目是怎么樣配置的。聚合字面理解就是聚在一起合作完成工作,就是將子模塊聚集起來完成相應(yīng)的項(xiàng)目需求父工程的搭建項(xiàng)目結(jié)構(gòu)在父工程中,主要負(fù)責(zé)完成依賴的版本管理,并不是實(shí)際的依賴。 從大二開始就一直關(guān)注segmentFault,在問題專區(qū)幫忙回答一些自己知曉的問題;在寫這篇文章之前我一直會(huì)在朋友圈發(fā)一些自己遇到的問題以及解決辦法,這是第一次寫...

    liaosilzu2007 評(píng)論0 收藏0
  • SSM框架整合

    摘要:整合項(xiàng)目結(jié)構(gòu)導(dǎo)入版本號(hào)相關(guān)包相關(guān)包相關(guān)包相關(guān)包數(shù)據(jù)庫連接池集成標(biāo)準(zhǔn)標(biāo)簽庫日志相關(guān)包單元測(cè)試相關(guān)包里面為空開發(fā)環(huán)境下,日志級(jí)別設(shè)置 ssm整合項(xiàng)目結(jié)構(gòu) showImg(https://segmentfault.com/img/bVbsw8O?w=533&h=815); Maven導(dǎo)入jar pom.xml 4.0.0 cn.scitc Test 1...

    twohappy 評(píng)論0 收藏0
  • ssm框架整合

    ssm整合 開發(fā)環(huán)境ide,mysql數(shù)據(jù)庫,Spring+SpringMVC+Mybatis,tomcat8.5,jdk使用的是1.7版本。 第一步:導(dǎo)入jar包 Spring+ SpringMVC + MyBatis + Mybatis-spring整合包 AOP聯(lián)盟+織入 + c3p0 數(shù)據(jù)庫連接池 + MySQL連接驅(qū)動(dòng) + jstl 鏈接:https://pan.baidu.com/...

    Simon_Zhou 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<