<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>


    posts - 15,  comments - 34,  trackbacks - 27

    Spring對JDBC進行了非常優雅的封裝,通過一系列的模板方法,只需簡單的幾行代碼就可實現數據庫的訪問。通過Spring的JdbcTemplate訪問數據庫從而實現用戶驗證。Access數據庫,建立表Account,包含兩個字段:

        username:VARCHAR(20),主鍵;
        password:VARCHAR(20)。

    然后輸入一些測試數據,注冊到系統DSN,名字為Blog。接下來我們在Tomcat中配置一個名為“jdbc/blog”的DataSource如下:

    如果你使用其他數據庫,只需要保證表的邏輯結構和JDNI名“jdbc/blog”。在AccountManager中,使用JdbcTemplate訪問數據庫來驗證用戶:

        Account getAccount(String username, String password) throws Exception {
            
    // validate the password:
            InitialContext ctx = new InitialContext();
            DataSource dataSource 
    = (DataSource)ctx.lookup("java:comp/env/jdbc/blog");
            JdbcTemplate jt 
    = new JdbcTemplate(dataSource);
            String pass 
    = (String) jt.queryForObject(
                
    "select password from Account where username=?",
                
    new Object[] {username}, String.class);
            
    if(password.equals(pass))
            
    {
                Account account 
    = new Account();
                account.setUsername(username);
                account.setPassword(password);
                
    return account;
            }

            
    throw new Exception("authorization failed.");
        }

     

    編譯運行,輸入hello.c?username=xxx&password=xxx來測試用戶登錄,如果匹配數據庫中的記錄,會顯示出用戶名,否則可以看到authorization failed異常。要更友好的顯示登陸失敗,可以在Controller中導向一個login_failed.jsp并給出登陸失敗的原因。

    下面來看這個AccountManager,很顯然在驗證邏輯中寫入了JNDI查找DataSource的代碼,這將導致比較“生硬”的編碼。“依賴注入”此刻顯示出了威力:讓容器注入DataSource:

    public class AccountManager implements java.io.Serializable {
        
    private DataSource dataSource;
        
    public void setDataSource(DataSource dataSource) {
            
    this.dataSource = dataSource;
        }


        Account getAccount(String username, String password) throws Exception 
    {
            JdbcTemplate jt 
    = new JdbcTemplate(dataSource);
            
        }

    }

    OK,現在這個AccountManager變得優雅多了,現在如何配置DataSource的注入呢?Spring提供了一個DataSourceUtils類,通過靜態方法getDataSourceFromJndi來獲得容器中配置的DataSource。我們添加以下配置:

        <bean id="dataSource"
              class
    ="org.springframework.jdbc.datasource.DataSourceUtils"
              factory-method
    ="getDataSourceFromJndi">
            
    <constructor-arg><value>jdbc/blogvalue>constructor-arg>
        
    bean>
        
    <bean id="accountManager" class="AccountManager">
            
    <property name="dataSource">
                
    <ref bean="dataSource" />
            
    property>
        
    bean>
     
    現在重新部署,效果和以前一樣了,但是相關代碼已被"放到",配置文件中了
    posted on 2005-02-04 11:20 jacky 閱讀(2019) 評論(1)  編輯  收藏 所屬分類: Open source

    FeedBack:
    # re: spring的jdbc封裝
    2011-09-14 14:21 | 呂紅芬
    OK,Thank you !!!  回復  更多評論
      
    <2025年5月>
    27282930123
    45678910
    11121314151617
    18192021222324
    25262728293031
    1234567

    常用鏈接

    留言簿(10)

    隨筆檔案

    文章分類

    文章檔案

    相冊

    收藏夾

    java

    搜索

    •  

    最新評論


    主站蜘蛛池模板: 蜜桃传媒一区二区亚洲AV| 美女被免费网站91色| 在线观看免费av网站| 亚洲国产成人久久一区WWW| 亚洲中文字幕无码av在线| 久久夜色精品国产亚洲AV动态图| 亚洲精品综合一二三区在线| 色偷偷尼玛图亚洲综合| 免费专区丝袜脚调教视频| 亚洲色欲久久久综合网| 亚洲福利一区二区精品秒拍| 久久久受www免费人成| 国产成人免费手机在线观看视频| 国产亚洲精aa成人网站| 亚洲色成人网一二三区| 亚洲AV色欲色欲WWW| 野花香高清在线观看视频播放免费| 免费国产成人高清在线观看网站| 国产成人无码免费视频97| 亚洲国产精品特色大片观看完整版| 精品亚洲AV无码一区二区| 久久精品成人免费看| 免费无码不卡视频在线观看| 亚洲精品成人无限看| 国产午夜亚洲精品| 啦啦啦完整版免费视频在线观看 | 最近中文字幕2019高清免费| 久久久久久A亚洲欧洲AV冫| 成a人片亚洲日本久久| 久久久久成人片免费观看蜜芽 | 一级毛片在线免费播放| 亚洲一级毛片免费观看| 亚洲国产精品lv| 国产成人免费ā片在线观看老同学| 最近2019中文字幕mv免费看| 亚洲精品蜜桃久久久久久| 一级人做人a爰免费视频| 亚洲国产成人乱码精品女人久久久不卡| 久久久亚洲欧洲日产国码是AV| 国产午夜亚洲精品不卡 | 一区二区三区无码视频免费福利|