SSM框架的搭建

来源:http://www.cnblogs.com/HawkFalcon/archive/2017/11/07/7799319.html
-Advertisement-
Play Games

第一階段: 1、用PowerDesign建數據模型,並導出SQL文件; 2、將SQL文件導入到MySQL客戶端,建立表格; MySQL數據遠程訪問:GRANT ALL PRIVILEGES ON *.* TO 'root'@'%'IDENTIFIED BY 'mypassword' WITH GRA ...


第一階段:

1、用PowerDesign建數據模型,並導出SQL文件;

2、將SQL文件導入到MySQL客戶端,建立表格;

  MySQL數據遠程訪問:GRANT ALL PRIVILEGES ON *.* TO 'root'@'%'IDENTIFIED BY 'mypassword' WITH GRANT OPTION;

如果是固定IP:grant all privileges on *.* to 'root'@'192.168.41.100'identified by '123456' with grant option;

//推送設置到記憶體或重啟伺服器也行
mysql>FLUSH PRIVILEGES

3、使用MyBatis框架,搭建DAO層:----------------------------Mybatis----------------------

  1)資料庫連接的信息:驅動類、連接地址、用戶名、密碼
<jdbcConnection driverClass="com.mysql.jdbc.Driver"        connectionURL="jdbc:mysql://192.168.41.100:3306/testtest" userId="root"    password="123456"></jdbcConnection>


  2)targetPackage="com.softjx.model"

  3)把表名與類名對應
<table schema="testtest" tableName="school" domainObjectName="School"></table>


  4)運行GeneratorSqlmap.java生成dao和model

第二階段:

1、在MyEclipse上新建一個Web項目,並導入ssm所需的jar包,放在WEB-INF/lib目錄下;

2、將第一階段通過Mybatis框架生成的model和dao複製到當前項目;----------------------------Dao層----------------------

3、搭建Service層:建com.softjx.service與com.softjx,service,impl包;----------------------------spring層----------------------

4、將需要相關的配置文件(mybatisconfig.xml,dbconfig.properties,applicationContext.xml,log4j.properties)放到src目錄下;

  1)修改dbconfig.properties文件,ip,資料庫,用戶名,密碼

  2)修改applicationContext.xml中的包名,目錄名

5、在com.softjx.service包中寫介面,在com.softjx.service.impl寫介面的實現。
  註意:com.softjx.service.impl寫介面的實現,
  @Service("studentService")
  @Transactional

7.單元測試:
  要註意mysql資料庫中主鍵要自增,這一步要我們去mysql中設置。
  studentService = (StudentService) context.getBean("studentService");
  這個"studentService"是從@Service("studentService")

 

第三階段:

1、修改WebRoot目錄下的web.xml如下:

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <web-app version="2.5" 
 3     xmlns="http://java.sun.com/xml/ns/javaee" 
 4     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
 5     xsi:schemaLocation="http://java.sun.com/xml/ns/javaee 
 6     http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
 7   <display-name></display-name>
 8   
 9   
