<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 閱讀(2018) 評論(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

    搜索

    •  

    最新評論


    主站蜘蛛池模板: 亚洲综合久久精品无码色欲| 亚洲高清在线mv| 黄桃AV无码免费一区二区三区 | 亚洲AV无码一区二区三区DV | 日韩亚洲人成在线| 99在线精品视频观看免费| 亚洲美女人黄网成人女| 三年片在线观看免费观看大全一| 亚洲av永久无码精品漫画| 曰批全过程免费视频在线观看无码 | 亚洲人成人77777在线播放| 毛片a级毛片免费观看免下载 | 久久久久久久岛国免费播放| 亚洲专区先锋影音| 69式国产真人免费视频| 在线亚洲高清揄拍自拍一品区| 性色av免费观看| 一本岛v免费不卡一二三区| 亚洲国产精品成人精品无码区在线| 久久免费观看国产99精品| 91亚洲精品自在在线观看| 国产又大又长又粗又硬的免费视频| 在线观看亚洲免费| 亚洲人成依人成综合网| 亚洲人成免费网站| 亚洲GV天堂GV无码男同| 国精无码欧精品亚洲一区 | 成年美女黄网站18禁免费| 免费一区二区无码视频在线播放| 成人免费无毒在线观看网站| 色多多免费视频观看区一区| 中文字幕亚洲电影| 亚洲免费在线观看视频| 黄网站色视频免费看无下截| 911精品国产亚洲日本美国韩国| 在线a毛片免费视频观看| 两个人看的www免费视频中文| 亚洲国产精品成人久久久| 国产免费的野战视频| 羞羞视频免费网站含羞草| 色婷婷亚洲十月十月色天|