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

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

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

    sclsch

    java備忘

    BlogJava 首頁(yè) 新隨筆 聯(lián)系 聚合 管理
      10 Posts :: 0 Stories :: 6 Comments :: 0 Trackbacks

    2008年10月28日 #

    package com.secondHand.db;

    import java.math.BigDecimal;
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.ResultSet;
    import java.sql.ResultSetMetaData;
    import java.sql.SQLException;
    import java.sql.Statement;
    import java.util.ArrayList;
    import java.util.Iterator;
    import java.util.List;

    public class DBUtil {
        
    private String url = "jdbc:mysql://localhost:3306/db_secondhand?user=root&password=root";

        
    private String dbUserName = "root";

        
    private String dbUserPassword = "root";

        
    private String driver = "com.mysql.jdbc.Driver";

        
    private Connection conn = null;

        
    private Statement stmt = null;

        
    private ResultSet rs = null;

        
    public DBUtil() {
            
    try {
                Class.forName(driver);
            } 
    catch (ClassNotFoundException e) {
                e.printStackTrace();
            }
        }

        
    private Connection getConnection() {
            
    try {
                conn 
    = DriverManager.getConnection(url, dbUserName, dbUserPassword);
            } 
    catch (SQLException e) {
                e.printStackTrace();
            }
            
    return conn;
        }

        
    private void close(ResultSet rs, Statement stmt, Connection conn) {
            
    if (rs != null) {
                
    try {
                    rs.close();
                } 
    catch (SQLException e) {
                    e.printStackTrace();
                }
            }
            
    if (stmt != null) {
                
    try {
                    stmt.close();
                } 
    catch (SQLException e) {
                    e.printStackTrace();
                }
            }
            
    if (conn != null) {
                
    try {
                    conn.close();
                } 
    catch (SQLException e) {
                    e.printStackTrace();
                }
            }
        }

        
    public List query(String sql) {
            List list 
    = new ArrayList();

            conn 
    = this.getConnection();
            
    try {
                stmt 
    = conn.createStatement();
                rs 
    = stmt.executeQuery(sql);
                
    // 獲取數(shù)據(jù)庫(kù)表結(jié)構(gòu)
                ResultSetMetaData rsm = rs.getMetaData();
                
    // 取得數(shù)據(jù)庫(kù)的列數(shù)
                int col = rsm.getColumnCount();
                
    // 生成col長(zhǎng)度的Object數(shù)組
                Object[] obj = new Object[col];
                
    // 遍歷結(jié)果集,將結(jié)果存入Object數(shù)組
                while (rs.next()) {
                    
    for (int i = 0; i < col; i++) {
                        obj[i] 
    = rs.getObject(i + 1);
                    }
                    list.add(obj);
                }
            } 
    catch (SQLException e) {
                e.printStackTrace();
            } 
    finally {
                
    this.close(rs, stmt, conn);
            }
            
    return list;
        }

        
    public void update(String sql) {
            
    try {
                conn 
    = this.getConnection();
                stmt 
    = conn.createStatement();
                stmt.executeUpdate(sql);
            } 
    catch (SQLException e) {
                e.printStackTrace();
            }
    finally{
                
    this.close(rs, stmt, conn);            
            }
        }

        
    public static void main(String args[]) {
            DBUtil nj 
    = new DBUtil();
            String sql 
    = "select * from users";
            List list 
    = nj.query(sql);
            
    // 返回list的迭代器
            Iterator it = list.iterator();
            
    // 遍歷迭代器,取出結(jié)果
            while (it.hasNext()) {
                Object[] o 
    = (Object[]) it.next();
                
    int id = ((BigDecimal) o[0]).intValue();
                System.out.println(id);
            }

        }
    }
    posted @ 2009-04-03 10:51 sclsch 閱讀(184) | 評(píng)論 (0)編輯 收藏

         摘要: 增加區(qū)域截取屏幕的功能,歡迎試用,簡(jiǎn)單實(shí)用。  閱讀全文
    posted @ 2009-01-27 21:45 sclsch 閱讀(1440) | 評(píng)論 (2)編輯 收藏

    個(gè)人開發(fā)的小巧的屏幕截圖工具,可以全屏截圖,其他功能還待完善。
    下載地址/Files/sclsch/LittleScreenCapture.rar
    posted @ 2009-01-26 18:15 sclsch 閱讀(1208) | 評(píng)論 (0)編輯 收藏

        下拉框是網(wǎng)頁(yè)的重要元素,動(dòng)態(tài)取數(shù)據(jù)并不難,通常的思路是在action中取數(shù)據(jù),然后把數(shù)據(jù)放到request中,最后在頁(yè)面上用標(biāo)簽遍歷數(shù)據(jù),但寫多了,是不是很煩,我想做一個(gè)通用的下拉框標(biāo)簽,只要指明了業(yè)務(wù)接口,并且該接口實(shí)現(xiàn)了特定方法,就可以了。
        首先定義一個(gè)接口,用來取下拉框的數(shù)據(jù)。
       
       1package com.ssh.tag;
       
    2.
       
    3import java.util.List;
       
    4.
       
    5/** 
       6.  * 
    @author 孫程亮 E-mail:sclsch@188.com 
       7.  * 
    @version 創(chuàng)建時(shí)間:Oct 27, 2008 6:59:05 PM
       8.  * 取得下拉框數(shù)據(jù)接口 
       9.  
    */
      
    10public interface SelectorInterface {
      
    11.   public List getVableValueList();
      
    12. }
       
        如果哪個(gè)業(yè)務(wù)層service需要增加下拉框的功能,就需要實(shí)現(xiàn)它。
    例如:
      
       1package com.ssh.entity.board.service;
       
    2.
       
    3import java.util.ArrayList;
       
    4import java.util.List;
       
    5.
       
    6import com.ssh.common.vo.ValueLabelBean;
       
    7import com.ssh.entity.board.dao.IBoardDao;
       
    8import com.ssh.entity.board.model.Board;
       
    9import com.ssh.tag.SelectorInterface;
      
    10import com.sun.java_cup.internal.internal_error;
      
    11.
      
    12/**
      13.  * 
    @author 孫程亮 E-mail:sclsch@188.com
      14.  * 
    @version 創(chuàng)建時(shí)間:Sep 4, 2008 6:36:22 PM
      15.  
    */
      
    16public class BoardServiceImpl implements IBoardService,SelectorInterface{
      
    17.     private IBoardDao boardDao;
      
    18.
      
    19.     public void addBoard(Board b) {
      
    20.        boardDao.addBorad(b);
      
    21.     }
      
    22.
      
    23.     public IBoardDao getBoardDao() {
      
    24.         return boardDao;
      
    25.     }
      
    26.
      
    27.     public void setBoardDao(IBoardDao boardDao) {
      
    28.         this.boardDao = boardDao;
      
    29.     }
      
    30.
      
    31.     public List getAllBoards() {
      
    32.         return this.boardDao.getAllBoards();
      
    33.     }
      
    34.     /**
      35.      * 用來實(shí)現(xiàn)下拉框的方法,
      36.      * 把下拉數(shù)據(jù)存放在ValuLabelBean中,再存放在list中返回
      37.      * 給自定義標(biāo)簽。
      38.      * 
    @return 下拉數(shù)據(jù)集合
      39.      
    */
      
    40.     public List getVableValueList() {
      
    41.         List list = this.boardDao.getAllBoards();
      
    42.         List valueLableList = new ArrayList();
      
    43.         for(int i=0;i<list.size();i++){
      
    44.           Board board = (Board)list.get(i);
      
    45.           ValueLabelBean vlb = new ValueLabelBean();
      
    46.           vlb.setValue(board.getId().toString());
      
    47.           vlb.setLabel(board.getName());
      
    48.           valueLableList.add(vlb);
      
    49.         }
      
    50.         return valueLableList;
      
    51.     }
      
    52. }
        注意數(shù)據(jù)必須放在ValueLabelBean中,label表示下拉框顯示的數(shù)據(jù),value表示下拉框的value值,下面是ValueLabelBean
    這個(gè)bean:
       1package com.ssh.common.vo;
       
    2.
       
    3import java.io.Serializable;
       
    4.
       
    5/**
       6.  * 
    @author 孫程亮 E-mail:sclsch@188.com
       7.  * 
    @version 創(chuàng)建時(shí)間:Oct 27, 2008 7:00:36 PM
       8.  
    */
       
    9public class ValueLabelBean implements Serializable {
      
    10.     private String value;
      
    11.     private String label;
      
    12.
      
    13.     public String getValue() {
      
    14.         return value;
      
    15.     }
      
    16.
      
    17.     public void setValue(String value) {
      
    18.         this.value = value;
      
    19.     }
      
    20.
      
    21.     public String getLabel() {
      
    22.         return label;
      
    23.     }
      
    24.
      
    25.     public void setLabel(String label) {
      
    26.         this.label = label;
      
    27.     }
      
    28. }

       下面就是寫tag了,暫時(shí)設(shè)置了三個(gè)屬性 tagId,serviceBean和title,
    tagId:select 的 id 屬性值。
    serviceBean:對(duì)應(yīng)于spring容器中service的id。
    title:select的默認(rèn)選中項(xiàng)。
       1package com.ssh.tag;
       
    2.
       
    3import java.io.IOException;
       
    4import java.lang.reflect.Method;
       
    5import java.util.List;
       
    6.
       
    7import javax.servlet.jsp.JspException;
       
    8import javax.servlet.jsp.tagext.TagSupport;
       
    9.
      
    10import org.springframework.context.support.AbstractApplicationContext;
      
    11import org.springframework.util.StringUtils;
      
    12import org.springframework.web.context.WebApplicationContext;
      
    13import org.springframework.web.context.support.WebApplicationContextUtils;
      
    14import org.springframework.web.util.JavaScriptUtils;
      
    15import com.ssh.common.util.*;
      
    16import com.ssh.entity.board.service.IBoardService;
      
    17import com.sun.org.apache.xml.internal.utils.ObjectPool;
      
    18import com.ssh.common.vo.*;
      
    19import com.ssh.tag.*;
      
    20/**
      21.  * 
      22.  * 
    @author 孫程亮 E-mail:sclsch@188.com
      23.  * 
    @version 創(chuàng)建時(shí)間:Oct 25, 2008 10:22:18 AM
      24.  
    */
      
    25public class SelectorTag extends TagSupport {
      
    26.     
      
    27.     private String tagId;      //select's id
      28.     private String serviceBean;//service
      29.     private String title;      //select's title
      30.     
      
    31.     public int doEndTag() throws JspException {
      
    32.       WebApplicationContext applicationContext =  WebApplicationContextUtils.getWebApplicationContext(pageContext.getServletContext());
      
    33.       SelectorInterface selectorInterface = (SelectorInterface)applicationContext.getBean(serviceBean);
      
    34.       List list1 = selectorInterface.getVableValueList();
      
    35.       //List list = ServiceLocator.getSelectorService(serviceBean).getVableValueList();
      36.       StringBuffer sBuffer = new StringBuffer();
      
    37.       sBuffer.append("<select id='"+this.tagId);
      
    38.
      
    39.       sBuffer.append("'>");
      
    40.       if(!StringUtil.isBlank(title)){
      
    41.           sBuffer.append("<option value='-1' selected>"+title+"</option>");
      
    42.       }
      
    43.       for(int i=0;i<list1.size();i++){
      
    44.         ValueLabelBean vlb =  (ValueLabelBean)list1.get(i);
      
    45.         sBuffer.append("<option value='"+vlb.getValue()+"'>"+vlb.getLabel()+"</option>");
      
    46.       }
      
    47.       sBuffer.append("</select>");
      
    48.       try {
      
    49.         pageContext.getOut().println(sBuffer.toString());
      
    50.     } catch (IOException e) {
      
    51.         // TODO Auto-generated catch block
      52.         e.printStackTrace();
      
    53.     }
      
    54.       return EVAL_PAGE;
      
    55.     }
      
    56.     public void setTagId(String tagId) {
      
    57.         this.tagId = tagId;
      
    58.     }
      
    59.     public void setServiceBean(String serviceBean) {
      
    60.         this.serviceBean = serviceBean;
      
    61.     }
      
    62.     public void setTitle(String title) {
      
    63.         this.title = title;
      
    64.     }
      
    65. }

    在標(biāo)簽中可以用WebApplicationContextUtils來得到context,曾一度起了彎路,想到用一個(gè)工具類加載容器,倒也能實(shí)現(xiàn),也想到用反射,但是行不通的。 看來變通一下,可能會(huì)少走很多彎路。
       下面是tld文件:
    <?xml version="1.0" encoding="UTF-8" ?>
     <!DOCTYPE taglib PUBLIC
         "-//Sun Microsystems, Inc.//DTD JSP Tag Library 1.2//EN"
         "http://java.sun.com/dtd/web-jsptaglibrary_1_2.dtd">

     <taglib>

         <tlib-version>1.0</tlib-version>
         <jsp-version>1.0</jsp-version>
         <short-name>sclschTag</short-name>
         <description>sclschTag</description>

         <tag>
             <name>selectorTag</name>
             <tag-class>com.ssh.tag.SelectorTag</tag-class>
             <body-content>JSP</body-content>
             <description>
             </description>
             <attribute>
                 <name>tagId</name>
                 <required>true</required>
                 <rtexprvalue>true</rtexprvalue>
             </attribute>

             <attribute>
                 <name>serviceBean</name>
                 <required>true</required>
                 <rtexprvalue>true</rtexprvalue>
             </attribute>
             <attribute>
                 <name>title</name>
                 <required>false</required>
                 <rtexprvalue>true</rtexprvalue>
             </attribute>
         </tag>

     </taglib>
    最后就剩頁(yè)面了:
      <%@ page language="java" contentType="text/html; charset=UTF-8"
         pageEncoding
    ="UTF-8"%>
     
    <%@ taglib uri="/WEB-INF/tld/selectorTag.tld" prefix="sclsch"%>
     
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
     
    <html xmlns="http://www.w3.org/1999/xhtml" lang="zh-CN">
     
    <head>
     
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
     
    <title>mytag(sclsch@188.com)</title>
     
    </head>
     
    <body>
     
    <sclsch:selectorTag tagId='myid' title="--請(qǐng)選擇--" serviceBean="boardService" />
     
    </body>
     
    </html>

        好了,盡管這個(gè)tag很簡(jiǎn)陋,但為以后省了不少工,只要在業(yè)務(wù)層實(shí)現(xiàn)一個(gè)SelectorInterface接口,在頁(yè)面上擺個(gè)標(biāo)簽就可以了。我剛學(xué)標(biāo)簽的編寫,有什么不足請(qǐng)指正,如果有更好的設(shè)計(jì)一定告訴我額。


    posted @ 2008-10-28 20:57 sclsch 閱讀(742) | 評(píng)論 (0)編輯 收藏

    主站蜘蛛池模板: 久久亚洲精品成人无码| 久久不见久久见免费影院| 亚洲精品国产精品| 亚洲成人精品久久| 亚洲成av人片不卡无码久久| 国产片AV片永久免费观看 | 免费污视频在线观看| 亚洲精品国产首次亮相| 91亚洲性爱在线视频| 亚洲国产国产综合一区首页| 亚洲人妻av伦理| 国产一区二区三区在线免费| 国产精品美女午夜爽爽爽免费| 95免费观看体验区视频| 免费无码av片在线观看| 国产精品视频全国免费观看| 豆国产96在线|亚洲| 亚洲日韩av无码中文| 亚洲 暴爽 AV人人爽日日碰| 亚洲欧洲国产经精品香蕉网| 亚洲另类激情综合偷自拍| 亚洲精品狼友在线播放| 亚洲熟妇av一区二区三区漫画| 亚洲婷婷国产精品电影人久久| 四虎永久免费影院| 国产美女无遮挡免费视频| 免费毛片在线播放| 永久免费毛片手机版在线看| 青青草国产免费久久久下载| 国产香蕉九九久久精品免费| 成人免费午夜无码视频 | 2020国产精品亚洲综合网| 亚洲天堂一区在线| 亚洲黄色在线电影| 亚洲AV色香蕉一区二区| 久久久久亚洲Av片无码v| 亚洲AV日韩精品久久久久久| 亚洲AV成人片色在线观看高潮 | 国产午夜不卡AV免费| 久久精品无码精品免费专区| 无码A级毛片免费视频内谢|