10   
11     <!-- 配置啟動 Spring IOC 容器的 Listener,啟動spring容器 -->
12     <context-param>
13         <param-name>contextConfigLocation</param-name>
14         <param-value>classpath:applicationContext.xml</param-value>
15     </context-param>
16 
17     <listener>
18         <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
19     </listener>
20 
21 
22     <!-- 表單提交controller獲得中文參數後亂碼解決方案 註意: jsp頁面編碼設置為UTF-8 form表單提交方式為必須為post,get方式下麵spring編碼過濾器不起效果 -->
23 
24     <filter>
25         <filter-name>characterEncodingFilter</filter-name>
26         <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
27         <init-param>
28             <param-name>encoding</param-name>
29             <param-value>UTF-8</param-value>
30         </init-param>
31         <init-param>
32             <param-name>forceEncoding</param-name>
33             <param-value>true</param-value>
34         </init-param>
35     </filter>
36     <filter-mapping>
37         <filter-name>characterEncodingFilter</filter-name>
38         <url-pattern>/*</url-pattern>
39     </filter-mapping>
40 
41 
42     <!-- 可以把 POST 請求轉為 DELETE 或 PUT 請求 -->
43 
44     <filter>
45         <filter-name>HiddenHttpMethodFilter</filter-name>
46         <filter-class>org.springframework.web.filter.HiddenHttpMethodFilter</filter-class>
47     </filter>
48 
49     <filter-mapping>
50         <filter-name>HiddenHttpMethodFilter</filter-name>
51         <url-pattern>/*</url-pattern>
52     </filter-mapping>
53 
54 
55 
56     <!-- 配置 DispatcherServlet -->
57     <servlet>
58         <servlet-name>dispatcherServlet</servlet-name>
59         <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
60 
61         <init-param>
62             <param-name>contextConfigLocation</param-name>
63             <param-value>classpath:springmvc.xml</param-value>
64         </init-param>
65 
66         <load-on-startup>1</load-on-startup>
67 
68     </servlet>
69 
70     <servlet-mapping>
71         <servlet-name>dispatcherServlet</servlet-name>
72         <url-pattern>/</url-pattern>
73     </servlet-mapping>
74   
75   
76   
77   
78   
79       
80   <welcome-file-list>
81     <welcome-file>index.jsp</welcome-file>
82   </welcome-file-list>
83 </web-app>

2、在src目錄下建立springmvc.xml文件,文件內容如下:----------------------------SpringMVC層----------------------

<?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:mvc="http://www.springframework.org/schema/mvc"
    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-4.0.xsd
        http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">

    <!-- 配置自定掃描的包 -->
    <context:component-scan base-package="com.softjx" use-default-filters="false">
        <context:include-filter type="annotation" 
            expression="org.springframework.stereotype.Controller"/>
        </context:component-scan>
    
    
    <!-- 配置視圖解析器: 如何把 handler 方法返回值解析為實際的物理視圖 -->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/WEB-INF/views/"></property>
        <property name="suffix" value=".jsp"></property>
    </bean>
    
    
    <!-- 處理靜態資源 -->
    <mvc:default-servlet-handler/>
    
    
    <!-- 預設配置方案。
    並提供了:數據綁定支持,@NumberFormatannotation支持,
    @DateTimeFormat支持,@Valid支持,讀寫XML的支持(JAXB),
    讀寫JSON的支持(Jackson)。
          後面,我們處理響應ajax請求時,就使用到了對json的支持。
     -->
    <mvc:annotation-driven></mvc:annotation-driven>
    

    
     
</beans>

 

3、在src目錄下新建com.softjx.action包,在包里建Action類;

註意:1)@Controller
   @RequestMapping("/student")

  2)每個方法:
   @RequestMapping("/studentAddInput")

 

 

4、在WEB-INF目錄下創建views文件,用來放置所有.jsp文件,這個jsp文件名是作為Action中方法 return的值。;

 

註意:1)在WEB-INF目錄下的jsp頁面只能通過程式來訪問,外部訪問不到。(安全)

 

     2)添加頁面的jsp,要註意控制項的屬性名是javabean的屬性名。 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本文將通過場景例子演示,來通俗易懂的講解在複雜的業務邏輯下,如何以最簡練的代碼,最直觀的編寫事務代碼。 通過一系列優化最終達到兩個效果,1.通過代碼塊來控制事務(分散式事務),2.通過委托優化TransactionScope的編碼寫法。 本文需要的知識點:1. Action委托 2. 分散式事務Tr ...
  • 在ABP官網創建一個.Net Core項目編譯完成 1、 發佈網站 2、 IIS新建站點 目錄指向發佈的目錄 3、安裝WindowsHosting IIS安裝伺服器上安裝DotNetCore.X.X.X-WindowsHosting安裝成功後重啟IIS伺服器。根據版本選擇下載 下載地址:https: ...
  • 一、設計目的:讓項目中只顯示一個實例對象 二、設計步驟: 三、項目相關名詞或知識點解釋 此處類類型:如果當前類為SingleCase,則此靜態變數類型也要為SingleCase類型, 即在此處定義的靜態變數的類型要和這個當前類的類型相同 定義單例實例變數時,儘量都用instance(實例)來指代,方 ...
  • 近乎產品的數據訪問是基於輕量級ORM——PetaPoco,哪怕是他們最新的5.2版本也是基於PetaPoco。至於為什麼沒有選用EF這些ORM,感興趣的可以去咨詢他們的產品人員,本文就不詳細說明瞭。 關於近乎源碼下載:www.jinhusns.com ...
  • Asp.Net Web API不可以需要IIS。可以自己在主機上承載一個Web API 創建WebAPI.Server項目 創建一個控制器項目的服務端 在Nuget中添加Microsoft.AspNet.WebApi.SelfHost 創建Model與Controller 首先在服務端添加一個Pro ...
  • 前兩天做一個項目的時候,由於頁面沒有限制TextBox的輸入長度,所以,後臺直接報錯了,超出資料庫最大的長度。 資料庫的長度是按照位元組來計算的,而且不同的編碼格式,漢字占用的位元組長度又不相同,比如,我們用的是UTF8,一個漢字是3個位元組,而預設的Default,一個漢字是2個位元組。 TextBox有 ...
  • 前言 參與過幾個中小型商城系統的開發,隨著時間的增長,以及對系統的深入研究和測試,發現確實有很多值得推敲和商榷的地方(總有很多重要細節存在缺陷)。基於商城系統,無論規模大小,或者本身是否分佈架構,個人覺得最核心的一環就是下單模塊,而這裡面更相關和棘手的一些設計和問題,大多時候都涉及庫存系統。想想之... ...
  • //用戶去銀行取錢(發佈方),用戶收到簡訊提醒,(接收方) class Program { static void Main(string[] args) { Bank b = new Bank(); //實例化銀行 User xm = new User("... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...