Java swing實現酒店管理系統


今天給大家提供一個由今天給大家提供一個由Java swing實現的酒店管理系統,數據庫采用sqlserver,我會貼上部分代碼,完整的代碼請看文章最下方下載,下面看代碼:

1.主框架代碼:

package 主框架窗口;
 
import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.Dimension;
import java.awt.FlowLayout;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.MouseEvent;
import java.awt.event.MouseListener;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
 
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JMenu;
import javax.swing.JMenuBar;
import javax.swing.JMenuItem;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JSplitPane;
import javax.swing.JToolBar;
import javax.swing.border.LineBorder;
import javax.swing.table.DefaultTableModel;
 
import com.sunshine.sunsdk.system.suntools;
 
import sunsdk.sql.Journal;
import sunsdk.sql.sunsql;
import sunsdk.swing.TJButton;
import 關於我們.About;
import 團體開單.Team;
import 客戶管理.Customer;
import 客房預定.Engage;
import 賓客結賬.CheckOut;
import 散客開單.Individual;
import 系統設置.Setup;
import 網絡設置.NetSetup;
import 菜單事件窗口.ApartBill;
import 菜單事件窗口.Change;
import 菜單事件窗口.GoOn;
import 菜單事件窗口.Record;
import 菜單事件窗口.UniteBill;
import 營業查詢.Query;
//加入公共類庫
//加入模塊類庫
//散客開單
//團體開單
//賓客結帳
//預訂房間
//營業查詢
//客戶管理
//網絡設置
//系統設置
//關於我們
//下拉菜單中的功能庫
 
 
 
public class HotelFrame 
extends JFrame 
implements ActionListener, MouseListener, Runnable {
 
 //用戶名,權限
 public static String userid, puil;
 public static JLabel lbA, lbB;
 public static String clue = " 提 示 : ";
 public static String face = " 當前操作界面 : ";
 
 //聲名與菜單相關的類
 private JMenuBar mb;
 private JMenu m1, m2, m3, m4;
 private JMenuItem mi11, mi12, mi13, mi14, mi15, mi16, mi17, mi18, mi19,
 mi21, mi22, mi23, mi24, mi25,
 mi31, mi32, mi33, mi34, mi35, mi36;
 //工具欄
 private JToolBar tb;
 private JButton bt1, bt2, bt3, bt4, bt5, bt6, bt7, bt8, bt9, btA;
 //分割面板
 private JSplitPane spaneMain, spaneLeft, spaneRight;
 //模塊接口
 private JPanel panelMain, bott, jp2, jp3, jp4;
 private LeftTopPanel jp1; //主窗口左邊面板
 //功能提示
 private String toolTip[] = {
 "零散賓客入住登記                    ",
 "團體入住登記                      ",
 "關於本軟件的支持信息                  ",
 "賓客退房結算                      ",
 "為賓客預訂房間                     ",
 "查詢營業情況                      ",
 "為酒店固定客戶設置參數                 ",
 "設置系統的網絡連接方式                 ",
 "設置系統參數                      ",
 "返回Windows                      "
 };
 
 //功能模塊
 /*#######################################################################*/
 Individual idv = new Individual(this); //散客開單
 Team tm = new Team(this); //團體開單
 CheckOut co = new CheckOut(this); //賓客結帳
 Engage eg = new Engage(this); //客房預定
 Query qr = new Query(this); //營業查詢
 Customer ct = new Customer(this); //客戶管理
 NetSetup ns = new NetSetup(this); //網絡設置
 Setup st = new Setup(this); //系統設置
 About ab = new About(this); //關於我們 
 GoOn go = new GoOn(this); //賓客續住
 Change cg = new Change(this); //更換房間
 // Remind rm = new Remind(this); //電子提醒
 UniteBill ub = new UniteBill(this); //合並帳單
 ApartBill ap = new ApartBill(this); //拆分帳單
 Record rc = new Record(this); //系統日志
 /*#######################################################################*/
 
 
 
 //構造函數
 public HotelFrame (String us, String pu) {
 super ("陽光酒店管理系統 - ★★版");
 
 userid = us; //獲得操作員名稱
 puil = pu; //獲得操作員權限
 
 panelMain = new JPanel (new BorderLayout()); //主面板
 
 //制作菜單
 buildMenuBar ();
 //制作工具欄
 buildToolBar ();
 //制作分割面板
 buildSpaneMain ();
 //制作窗口底端信息框
 buildBott ();
 
 //加入組件到主面板
 panelMain.add ("North", tb); //加入工具欄
 panelMain.add ("South", bott); //加入窗口底端信息框
 panelMain.add ("Center", spaneMain); //加入分割面板
 
 //加入菜單欄
 this.setJMenuBar (mb);
 
 //加事件監聽
 addListener ();
 
 this.addWindowListener (new WindowAdapter () {
 public void windowClosing (WindowEvent we) {
 quit ();
 }//End windowClosing
 });
 
 this.setContentPane (panelMain);
 this.setBounds (2, 2, 1020, 740);
 this.setDefaultCloseOperation (JFrame.DO_NOTHING_ON_CLOSE);
 this.setMinimumSize (new Dimension (1020, 740)); //設置窗口最小尺寸
 this.setVisible (true);
 (new Thread(this)).start(); //啟動房間狀態檢查線程
 }
 
 //制作菜單
 private void buildMenuBar () {
 //實例菜單欄
 mb = new JMenuBar ();
 
 //實例菜單
 m1 = new JMenu ("來賓登記 (B)");
 m2 = new JMenu ("收銀結算 (S)");
 m3 = new JMenu ("系統維護 (W)");
 
 //實例菜單項
 mi11 = new JMenuItem ("散客開單  (G)");
 mi12 = new JMenuItem ("團體開單  (M)");
 mi13 = new JMenuItem ("賓客續住  (Z)");
 mi14 = new JMenuItem ("更換房間  (A)");
 mi15 = new JMenuItem ("修改登記  (J)");
 mi16 = new JMenuItem ("房間狀態  (Z)");
 mi17 = new JMenuItem ("預訂管理  (T)");
 mi18 = new JMenuItem ("電子提醒  (L)");
 mi19 = new JMenuItem ("退出系統  (X)");
 mi21 = new JMenuItem ("賓客結帳  (J)");
 mi22 = new JMenuItem ("合並帳單  (E)");
 mi23 = new JMenuItem ("折分帳單  (F)");
 mi24 = new JMenuItem ("賓客消費明細查詢");
 mi25 = new JMenuItem ("賓客退單明細查詢");
 mi31 = new JMenuItem ("網絡設置  (N)");
 mi32 = new JMenuItem ("系統設置  (X)");
 mi33 = new JMenuItem ("系統日志  (Z)");
 mi34 = new JMenuItem ("數據備份  (R)");
 mi35 = new JMenuItem ("軟件幫助  (H)");
 mi36 = new JMenuItem ("關於我們  (A)");
 ///////////////////////////////////////////
 mi16.setEnabled(false);//未開發完畢的功能
 mi18.setEnabled(false);
 mi34.setEnabled(false);
 ////////////////////////////////////////////
 //組織菜單
 m1.add (mi11); //來賓登記
 m1.add (mi12);
 m1.add (mi13);
 m1.add (mi14);
 m1.add (mi15);
 m1.add (mi16);
 m1.addSeparator();
 m1.add (mi17);
 m1.add (mi18);
 m1.addSeparator();
 m1.add (mi19);
 
 m2.add (mi21); //收銀結算
 m2.add (mi22);
 m2.add (mi23);
 //m2.addSeparator();
 //m2.add (mi24); //賓客消費明細
 //m2.add (mi25);
 m3.add (mi31); //系統維護
 m3.add (mi32);
 m3.add (mi33);
 m3.addSeparator();
 m3.add (mi34);
 m3.addSeparator();
 m3.add (mi35);
 m3.add (mi36);
 
 mb.add (m1); //加入菜單欄
 mb.add (m2);
 mb.add (m3);
 }
 
 //制作工具欄
 private void buildToolBar () {
 tb = new JToolBar();
 //制作按鍵
 bt1 = new TJButton ("pic/ToolBar/m01.gif", " 散客開單 ", "零散賓客入住登記", true);
 bt2 = new TJButton ("pic/ToolBar/m02.gif", " 團體開單 ", "團體入住登記", true);
 bt3 = new TJButton ("pic/ToolBar/m03.gif", " 關於我們 ", "軟件信息", true);
 bt4 = new TJButton ("pic/ToolBar/m04.gif", " 賓客結帳 ", "賓客退房結算", true);
 bt5 = new TJButton ("pic/ToolBar/m05.gif", " 客房預訂 ", "為賓客預定房間", true);
 bt6 = new TJButton ("pic/ToolBar/m06.gif", " 營業查詢 ", "查詢營業情況", true);
 bt7 = new TJButton ("pic/ToolBar/m07.gif", " 客戶管理 ", "為酒店固定客戶設置", true);
 bt8 = new TJButton ("pic/ToolBar/m08.gif", " 網絡設置 ", "設置連接方式", true);
 bt9 = new TJButton ("pic/ToolBar/m09.gif", " 系統設置 ", "設置系統參數", true);
 btA = new TJButton ("pic/ToolBar/m10.gif", " 退出系統 ", "返回Windows", true);
 
 //把按鍵加入工具欄
 tb.addSeparator ();
 tb.add (bt1);
 tb.add (bt2);
 tb.addSeparator ();
 tb.add (bt4);
 tb.add (bt5);
 tb.add (bt6);
 tb.addSeparator ();
 tb.add (bt7);
 tb.add (bt8);
 tb.add (bt9);
 tb.addSeparator ();
 tb.add (bt3);
 tb.addSeparator ();
 tb.add (btA);
 
 //設置工具欄不可浮動
 tb.setFloatable(false);
 }
 
 //制作主面板
 private void buildSpaneMain () {
 
 jp1 = new LeftTopPanel (); //這四個面板為功能接口//////////////
 jp2 = new LeftBottPanel(); //左下面板 快速通道
 jp3 = new RightTopPanel(); ///////////////////////////////
 jp4 = new RightBottPanel(); //右下面板 消費信息表
 
 //聲名分割面板
 spaneLeft = new JSplitPane(JSplitPane.VERTICAL_SPLIT, true, jp1, jp2);
 spaneRight = new JSplitPane(JSplitPane.VERTICAL_SPLIT, true, jp3, jp4);
 spaneMain = new JSplitPane(JSplitPane.HORIZONTAL_SPLIT, true, spaneLeft, spaneRight);
 
 //設置面板最小尺寸
 jp1.setMinimumSize(new Dimension (157, 450));
 jp2.setMinimumSize(new Dimension (157, 94));
 jp3.setMinimumSize(new Dimension (875, 300));
 jp4.setMinimumSize(new Dimension (875, 94));
 spaneRight.setMinimumSize(new Dimension (875, 565));
 
 //設置分割條是否有伸縮鍵
 spaneMain.setOneTouchExpandable (true);
 spaneRight.setOneTouchExpandable(true);
 
 //設置各面板的初起尺寸
 spaneMain.setDividerLocation (160);
 spaneLeft.setDividerLocation (450);
 spaneRight.setDividerLocation(450);
 
 //設置分隔條寬度
 spaneMain.setDividerSize (10);
 spaneLeft.setDividerSize (23);
 spaneRight.setDividerSize(23);
 }
 
 //制作bott欄
 private void buildBott () {
 JLabel lb1, lb2;
 
 lb1 = new JLabel(" 陽 光 酒 店 管 理 系 統 ");
 lb2 = new JLabel(" 當前操作員 : " + userid + "  ");
 lbA = new JLabel(clue + "請選擇功能項 ...                     ");
 lbB = new JLabel(face + "陽 光 酒 店 管 理 系 統 - ★★ 版 ");
 
 //加外框線
 lbA.setBorder(new LineBorder(new Color(87, 87, 47)));
 lbB.setBorder(new LineBorder(new Color(87, 87, 47)));
 lb1.setBorder(new LineBorder(new Color(87, 87, 47)));
 lb2.setBorder(new LineBorder(new Color(87, 87, 47)));
 
 bott = new JPanel(new FlowLayout(FlowLayout.LEFT, 2, 2));
 
 bott.add (lb1);
 bott.add (lbA);
 bott.add (lbB);
 bott.add (lb2);
 }
 
 //加事件監聽
 private void addListener () {
 mi11.addActionListener (this); //來賓登記
 mi12.addActionListener (this);
 mi13.addActionListener (this);
 mi14.addActionListener (this);
 mi15.addActionListener (this);
 mi16.addActionListener (this);
 mi17.addActionListener (this);
 mi18.addActionListener (this);
 mi19.addActionListener (this);
 mi21.addActionListener (this); //收銀結算
 mi22.addActionListener (this);
 mi23.addActionListener (this);
 mi24.addActionListener (this);
 mi25.addActionListener (this);
 mi31.addActionListener (this); //系統維護
 mi32.addActionListener (this);
 mi33.addActionListener (this);
 mi34.addActionListener (this);
 mi35.addActionListener (this);
 mi36.addActionListener (this);
 bt1.addActionListener (this); //按鍵加動作監聽
 bt2.addActionListener (this);
 bt3.addActionListener (this);
 bt4.addActionListener (this);
 bt5.addActionListener (this);
 bt6.addActionListener (this);
 bt7.addActionListener (this);
 bt8.addActionListener (this);
 bt9.addActionListener (this);
 btA.addActionListener (this);
 bt1.addMouseListener (this); //按鍵加鼠標監聽
 bt2.addMouseListener (this);
 bt3.addMouseListener (this);
 bt4.addMouseListener (this);
 bt5.addMouseListener (this);
 bt6.addMouseListener (this);
 bt7.addMouseListener (this);
 bt8.addMouseListener (this);
 bt9.addMouseListener (this);
 btA.addMouseListener (this);
 }
 
 /**=======================================================================**
 * [## private void quit () {} ]: 系統退出
 * 參數 :無
 * 返回值 :無
 * 修飾符 :private
 * 功能 :關閉系統函數,僅類內使用
 **=======================================================================**
 */
 private void quit () {
 int flag = 0;
 String msg = "您 現 在 要 關 閉 系 統 嗎 ?";
 flag = JOptionPane.showConfirmDialog (null, msg, "提示", JOptionPane.YES_NO_OPTION);
 if(flag == JOptionPane.YES_OPTION) {
 Journal.writeJournalInfo(userid, "退出本系統", Journal.TYPE_LG);//記錄操作日志
 this.setVisible (false);
 System.exit (0);
 }//End if(flag == JOptionPane.YES_OPTION)
 return;
 }
 
 //刷新左房間信息欄數據
 private void initLeftData() {
 jp1.title1.setText(""); //刷房間信息
 for (int i = 0; i < 8; i++) {
 jp1.lt[i].setText("");
 }//Endfor
 jp1.initRoomstate(); //刷新房間總狀態
 }
 
 //傳數據給散客開單窗口
 private boolean initIDV() {
 try {
 //從房間信息表里獲得當前房間的狀態和房間類型編號
 ResultSet rs = sunsql.executeQuery("select state,r_type_id from roominfo " +
 "where delmark=0 and id='" + LeftTopPanel.title1.getText() + "'");
 
 if(!rs.next()) { //如果無結果集,提示用戶刷新房間數據
 if(LeftTopPanel.title1.getText().length() == 0) {
 JOptionPane.showMessageDialog(null,"請選定房間后,再為賓客開設房間", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 }else {
 JOptionPane.showMessageDialog(null, "[ " + LeftTopPanel.title1.getText() + 
 " ] 房間信息已更改,請刷新房間信息,再為賓客開設房間", "提示", JOptionPane.INFORMATION_MESSAGE);
 }
 return false;
 }else {
 if(!rs.getString(1).equals("可供")) { //只有狀態是可供房間,才能為賓客開設
 JOptionPane.showMessageDialog(null, "請選擇空房間,再為賓客開設房間", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 return false;
 }//Endif
 
 //傳房間號到開單窗口
 Individual.lbA.setText(LeftTopPanel.title1.getText());
 //傳房間類型到開單窗口
 Individual.lbB.setText(LeftTopPanel.title0.getText().substring(0, 
 LeftTopPanel.title0.getText().length()-2));
 //傳房間單價到開單窗口
 Individual.lbC.setText(LeftTopPanel.lt[1].getText());
 
 //房間類型編號
 String clRoom = rs.getString(2);
 //獲得此類型房間是否可以開設鍾點房
 rs = sunsql.executeQuery("select cl_room from roomtype where " +
 "delmark=0 and id='" + clRoom + "'");
 rs.next();
 if(rs.getString(1).equals("N")) { //不能開設,則開單窗口的鍾點選項不可用
 Individual.chk1.setSelected(false); //取消選中狀態
 Individual.chk1.setEnabled(false); //設置不可用
 }else {
 Individual.chk1.setEnabled(true); //可用
 }//Endif
 
 //傳賓客類型數據給開單窗口
 rs = sunsql.executeQuery("select distinct c_type from customertype where " +
 "delmark = 0 and pk!=0");
 int ct = sunsql.recCount(rs);
 String cType[] = new String[ct];
 for (int i = 0; i < ct; i++) {
 rs.next();
 cType[i] = rs.getString(1);
 }//Endfor
 Individual.cb2.removeAllItems();
 for (int i = 0; i < ct; i++) {
 Individual.cb2.addItem(cType[i]);
 }//Endfor
 Individual.cb2.setSelectedItem("普通賓客");
 
 //初始化開單房間表---------臨時表
 sunsql.executeUpdate("delete from roomnum"); //清空臨時表
 sunsql.executeUpdate("insert into roomnum(roomid) values('" + 
 LeftTopPanel.title1.getText() + "')"); //加入當前房間信息
 //初始化開單窗口的開單房間表
 sunsql.initDTM(Individual.dtm2,"select roomid 房間編號 from roomnum");
 
 //初始化追加房間表---------當前類型的除當前房間的所有可供房間
 sunsql.executeUpdate("update roominfo set indimark=0"); //刷新所有房間的開單狀態
 sunsql.executeUpdate("update roominfo set indimark=1 where id='" + 
 LeftTopPanel.title1.getText() + "'"); //設置當前房間為開單狀態
 //初始化開單窗口的可供房間表
 sunsql.initDTM(Individual.dtm1,"select a.id 房間編號1 from roominfo " +
 "a,(select id from roomtype where r_type='" + Individual.lbB.getText() + 
 "') b where a.delmark=0 and a.indimark=0 and a.state='可供' and a.r_type_id=b.id");
 
 }//Endif
 }
 catch (Exception ex) {
 System.out.println ("HotelFrame.initIDV(): false");
 }//End try
 return true;
 }
 
 //傳數據給團體開單窗口
 private boolean initTeam() {
 try {
 //初始化開單房間表---------臨時表
 sunsql.executeUpdate("delete from roomnums"); //清空臨時表
 //初始化開單窗口的開單房間表
 Team.initDTM2();
 
 //初始化追加房間表---------當前類型的除當前房間的所有可供房間
 sunsql.executeUpdate("update roominfo set indimark=0"); //刷新所有房間的開單狀態
 
 //傳房間類型數據給團體開單窗口
 ResultSet rs = sunsql.executeQuery("select r_type from roomtype where delmark=0");
 int ct = sunsql.recCount(rs);
 String type[] = new String[ct];
 
 //傳賓客房型數據給團體開單窗口
 for (int i = 0; i < ct; i++) {
 rs.next();
 type[i] = rs.getString(1);
 }//Endfor
 Team.cb.removeAllItems();
 for (int i = 0; i < ct; i++) {
 Team.cb.addItem(type[i]);
 }//Endfor
 
 //傳賓客類型數據給團體開單窗口
 rs = sunsql.executeQuery("select distinct c_type from customertype where " +
 "delmark = 0 and pk!=0");
 ct = sunsql.recCount(rs);
 for (int i = 0; i < ct; i++) {
 rs.next();
 type[i] = rs.getString(1);
 }//Endfor
 Team.cb2.removeAllItems();
 for (int i = 0; i < ct; i++) {
 Team.cb2.addItem(type[i]);
 }//Endfor
 Team.cb2.setSelectedItem("普通賓客");
 }
 catch (Exception ex) {
 System.out.println ("HotelFrame.initTeam(): false");
 }//Endtry
 return true;
 }
 
 //傳數據給結算窗口
 private boolean initCKO() {
 try {
 ResultSet rs = sunsql.executeQuery("select state,r_type_id from roominfo " +
 "where delmark=0 and id='" + LeftTopPanel.title1.getText() + "'");
 
 if(!rs.next()) { //如果無結果集,提示用戶刷新房間數據
 if(LeftTopPanel.title1.getText().length() == 0) {
 JOptionPane.showMessageDialog(null,"請選定賓客入住的房間后,再為賓客結算費用", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 }else {
 JOptionPane.showMessageDialog(null, "[ " + LeftTopPanel.title1.getText() + 
 " ] 房間信息已更改,請刷新房間信息,再為賓客開設房間", "提示", JOptionPane.INFORMATION_MESSAGE);
 }//Endif
 return false;
 }else {
 //只有狀態是占用或鍾點房間,才能為賓客結算
 if(!rs.getString(1).equals("占用") && !rs.getString(1).equals("鍾點")) {
 JOptionPane.showMessageDialog(null, "請選擇賓客正在消費的房間進行結算費用操作", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 return false;
 }//Endif
 
 //傳結算單號給結算窗口
 co.lbA.setText(suntools.getNumber(suntools.Number_JS));
 //傳結算房間給結算窗口
 co.lbB.setText(jp1.title1.getText());
 //傳結算賓客名稱給結算窗口
 co.lbC.setText(jp1.lt[0].getText());
 //傳押金給結算窗口
 co.lbF.setText(jp1.lt[6].getText());
 
 //清空結算中間表
 sunsql.executeUpdate("delete from checkout_temp");
 
 //獲得主房間號
 rs = sunsql.executeQuery("select main_room,in_no from livein where " +
 "delmark=0 and r_no='" + co.lbB.getText() + "' and statemark='正在消費'");
 
 if(!rs.next()) {
 JOptionPane.showMessageDialog(null, "操作失敗,請檢查網絡情況", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 return false;
 }//Endif
 
 String mainRoom = rs.getString(1); //取出主房間號
 co.inNo = rs.getString(2); //傳入住單號為結算窗口
 
 //獲得主房間狀態,看是普通住宿還是鍾點房
 rs = sunsql.executeQuery("select state from roominfo where delmark=0 and id='" + mainRoom + "'"); 
 rs.next();
 int mrState = 0; //主房間狀態 0:普通入住 1:鍾點房
 if(rs.getString(1).equals("鍾點")) {
 mrState = 1;
 }//Endif
 
 DefaultTableModel ckoDTM = new DefaultTableModel(); //主房間下的所有房間信息
 sunsql.initDTM(ckoDTM, "select pk,r_no,r_type_id,c_type_id,in_time,foregift from " +
 "livein where delmark=0 and main_room='" + mainRoom + "'");
 
 double total = 0; //消費總金額
 double shsh = 0; //實收金額
 double youh = 0; //優惠金額
 for (int i = 0; i < ckoDTM.getRowCount(); i++) {
 //取出當前房間的標准單價
 rs = sunsql.executeQuery("select price,cl_price from roomtype where delmark=0 and id='" + 
 ckoDTM.getValueAt(i, 2) + "'");
 rs.next();
 double rprice = 0;
 double days = 0;
 if(mrState == 0) {
 rprice = rs.getDouble(1); //普通入住單價
 //獲得入住天數
 days = suntools.getConsumeFactor(ckoDTM.getValueAt(i, 4) + "", Journal.getNowDTime());
 }else {
 rprice = rs.getDouble(2); //鍾點房單價
 days = suntools.getClockFactor(ckoDTM.getValueAt(i, 4) + "", Journal.getNowDTime());
 }//Endif
 
 double rd = rprice * days; //當前房間的消費總金額
 total = total + rd; //累加總消費
 rs = sunsql.executeQuery("select discount from customertype where delmark=0 and " +
 "id='" + ckoDTM.getValueAt(i, 3) + "' and dis_attr='" + ckoDTM.getValueAt(i, 2) + "'");
 rs.next();
 //取出賓客享受的折扣
 int dst = rs.getInt(1);
 double ddr = rd * dst/10; //當前房間的打折后價格
 shsh = shsh + ddr; //應收金額累加
 youh = youh + rd - ddr; //優惠金額累加
 
 //向結算中間表加入數據
 sunsql.executeUpdate("insert into checkout_temp(pk,r_type_id,r_no,price," +
 "discount,dis_price,account,money,in_time) values(" + ckoDTM.getValueAt(i, 0) +
 ",'" + ckoDTM.getValueAt(i, 2) + "','" + ckoDTM.getValueAt(i, 1) + "'," + 
 rprice + "," + dst + "," + rprice * dst / 10 + "," + days + "," + ddr + ",'" + 
 ckoDTM.getValueAt(i, 4) + "')");
 }
 
 //傳消費金額給結算窗口
 co.lbD.setText(total + "");
 //傳應收金額給結算窗口
 co.lbE.setText(shsh + "");
 //傳實收金額
 co.tf1.setText(shsh + "");
 //傳優惠金額給結算窗口
 co.lbG.setText(youh + "");
 //傳找零金額給結算窗口
 co.lbH.setText(Double.parseDouble(co.lbF.getText()) - shsh + "");
 
 //刷新結算中間表數據
 co.initDTM();
 
 co.tf2.requestFocus(true); //給賓客支付焦點
 
 }//Endif
 }
 catch (Exception ex) {
 JOptionPane.showMessageDialog(null, "操作失敗,請檢查網絡情況", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 ex.printStackTrace();
 System.out.println ("HotelFrame.initCKO(): false");
 return false;
 }//End try
 return true;
 }
 
 /**=======================================================================**
 * ActionListener 監聽
 **=======================================================================**
 */
 public void actionPerformed (ActionEvent ae) {
 Object o = ae.getSource ();
 if(o == bt1 || o ==mi11) {//============================================
 lbB.setText(face + "散 客 開 單         -");
 if(initIDV()) { //傳數據給散客開單窗口
 idv.show(); //散客開單
 initLeftData(); //刷新左房間信息欄數據
 }//Endif
 }else if(o == bt2 || o == mi12) {//=====================================
 lbB.setText(face + "團 體 開 單         -");
 if(initTeam()) { //傳賓客類型數據給團體開單窗口
 tm.show(); //團體開單
 initLeftData(); //刷新左房間信息欄數據
 }//Endif
 }else if(o == bt3 || o == mi36) {//=====================================
 lbB.setText(face + "關 於 我 們         -");
 ab.show(); //關於我們
 }else if(o == bt4 || o == mi21) {//=====================================
 lbB.setText(face + "賓 客 結 帳         -");
 if(initCKO()) { //傳數據給結算窗口
 co.show(); //賓客結帳
 initLeftData(); //刷新左房間信息欄數據
 }//Endif
 }else if(o == bt5 || o == mi17) {//=====================================
 lbB.setText(face + "客 房 預 訂         -");
 eg.show(); //客房預訂
 initLeftData(); //刷新左房間信息欄數據
 }else if(o == bt6) {//==================================================
 lbB.setText(face + "營 業 查 詢         -");
 qr.show(); //營業查詢
 }else if(o == bt7) {//==================================================
 if(puil.equals("普通操作員")) { //客戶管理
 String msg = "對不起,您的權限不能進入 [ 客戶管理 ] 頁面,請用管理員ID登錄 ...";
 JOptionPane.showMessageDialog(null, msg, "提示", JOptionPane.INFORMATION_MESSAGE);
 return;
 }
 lbB.setText(face + "客 戶 管 理         -");
 ct.show();
 }else if(o == bt8 || o == mi31) {//=====================================
 if(puil.equals("普通操作員")) { //網絡設置
 String msg = "對不起,您的權限不能進入 [ 網絡設置 ] 頁面,請用管理員ID登錄 ...";
 JOptionPane.showMessageDialog(null, msg, "提示", JOptionPane.INFORMATION_MESSAGE);
 return;
 }
 lbB.setText(face + "網 絡 設 置         -");
 ns.show();
 }else if(o == bt9 || o == mi32) {//=====================================
 if(puil.equals("普通操作員")) { //系統設置
 String msg = "對不起,您的權限不能進入 [ 網絡設置 ] 頁面,請用管理員ID登錄 ...";
 JOptionPane.showMessageDialog(null, msg, "提示", JOptionPane.INFORMATION_MESSAGE);
 return;
 }
 lbB.setText(face + "系 統 設 置         -");
 st.buildDTM12(""); //刷新房間信息表的房間狀態
 st.show();
 initLeftData(); //刷新左房間信息欄數據
 }else if(o == btA || o == mi19) {//=====================================
 quit (); //退出系統
 }else if(o == mi13) {//=================================================
 lbB.setText(face + "賓 客 續 住         -");
 go.show(); //賓客續住
 }else if(o == mi14) {//=================================================
 lbB.setText(face + "更 換 房 間         -");
 cg.show(); //更換房間
 }else if(o == mi15) {//=================================================
 lbB.setText(face + "修 改 登 記         -");
 idv.show(); //修改登記-------還要修改
 }else if(o == mi16) {//=================================================
 //房間狀態
 }else if(o == mi18) {//=================================================
 //電子提醒
 
 }else if(o == mi22) {//=================================================
 lbB.setText(face + "合 並 帳 單         -");
 ub.show(); //合並帳單
 }else if(o == mi23) {//=================================================
 lbB.setText(face + "折 分 帳 單         -");
 ap.show(); //折分帳單
 }else if(o == mi33) {//=================================================
 lbB.setText(face + "系 統 日 志         -");
 rc.initDTM(); //刷新日志列表
 rc.show(); //系統日志
 }else if(o == mi34) {//=================================================
 //數據備份
 }else if(o == mi35) {//=================================================
 //軟件幫助
 }
 lbB.setText(face + "陽 光 酒 店 管 理 系 統 - ★★ 版 ");
 }
 
 
 /**=======================================================================**
 * MouseListener 監聽
 **=======================================================================**
 */
 public void mouseClicked (MouseEvent me) {
 }
 
 public void mousePressed (MouseEvent me) {
 }
 
 public void mouseReleased(MouseEvent me) {
 }
 
 public void mouseEntered (MouseEvent me) { //鼠標移進提示
 Object o = me.getSource ();
 if(o == bt1) {
 lbA.setText (clue + toolTip[0]);
 }else if(o == bt2) {
 lbA.setText (clue + toolTip[1]);
 }else if(o == bt3) {
 lbA.setText (clue + toolTip[2]);
 }else if(o == bt4) {
 lbA.setText (clue + toolTip[3]);
 }else if(o == bt5) {
 lbA.setText (clue + toolTip[4]);
 }else if(o == bt6) {
 lbA.setText (clue + toolTip[5]);
 }else if(o == bt7) {
 lbA.setText (clue + toolTip[6]);
 }else if(o == bt8) {
 lbA.setText (clue + toolTip[7]);
 }else if(o == bt9) {
 lbA.setText (clue + toolTip[8]);
 }else if(o == btA) {
 lbA.setText (clue + toolTip[9]);
 }
 }
 
 public void mouseExited (MouseEvent me) {
 lbA.setText (clue + "請選擇功能項 ...                     ");
 }
 
 
 /**=======================================================================**
 * [## public void run() {} ]: 
 * 參數 :無
 * 返回值 :無
 * 修飾符 :public
 * 功能 :結算后檢查房間狀態線程
 **=======================================================================**
 */
 public void run() {
 try {
 Statement ste1 = null;
 Connection conn1 = null;
 if(sunini.getIniKey ("Default_Link").equals ("1")) { //JDBC連接方式
 String user1 = sunini.getIniKey ("UserID");
 String pwd1 = sunini.getIniKey ("Password");
 String ip1 = sunini.getIniKey ("IP");
 String acc1 = sunini.getIniKey ("Access");
 String dbf1 = sunini.getIniKey ("DBFname");
 String url1 = "jdbc:microsoft:sqlserver://" + ip1 + ":" + acc1 + ";" + "databasename=" + dbf1;
 //注冊驅動
 DriverManager.registerDriver (new com.microsoft.jdbc.sqlserver.SQLServerDriver());
 //獲得一個連接
 conn1 = DriverManager.getConnection (url1, user1, pwd1);
 }
 else {
 //注冊驅動 //JDBCODBC連接方式
 DriverManager.registerDriver (new sun.jdbc.odbc.JdbcOdbcDriver());
 //獲得一個連接
 conn1 = DriverManager.getConnection ("jdbc:odbc:" + sunini.getIniKey("LinkName"));
 }
 
 //建立高級載體
 ste1 = conn1.createStatement (ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE);
 while( true ) {
 ste1.executeUpdate("update roominfo set statetime=statetime-1 where statetime>0");
 ste1.executeUpdate("update roominfo set state='可供' where statetime=0 and state='臟房'");
 Thread.sleep(30000);
 }//End while
 }
 catch (Exception ex) {
 JOptionPane.showMessageDialog (null, "數據庫連接失敗...", "錯誤", JOptionPane.ERROR_MESSAGE);
 System.exit(0);
 //ex.printStackTrace();
 }//End try
 }
/*
 public static void main (String sd[]) {
 sunswing.setWindowStyle (sunini.getIniKey ("Sys_style").charAt (0));
 new HotelFrame ("gujun", "管理員");
 }*/
}

2.系統設置:

package com.sunshine.setup;
 
import javax.swing.*;
import javax.swing.border.*;
import javax.swing.table.*;
import java.awt.*;
import java.awt.event.*;
import java.sql.*;
import com.sunshine.sunsdk.sql.*; //公共類庫
import com.sunshine.sunsdk.system.*;
import com.sunshine.sunsdk.swing.*;
import com.sunshine.mainframe.HotelFrame; //加載主窗口
 
public class Setup 
extends JDialog 
implements ActionListener, MouseListener {
 
 private JLabel top,bott;
 private JTabbedPane tp;
 private JPanel panelMain;
 //=========房間項目設置
 private JTable tb11, tb12;
 private DefaultTableModel dtm11, dtm12; //房間類型列表//房間信息列表
 
 private JScrollPane sp11,sp12;
 private JComboBox cb11,cb12;
 //房間類型,可供/清理狀態
 private JButton bt11, bt12, bt13, bt14, bt15, bt16, bt17, bt18, bt19, bt20;
 //添加, 修改,刪除LX,折扣,單個,批量添加,刪除,修改FJ,保存,篩選
 private JTextField tf11;
 //=========客戶類型設置
 private JTable tb21,tb22;
 private DefaultTableModel dtm21,dtm22;
 //客戶類型列表,房間費打折列表
 private JScrollPane sp21,sp22;
 private JButton bt21, bt22, bt23, bt24;
 //添加, 修改,刪除LX,房費打折
 //=========操作員設置
 private JTable tb31;
 private DefaultTableModel dtm31;
 //操作員列表
 private JScrollPane sp31;
 private JComboBox cb31;//用戶名
 private JPasswordField tf31, tf32, tf33;
 //原密碼,新密碼,確認密碼
 private JRadioButton rb31, rb32, rb33, rb34, rb35;
 //新用戶登記, 修改密碼,刪除用戶,普通用戶,管理員
 private JButton bt31, bt32, bt33;
 // 登記, 修改, 刪除
 //=========計費設置
 private JTextField tf41, tf42, tf43, tf44, tf45, tf46, tf47; 
 private JCheckBox ck;
 private JButton bt41, bt42;
 
 //提示信息
 String msg0 = "您確定要刪除在表格中選中的資料條目嗎?";
 String msg1 = "請在相應的表格中選定條目,再點刪除鍵 ...";
 //日志信息
 String journal;
 //INI文件中的鍵名
 String ini[] = { "[SOFTINFO]", "UserName", "CompName", "[CONFIG]", "Soft_First",
 "Default_Link" , "Default_Page", "Sys_style", "[NUMBER]",
 "LodgName", "LodgNumber", "EngaName", "EngaNumber", "ChouName", 
 "ChouNumber", "[HABITUS]", "Ck_Habitus", "Ck_Minute", "[PARTTIME]", 
 "In_Room", "Out_Room1", "Out_Room2", "InsuDay", "ClockRoom1", 
 "ClockRoom2", "InsuHour1", "InsuHour2", "[JDBC]", "DBFname", 
 "UserID", "Password", "IP", "Access", "[ODBC]", "LinkName" };
 
 //實例化功能模塊
 //========================================================================//
 AddRoomType art = new AddRoomType (this); //添加房間類型
 ModiRoomType mrt = new ModiRoomType(this); //添加房間類型
 AddCustomerType act = new AddCustomerType(this); //添加客戶類型
 ModiCustomerType mct = new ModiCustomerType(this); //添加客戶類型
 Discount dis = new Discount(this); //折扣設置
 AddRoomInfo ari = new AddRoomInfo(this); //單個添加房間
 AddRoomInfos aris = new AddRoomInfos(this); //批量添加房間
 ModiRoomInfo mri = new ModiRoomInfo(this); //修改房間信息
 //========================================================================//
 
 /**=======================================================================**
 * [## public Setup(JFrame frame) {} ]: 構造函數
 * 參數 :JDialog對象表示本對話框的父窗口
 * 返回值 :無
 * 修飾符 :public
 * 功能 :組建系統設置模塊
 **=======================================================================**
 */
 public Setup(JFrame frame) {
 super (frame, "系統設置", true);
 top = new JLabel(); //假空格
 panelMain = new JPanel(new BorderLayout(0,10));
 tab(); //制作系統設置項目標簽面板
 addListener(); //加入事件監聽
 panelMain.add("North",top);
 panelMain.add("Center",tp);
 this.setContentPane(panelMain);
 this.setPreferredSize (new Dimension (718,508));
 this.setMinimumSize (new Dimension (718,508));
 this.setResizable(false); //不允許改變窗口大小
 pack();
 sunswing.setWindowCenter(this); //窗口屏幕居中
 }
 
 /**=======================================================================**
 * [## private void addListener() {} ]: 加事件監聽
 * 參數 :無
 * 返回值 :無
 * 修飾符 :private
 * 功能 :加事件監聽
 **=======================================================================**
 */
 private void addListener() {
 bt11.addActionListener(this); //加動作監聽
 bt12.addActionListener(this);
 bt13.addActionListener(this);
 bt14.addActionListener(this);
 bt15.addActionListener(this);
 bt16.addActionListener(this);
 bt17.addActionListener(this);
 bt18.addActionListener(this);
 bt19.addActionListener(this);
 bt20.addActionListener(this);
 bt21.addActionListener(this);
 bt22.addActionListener(this);
 bt23.addActionListener(this);
 bt24.addActionListener(this);
 bt31.addActionListener(this);
 bt32.addActionListener(this);
 bt33.addActionListener(this);
 bt41.addActionListener(this);
 bt42.addActionListener(this);
 rb31.addActionListener(this); //操作員作操范圍監聽
 rb32.addActionListener(this);
 rb33.addActionListener(this);
 tf41.addActionListener(this); //計費設置文本框加監聽
 tf42.addActionListener(this);
 tf43.addActionListener(this);
 tf44.addActionListener(this);
 tf45.addActionListener(this);
 tf46.addActionListener(this);
 bt11.addMouseListener(this); //加鼠標監聽
 bt12.addMouseListener(this);
 bt13.addMouseListener(this);
 bt14.addMouseListener(this);
 bt15.addMouseListener(this);
 bt16.addMouseListener(this);
 bt17.addMouseListener(this);
 bt18.addMouseListener(this);
 bt19.addMouseListener(this);
 bt20.addMouseListener(this);
 bt21.addMouseListener(this);
 bt22.addMouseListener(this);
 bt23.addMouseListener(this);
 bt24.addMouseListener(this);
 bt31.addMouseListener(this);
 bt32.addMouseListener(this);
 bt33.addMouseListener(this);
 bt41.addMouseListener(this);
 bt42.addMouseListener(this);
 }
 
 /**=======================================================================**
 * [## private void tab() {} ]: 制作系統設置項目標簽面板
 * 參數 :無
 * 返回值 :無
 * 修飾符 :private
 * 功能 :制作系統設置項目標簽面板
 **=======================================================================**
 */
 private void tab() {
 JPanel jp1,jp2,jp3,jp4;
 ///////////////////////////////////////////////-------模塊面板接口
 jp1 = fangjian(); //房間項目設置
 jp2 = kehu(); //客戶類型設置
 jp3 = caozuo(); //操作員設置
 jp4 = jiFei(); //計費設置
 //////////////////////////////////////////////////////////////////
 tp = new JTabbedPane();
 tp.addTab("房間項目設置", new ImageIcon("pic/u01.gif"), jp1);
 tp.addTab("客戶類型設置", new ImageIcon("pic/u02.gif"), jp2);
 tp.addTab("操作員設置", new ImageIcon("pic/u03.gif"), jp3);
 tp.addTab("計費設置", new ImageIcon("pic/u04.gif"), jp4);
 }
 
 /**=======================================================================**
 * [## private JPanel fangjian() {} ]: 
 * 參數 :無
 * 返回值 :JPanel
 * 修飾符 :private
 * 功能 :房間項目設置
 **=======================================================================**
 */
 private JPanel fangjian() {
 
 dtm11 = new DefaultTableModel();
 tb11 = new JTable(dtm11);
 sp11 = new JScrollPane(tb11);
 dtm12 = new DefaultTableModel();
 tb12 = new JTable(dtm12);
 sp12 = new JScrollPane(tb12);
 
 JPanel pfangjian,pTop,pBott,pTn,pTc,pBn,pBc,pTcc,pTcs,pBcc,pBcs;
 pfangjian = new JPanel(new GridLayout(2,1,0,5));
 pTop = new JPanel(new BorderLayout());
 pBott = new JPanel(new BorderLayout());
 pTn = new JPanel(); //放置保存按鈕等...
 pTc = new JPanel(new BorderLayout()); //放置房間類型列表及四個按鈕
 pBn = new JPanel(new FlowLayout(FlowLayout.LEFT,10,0));//放置下拉列表
 pBc = new JPanel(new BorderLayout()); //放置房間信息列表及四個按鈕
 pTcc = new JPanel(new GridLayout(1,1));//放置房間類型列表
 pTcs = new JPanel(new FlowLayout(FlowLayout.CENTER,20,5));//放置四個按鈕
 pBcc = new JPanel(new GridLayout(1,1));//放置房間信息列表
 pBcs = new JPanel(new FlowLayout(FlowLayout.CENTER,20,5));//放置四個按鈕
 
 //保存按鈕等 ...
 JLabel lb1,lb2,lb3;
 lb1 = new JLabel("結帳后房間狀態變為: ");
 lb2 = new JLabel(" 結帳后");
 lb3 = new JLabel("分鍾后變為可供狀態 ");
 tf11 = new TJTextField(sunini.getIniKey(ini[17]),5); //根據INI文件給初值
 tf11.setHorizontalAlignment(JTextField.RIGHT);
 cb12 = new JComboBox();
 cb12.addItem(" 可供狀態 ");
 cb12.addItem(" 清理狀態 "); //根據INI文件給初值
 cb12.setSelectedIndex(Integer.parseInt(sunini.getIniKey(ini[16])));
 bt19 = new TJButton ("pic/save.gif", " 保 存 ", "保存設置");
 pTn.add(lb1);
 pTn.add(cb12);
 pTn.add(lb2);
 pTn.add(tf11);
 pTn.add(lb3);
 pTn.add(bt19);
 pTn.setBorder(BorderFactory.createTitledBorder(""));
 
 //房間類型列表及四個按鈕
 bt11 = new TJButton ("pic/new.gif", "添加類型", "添加房間類型");
 bt12 = new TJButton ("pic/modi0.gif", "修改類型", "修改房間類型");
 bt13 = new TJButton ("pic/del.gif", "刪除類型", "刪除房間類型");
 bt14 = new TJButton ("pic/modi3.gif", "房費打折", "設置房間費折扣");
 pTcc.add(sp11);
 pTcs.add(bt11);
 pTcs.add(bt12);
 pTcs.add(bt13);
 pTcs.add(bt14);
 pTc.add(pTcc);
 pTc.add("South",pTcs);
 pTc.setBorder(BorderFactory.createTitledBorder("房間類型"));
 
 //完成上半部分
 pTop.add("North",pTn);
 pTop.add(pTc);
 
 
 //下拉列表
 JLabel lb0 = new JLabel("按包廂類型過濾: ");
 cb11 = new JComboBox();
 bt20 = new TJButton ("pic/choose1.gif", "篩 選", "篩選房間信息");
 bt20.setBorderPainted(false);
 bt20.setFocusPainted(false);
 pBn.add(lb0);
 pBn.add(cb11);
 pBn.add(bt20);
 
 buildDTM11(); //初始化房間類型列表和下拉列表的值
 buildDTM12(""); //初始化房間號列表
 
 
 //房間信息列表及四個按鈕
 bt15 = new TJButton ("pic/new.gif", "單個添加", "添加單個房間信息");
 bt16 = new TJButton ("pic/book.gif", "批量添加", "批量添加房間信息");
 bt17 = new TJButton ("pic/del.gif", "刪除房間", "刪除某個房間信息");
 bt18 = new TJButton ("pic/modi0.gif", "修改房間", "修改某個房間信息");
 pBcc.add(sp12);
 pBcs.add(bt15);
 pBcs.add(bt16);
 pBcs.add(bt17);
 pBcs.add(bt18);
 pBc.add(pBcc);
 pBc.add("South",pBcs);
 pBc.setBorder ( BorderFactory.createTitledBorder ("房間信息") );
 
 //完成下半部分
 pBott.add("North",pBn);
 pBott.add(pBc);
 
 //組合
 pfangjian.add(pTop);
 pfangjian.add(pBott);
 
 return pfangjian;
 }
 
 //
 /**=======================================================================**
 * [## private void buildDTM11() {} ]: 
 * 參數 :無
 * 返回值 :無
 * 修飾符 :private
 * 功能 :房間類型列表和ComboBox
 **=======================================================================**
 */
 private void buildDTM11() {
 String sqlCode2 = "select pk,sysmark,id,foregift,r_type 房間類型," +
 "price 預設單價,cl_price " + "'鍾點價格/小時'" + ",bed 床位數量,cl_room "+
 "'能否按鍾點計費(Y/N)' from roomtype where delmark = 0";
 sunsql.initDTM(dtm11,sqlCode2);
 tb11.removeColumn(tb11.getColumn("pk"));
 tb11.removeColumn(tb11.getColumn("sysmark"));
 tb11.removeColumn(tb11.getColumn("foregift"));
 tb11.removeColumn(tb11.getColumn("id"));
 
 String sqlCode1 = "select r_type from roomtype where delmark = 0";
 sunsql.initJComboBox(cb11,sqlCode1);
 cb11.addItem("顯示全部房間信息");
 cb11.setSelectedIndex(cb11.getItemCount() - 1); //設置顯示全部
 }
 
 /**=======================================================================**
 * [## private void buildDTM12(String rType) {} ]: 
 * 參數 :String rType為刷新參數
 * 返回值 :無
 * 修飾符 :private
 * 功能 :房間信息表
 **=======================================================================**
 */
 public void buildDTM12(String rType) {
 String sqlCode = "select a.pk,a.r_type_id,a.id 房間號,b.r_type 房間類型," +
 "a.state 房間狀態,a.location 所在區域,a.r_tel 房間電話 from roominfo as a," +
 "roomtype as b where a.r_type_id = b.id and a.delmark = 0 " + rType;
 sunsql.initDTM(dtm12,sqlCode);
 tb12.removeColumn(tb12.getColumn("pk"));
 tb12.removeColumn(tb12.getColumn("r_type_id"));
 }
 
 /**=======================================================================**
 * [## private JPanel kehu() {} ]: 
 * 參數 :無
 * 返回值 :無
 * 修飾符 :private
 * 功能 :客戶類型設置
 **=======================================================================**
 */
 private JPanel kehu() {
 
 dtm21 = new DefaultTableModel();
 tb21 = new JTable(dtm21);
 sp21 = new JScrollPane(tb21);
 dtm22 = new DefaultTableModel();
 tb22 = new JTable(dtm22);
 sp22 = new JScrollPane(tb22);
 
 JPanel pkehu,p1,p2,p1b,p2b;
 p1 = new JPanel(new BorderLayout());//客戶類型面板
 p2 = new JPanel(new BorderLayout());//房間費打折面板
 p1b = new JPanel(new FlowLayout(FlowLayout.CENTER,30,5));//客戶類型按鈕面板
 p2b = new JPanel(); //房間費打折按鈕面板
 
 buildDTM21(); //初始化客戶類型表
 bt21 = new TJButton ("pic/new.gif", "添加類型", "添加客戶類型");
 bt22 = new TJButton ("pic/modi0.gif", "修改類型", "修改客戶類型");
 bt23 = new TJButton ("pic/del.gif", "刪除類型", "刪除客戶類型");
 p1b.add(bt21);
 p1b.add(bt22);
 p1b.add(bt23);
 p1.add(sp21);
 p1.add("South",p1b);
 p1.setBorder ( BorderFactory.createTitledBorder ("客戶類型") );
 
 buildDTM22(); //初始化房間打折表
 bt24 = new TJButton ("pic/modi3.gif", " 房間費打折 ", "設置房間費折扣");
 p2b.add(bt24);
 p2.add(sp22);
 p2.add("South",p2b);
 p2.setBorder ( BorderFactory.createTitledBorder ("房間費打折") );
 
 pkehu = new JPanel(new GridLayout(2,1,0,10));
 pkehu.add(p1);
 pkehu.add(p2);
 
 return pkehu;
 }
 
 /**=======================================================================**
 * [## private JPanel caozuo() {} ]: 
 * 參數 :無
 * 返回值 :JPanel
 * 修飾符 :private
 * 功能 :操作員設置
 **=======================================================================**
 */
 private JPanel caozuo() {
 JPanel panelMain,panelMain1,panelTop,panelBott1,panelBott2;
 
 dtm31 = new DefaultTableModel();
 tb31 = new JTable(dtm31);
 sp31 = new JScrollPane(tb31);
 
 panelMain = new JPanel(new GridLayout(2,1,0,5));
 panelMain1 = new JPanel (new BorderLayout (0,3)); //下半面板
 panelTop = new JPanel(new GridLayout(1,1)); //操作員列表面板
 panelBott1 = new JPanel(new GridLayout (1, 2));//詳細信息,操作范圍,操作權限面板
 panelBott2 = new JPanel(new FlowLayout (FlowLayout.CENTER,20,5));//按鈕面板
 
 bt31 = new TJButton ("pic/new.gif", " 登 記 ", "保存當前用戶信息", false);
 bt32 = new TJButton ("pic/key.gif", " 修 改 ", "修改密碼", false);
 bt33 = new TJButton ("pic/del.gif", " 刪 除 ", "刪除當前用戶", false);
 
 bt32.setEnabled(false);
 bt33.setEnabled(false);
 
 panelBott2.add (bt31);
 panelBott2.add (bt32);
 panelBott2.add (bt33);
 
 //制作並加入Top_Left面板
 panelBott1.add (bottLeft());
 
 //制作並加入Top_Right面板
 panelBott1.add (bottRight());
 
 panelMain1.add ("Center", panelBott1);
 panelMain1.add ("South", panelBott2);
 
 buildDTM31(); //初始化操作員信息表
 panelTop.add(sp31);
 panelTop.setBorder(BorderFactory.createTitledBorder("操作員列表"));
 panelMain.add(panelTop);
 panelMain.add(panelMain1);
 
 return panelMain;
 }
 
 /**=======================================================================**
 * [## private JPanel topLeft () {} ]: 制作Top_Left面板
 * 參數 :無
 * 返回值 :JPanel表示組織好的面板
 * 修飾符 :private
 * 功能 :組建對話框的用戶名和密碼面板
 **=======================================================================**
 */
 private JPanel bottLeft () {
 JLabel lb1, lb2, lb3, lb4;
 JPanel tl, jp1, jp2;
 
 lb1 = new JLabel ("用 戶 名: ");
 lb2 = new JLabel ("原 密 碼: ");
 lb3 = new JLabel ("新 密 碼: ");
 lb4 = new JLabel ("確認密碼: ");
 
 tf31 = new TJPasswordField (17);
 tf32 = new TJPasswordField (17);
 tf33 = new TJPasswordField (17);
 
 
 tl = new JPanel ();
 jp1 = new JPanel (new GridLayout (4, 1, 0, 18));
 jp2 = new JPanel (new GridLayout (4, 1, 0, 9));
 
 //初始化用戶名下拉框
 cb31 = new JComboBox ();
 cb31.setEditable (true);
 
 tf31.setEditable (false);
 
 //加入組件
 jp1.add (lb1);
 jp1.add (lb2);
 jp1.add (lb3);
 jp1.add (lb4);
 jp2.add (cb31);
 jp2.add (tf31);
 jp2.add (tf32);
 jp2.add (tf33);
 
 tl.add (jp1);
 tl.add (jp2);
 tl.setBorder (BorderFactory.createTitledBorder (" 詳細信息 "));
 return tl;
 }
 
 /**=======================================================================**
 * [## private JPanel topRight () {} ]: 制作Top_Right面板
 * 參數 :無
 * 返回值 :JPanel表示組織好的面板
 * 修飾符 :private
 * 功能 :組建對話框操作面板
 **=======================================================================**
 */
 private JPanel bottRight () {
 JPanel tr, jp1, jp2;
 ButtonGroup bg1,bg2;
 
 rb31 = new JRadioButton ("新用戶登記", true);
 rb32 = new JRadioButton ("修改密碼");
 rb33 = new JRadioButton ("刪除用戶");
 rb34 = new JRadioButton ("普通操作員", true);
 rb35 = new JRadioButton ("管 理 員");
 
 bg1 = new ButtonGroup ();
 bg2 = new ButtonGroup ();
 
 tr = new JPanel (new GridLayout (2, 1));
 jp1 = new JPanel ();
 jp2 = new JPanel ();
 
 //加單選組 操作范圍
 bg1.add (rb31);
 bg1.add (rb32);
 bg1.add (rb33);
 
 //加單選組 操作權限
 bg2.add (rb34);
 bg2.add (rb35);
 
 jp1.add (rb31);
 jp1.add (rb32);
 jp1.add (rb33);
 
 jp2.add (rb34);
 jp2.add (rb35);
 
 jp1.setBorder (BorderFactory.createTitledBorder (" 操作范圍 "));
 jp2.setBorder (BorderFactory.createTitledBorder (" 操作權限 "));
 
 tr.add (jp1);
 tr.add (jp2);
 
 return tr;
 }
 
 /**=======================================================================**
 * [## private void buildDTM21() {} ]: 
 * 參數 :無
 * 返回值 :無
 * 修飾符 :private
 * 功能 :初始化客戶類型列表
 **=======================================================================**
 */
 private void buildDTM21() {
 String sqlCode = "select pk,id 客戶類型編號,id,c_type 客戶類型,discount " +
 "打折比率 from customertype where delmark = 0 and dis_attr = '購物折扣' and id!='SYSMARK'";
 sunsql.initDTM(dtm21,sqlCode);
 tb21.removeColumn(tb21.getColumn("pk"));
 tb21.removeColumn(tb21.getColumn("id"));
 }
 
 /**=======================================================================**
 * [## private void buildDTM22() {} ]: 
 * 參數 :無
 * 返回值 :無
 * 修飾符 :private
 * 功能 :初始化房間打折費列表
 **=======================================================================**
 */
 private void buildDTM22() {
 String sqlCode = "select pk,sysmark,id,foregift,r_type 房間類型,price 預設單價 from roomtype where delmark = 0";
 sunsql.initDTM(dtm22,sqlCode);
 tb22.removeColumn(tb22.getColumn("pk"));
 tb22.removeColumn(tb22.getColumn("id"));
 tb22.removeColumn(tb22.getColumn("sysmark"));
 tb22.removeColumn(tb22.getColumn("foregift"));
 }
 
 
 /**=======================================================================**
 * [## private void buildDTM31() {} ]: 
 * 參數 :無
 * 返回值 :無
 * 修飾符 :private
 * 功能 :初始化操作員列表
 **=======================================================================**
 */
 private void buildDTM31() {
 String sqlCode = "select pk,userid 用戶登錄ID,puis 用戶權限 from pwd where delmark = 0";
 sunsql.initDTM(dtm31,sqlCode);
 tb31.removeColumn(tb31.getColumn("pk"));
 
 sunsql.initJComboBox (cb31, "select userid from pwd where delmark=0");
 }
 
 /**=======================================================================**
 * [## private JPanel jiFei() {} ]: 
 * 參數 :無
 * 返回值 :JPanel
 * 修飾符 :private
 * 功能 :計費設置
 **=======================================================================**
 */
 private JPanel jiFei() {
 JLabel lb1, lb2, lb3, lb4, lb5, lb6, lb7, lb8, lb9, lb10, 
 lb11, lb12, lb13, lb14, lb15, lb16;
 //定義各方位面板
 JPanel panelJF, jfTop, jfLeft, jfRight, jfBott;
 JPanel jp1, jp2, jp3, jp4, jp5, jp6, jp7, jp8, jp9;
 //定義標簽
 lb1 = new JLabel("  客人開房時間在");
 lb2 = new JLabel("點之后按新的一天開始計費");
 lb3 = new JLabel("  客人退房時間在");
 lb4 = new JLabel("點之后計價天數自動追加半天");
 lb5 = new JLabel("  客人退房時間在");
 lb6 = new JLabel("點之后計價天數自動追加一天");
 lb7 = new JLabel("  開房后");
 lb8 = new JLabel("分鍾開始計費");
 lb9 = new JLabel("  最少按");
 lb10 = new JLabel("小時計費,小於這個時間的按此時間計費");
 lb11 = new JLabel("  若不足一小時但超過");
 lb12 = new JLabel("分鍾的部分按1小時計費");
 lb13 = new JLabel("  不足上面分鍾數但超過");
 lb14 = new JLabel("分鍾的部分按半小時計費");
 lb15 = new JLabel("注:此設置僅限於標准計費的鍾點房!    ");
 lb16 = new JLabel("  ");
 lb15.setForeground(new Color(255, 138, 0));
 //初始化計時計費設置
 tf41 = new TJTextField(sunini.getIniKey("In_Room"), 5);
 tf42 = new TJTextField(sunini.getIniKey("Out_Room1"), 5);
 tf43 = new TJTextField(sunini.getIniKey("Out_Room2"), 5);
 tf44 = new TJTextField(sunini.getIniKey("ClockRoom1"), 5);
 tf45 = new TJTextField(sunini.getIniKey("ClockRoom2"), 5);
 tf46 = new TJTextField(sunini.getIniKey("InsuHour1"), 5);
 tf47 = new TJTextField(sunini.getIniKey("InsuHour2"), 5);
 //設置文本框右對齊
 tf41.setHorizontalAlignment(JTextField.RIGHT);
 tf42.setHorizontalAlignment(JTextField.RIGHT);
 tf43.setHorizontalAlignment(JTextField.RIGHT);
 tf44.setHorizontalAlignment(JTextField.RIGHT);
 tf45.setHorizontalAlignment(JTextField.RIGHT);
 tf46.setHorizontalAlignment(JTextField.RIGHT);
 tf47.setHorizontalAlignment(JTextField.RIGHT);
 //不足一天是否按一天計價
 ck = new JCheckBox("入住時間不足一天的按一天計費");
 if(sunini.getIniKey("InsuDay").equals("1")) {
 ck.setSelected(true);
 }
 bt41 = new TJButton ("pic/save.gif", " 保 存 ", "保存當前設置");
 bt42 = new TJButton ("pic/exit.gif", " 返 回 ", "返回主窗口");
 
 panelJF = new JPanel(new BorderLayout()); //計費主面板
 jfTop = new JPanel(new GridLayout(2, 1)); //放左右面板
 jfLeft = new JPanel(new GridLayout(4, 1)); //計費左面板
 jfRight = new JPanel(new GridLayout(5, 1)); //計費右面板
 jfBott = new JPanel(new FlowLayout(FlowLayout.RIGHT, 40, 4));//按鍵面板
 
 jp1 = new JPanel(new FlowLayout(FlowLayout.LEFT)); //左邊的面板用到的
 jp2 = new JPanel(new FlowLayout(FlowLayout.LEFT));
 jp3 = new JPanel(new FlowLayout(FlowLayout.LEFT));
 jp4 = new JPanel(new FlowLayout(FlowLayout.LEFT));
 jp5 = new JPanel(new FlowLayout(FlowLayout.LEFT)); //右邊的面板用到的
 jp6 = new JPanel(new FlowLayout(FlowLayout.LEFT));
 jp7 = new JPanel(new FlowLayout(FlowLayout.LEFT));
 jp8 = new JPanel(new FlowLayout(FlowLayout.LEFT));
 jp9 = new JPanel(new FlowLayout(FlowLayout.RIGHT));
 
 //制作左邊面板
 jp1.add(lb1);
 jp1.add(tf41);
 jp1.add(lb2);
 jp2.add(lb3);
 jp2.add(tf42);
 jp2.add(lb4);
 jp3.add(lb5);
 jp3.add(tf43);
 jp3.add(lb6);
 jp4.add(lb16); //假空格
 jp4.add(ck);
 
 jfLeft.add(jp1);
 jfLeft.add(jp2);
 jfLeft.add(jp3);
 jfLeft.add(jp4);
 
 //制作右邊面板
 jp5.add(lb7);
 jp5.add(tf44);
 jp5.add(lb8);
 jp6.add(lb9);
 jp6.add(tf45);
 jp6.add(lb10);
 jp7.add(lb11);
 jp7.add(tf46);
 jp7.add(lb12);
 jp8.add(lb13);
 jp8.add(tf47);
 jp8.add(lb14);
 jp9.add(lb15);
 
 jfRight.add(jp5);
 jfRight.add(jp6);
 jfRight.add(jp7);
 jfRight.add(jp8);
 jfRight.add(jp9);
 
 //組織兩個表到一起
 jfTop.add(jfLeft);
 jfTop.add(jfRight);
 
 //組織按鍵面板
 jfBott.add(bt41);
 jfBott.add(bt42);
 
 //加入主面板
 panelJF.add("Center", jfTop);
 panelJF.add("South", jfBott);
 
 jfLeft.setBorder(BorderFactory.createTitledBorder("普通房間標准計費"));
 jfRight.setBorder ( BorderFactory.createTitledBorder ("鍾點房標准計費") );
 return panelJF;
 }
 
 /**=======================================================================**
 * [## private boolean initMrt() {} ]: 
 * 參數 :無
 * 返回值 :boolean
 * 修飾符 :private
 * 功能 :傳數據給修改房間類型窗口
 **=======================================================================**
 */
 private boolean initMrt() {
 int row = tb11.getSelectedRow();
 if(row == -1) {
 JOptionPane.showMessageDialog(null, "請在上面類型表中指定房間類型," +
 "才能執行修改操作", "提示", JOptionPane.INFORMATION_MESSAGE);
 return false;
 }
 ModiRoomType.tf0.setText(dtm11.getValueAt(row,2) + ""); //類型編號
 ModiRoomType.tf1.setText(dtm11.getValueAt(row,4) + ""); //類型名稱
 ModiRoomType.tf2.setText(dtm11.getValueAt(row,7) + ""); //床位數量
 ModiRoomType.tf3.setText(dtm11.getValueAt(row,5) + ""); //預設單價
 ModiRoomType.tf4.setText(dtm11.getValueAt(row,3) + ""); //預設押金
 ModiRoomType.tf5.setText(dtm11.getValueAt(row,6) + ""); //鍾點計費
 String cl_room = dtm11.getValueAt(row, 8) + "";
 if(cl_room.equals("Y")) {
 ModiRoomType.chk.setSelected(true); //允許提供鍾點服務
 }
 else {
 ModiRoomType.chk.setSelected(false); //不允許提供鍾點服務
 ModiRoomType.tf5.setEnabled(false); //設置鍾點計費不可用
 }
 return true;
 }
 
 /**=======================================================================**
 * [## private boolean initMri() {} ]: 
 * 參數 :無
 * 返回值 :boolean
 * 修飾符 :private
 * 功能 :傳數據給修改房間信息窗口
 **=======================================================================**
 */
 private boolean initMri() {
 int row = tb12.getSelectedRow();
 if(row == -1) {
 JOptionPane.showMessageDialog(null, "請在上面房間信息表中指定房間號," +
 "才能執行修改操作", "提示", JOptionPane.INFORMATION_MESSAGE);
 return false;
 }
 ModiRoomInfo.tf1.setText(dtm12.getValueAt(row, 2) + ""); //房間編號
 ModiRoomInfo.tf2.setText(dtm12.getValueAt(row, 5) + ""); //所在區域
 ModiRoomInfo.tf3.setText(dtm12.getValueAt(row, 6) + ""); //房間電話
 ModiRoomInfo.pk = dtm12.getValueAt(row, 0) + ""; //獲得當前行的PK
 try {
 ResultSet rs = sunsql.executeQuery("select r_type from roomtype " +
 "where delmark=0 and id='" + dtm12.getValueAt(row,1) + "'");
 rs.next();
 ModiRoomInfo.cb1.setSelectedItem(rs.getString(1)); //房間類型
 }
 catch (Exception ex) {
 System.out.println ("ModiRoomInfo.initMri(): Modi false");
 }//End try
 return true;
 }
 
 /**=======================================================================**
 * [## private boolean initMct() {} ]: 
 * 參數 :無
 * 返回值 :boolean
 * 修飾符 :private
 * 功能 :傳數據給修改客戶類型窗口
 **=======================================================================**
 */
 private boolean initMct() {
 int row = tb21.getSelectedRow();
 if(row == -1) {
 JOptionPane.showMessageDialog(null, "請在上面類型表中指定客戶類型," +
 "才能執行修改操作", "提示", JOptionPane.INFORMATION_MESSAGE);
 return false;
 }
 ModiCustomerType.tf1.setText(dtm21.getValueAt(row,1) + ""); //客戶類型編號
 ModiCustomerType.tf2.setText(dtm21.getValueAt(row,3) + ""); //客戶類型名稱
 ModiCustomerType.tf3.setText(dtm21.getValueAt(row,4) + ""); //客戶類型折扣
 ModiCustomerType.pk = dtm21.getValueAt(row, 0) + ""; //獲得當前行的PK
 return true;
 }
 
 /**=======================================================================**
 * [## private boolean initDis(JTable dtb, DefaultTableModel ddtm) {} ]: 
 * 參數 :JTable 與 DefaultTableModel 為項目與折扣中的表
 * 返回值 :boolean
 * 修飾符 :private
 * 功能 :傳數據給打折設置窗口
 **=======================================================================**
 */
 private boolean initDis(JTable dtb, DefaultTableModel ddtm) {
 int row = dtb.getSelectedRow();
 if(row == -1) {
 JOptionPane.showMessageDialog(null, "請在相應列表中指定房間類型," +
 "才能進行打折設置操作", "提示", JOptionPane.INFORMATION_MESSAGE);
 return false;
 }
 try {
 Discount.rt = ddtm.getValueAt(row, 2) + ""; //獲得房間編號
 ResultSet rs = sunsql.executeQuery("select discount from customertype " +
 "where id='SYSMARK' and dis_attr='" + ddtm.getValueAt(row, 2) + "'");
 rs.next();
 int temp = rs.getInt(1);
 if(temp == 10){
 Discount.cb1.setSelectedIndex(1); //普通賓客不打折選項
 Discount.tf1.setEnabled(false);
 }else {
 Discount.cb1.setSelectedIndex(0); //普通賓客打折選項
 Discount.tf1.setEnabled(true);
 }//Endif
 Discount.tf1.setText(temp + ""); //普通賓客的折扣
 }
 catch (Exception ex) {
 }
 Discount.lb1.setText(ddtm.getValueAt(row, 4) + ""); //房間類型名稱
 Discount.lb2.setText(ddtm.getValueAt(row, 5) + ""); //房間價格
 //初始化表格的DTM
 sunsql.initDTM(Discount.dtm, "select c_type 客戶等級,discount 享受折扣, " +
 "dis_price 折扣價格 from customertype where delmark=0 and dis_attr='" + 
 ddtm.getValueAt(row, 2) + "' and id!='SYSMARK'");
 //初始化會員等級ComboBox
 sunsql.initJComboBox(Discount.cb2, "select c_type from customertype where " + 
 "delmark=0 and id!='SYSMARK' and dis_attr='" + ddtm.getValueAt(row, 2) + "'");
 
 return true;
 }
 
 /**=======================================================================**
 * [## private boolean delInfo (String tName, DefaultTableModel delDtm, int dr[], String m) {} ]: 
 * 參數 :Sring tName 表示要執行刪除的表名
 * DTM delDtm 表示相關聯的DTM
 * int dr[] 要被執行刪除的行數
 * String m 提示信息
 * 返回值 :boolean
 * 修飾符 :private
 * 功能 :房間類型、房間信息和客戶類型的刪操作
 **=======================================================================**
 */
 private boolean delInfo (String tName, DefaultTableModel delDtm, int dr[], String m) {
 int rowCount = dr.length;
 int r =0; //DTM行指針
 
 if(tName.equals ("roomtype")) { //如果刪除房間類型,則刪除與房間類型相關的房間信息與客戶折扣設置
 rowCount = rowCount * 3;
 }//Endif
 
 if(rowCount > 0) { //判斷選擇記錄數
 int isDel = JOptionPane.showConfirmDialog (null, m, "提示", JOptionPane.YES_NO_OPTION);
 if(isDel == JOptionPane.YES_OPTION) {
 String sqlCode[] = new String[rowCount];
 //生成SQL語句
 for (int i = 0; i < rowCount; i++) {
 sqlCode[i] = "update " + tName +" set delmark=1 where pk=" + delDtm.getValueAt(dr[r], 0) + " and id='" + delDtm.getValueAt(dr[r],2) + "'";
 if(tName.equals ("roomtype")) { //如果刪除房間類型,則同時刪除相關房間信息
 i++;
 sqlCode[i] = "update roominfo set delmark=1 where id='sunhotel' or r_type_id='" + delDtm.getValueAt(dr[r],2) + "'";
 i++;
 sqlCode[i] = "update customertype set delmark=1 where id='sunhotel' or dis_attr='" + delDtm.getValueAt(dr[r],2) + "'";
 }
 r++; //DTM行指針加1
 }//Endfor
 //以事務模式執行SQL語句組, 確保操作正確, 返回值為成功執行SQL語句的條數
 isDel = sunsql.runTransaction(sqlCode); 
 if(isDel != rowCount) { //如果成功執行的條數 = 數組長度,則表示更新成功
 String mm = "在執行第 [ " + (isDel + 1) + " ] 條記錄的刪除操作時出錯,數據有可能被其它終端修改\n或者是網絡不通暢 ...";
 JOptionPane.showMessageDialog(null, mm, "錯誤",JOptionPane.ERROR_MESSAGE);
 //更新失敗,返回false
 return false;
 }//Endif
 return true; //更新成功,返回true
 }//Endif
 }
 else //如果沒有選中記錄,則提示一下
 JOptionPane.showMessageDialog(null, msg1, "提示",JOptionPane.INFORMATION_MESSAGE);
 return false;
 }
 
 /**=======================================================================**
 * [## private void umAdd () {} ]: 添加操作
 * 參數 :無
 * 返回值 :無
 * 修飾符 :private
 * 功能 :添加新的用戶ID
 **=======================================================================**
 */
 private void umAdd () {
 String pwd1 = String.valueOf(tf32.getPassword());
 String pwd2 = String.valueOf(tf33.getPassword());
 String pu = "普通操作員"; //用戶權限
 if(!pwd1.equals (pwd2)) { //兩次密碼不相等
 JOptionPane.showMessageDialog (null, "輸入錯誤,[ 新密碼 ] 與 [ 確認密碼 ] " +
 "不正確,請重新輸入 ...", "錯誤",JOptionPane.ERROR_MESSAGE);
 return;
 }//Endif
 String umName = cb31.getEditor ().getItem () + "";//獲得用戶名
 try {
 ResultSet rs = sunsql.executeQuery ("select userid from pwd where delmark=0 " +
 "and userid='" + umName + "'");
 
 int isID = sunsql.recCount(rs);
 if(isID > 0){ //當前要加入的用戶名是否存在
 JOptionPane.showMessageDialog (null, "管理員ID [ " + umName + " ] 已存在," +
 "請重新輸入 ...", "錯誤",JOptionPane.ERROR_MESSAGE);
 return;
 }//Endif
 if(rb35.isSelected()) //獲得是否是管理員權限
 pu = "管理員";
 long pk = sunsql.getPrimaryKey();//從服務獲得主鍵
 //記入數據庫
 isID = sunsql.executeUpdate("insert into pwd(pk,userid,pwd,puis) values(" + pk + 
 ",'" + umName + "','" + pwd1 + "','" + pu + "')");
 
 if(isID == 0) {
 JOptionPane.showMessageDialog (null, "添加操作失敗,請檢查網絡連接是否正常 " +
 "...", "錯誤",JOptionPane.ERROR_MESSAGE);
 return;
 }
 tf32.setText(""); //清空密碼
 tf33.setText("");
 }
 catch (Exception ex) {
 System.out.println ("UserID.umAdd(): Add new ID error.");
 }//End try
 }
 
 /**=======================================================================**
 * [## private void umUpdate (int type) {} ]: 更新刪除操作
 * 參數 :int 變量表示操作類型 0:表示修改密碼 1:表示刪除記錄
 * 返回值 :無
 * 修飾符 :private
 * 功能 :修改密碼和刪除用戶ID
 **=======================================================================**
 */
 private void umUpdate (int type) {
 String umName = cb31.getSelectedItem() + ""; //獲得用戶名
 String pwd0;
 String pwd1 = String.valueOf (tf32.getPassword ());
 String pwd2 = String.valueOf (tf33.getPassword ());
 
 int isID = 0; //用戶是否存在
 if(!pwd1.equals (pwd2)) { //兩次密碼不相等
 JOptionPane.showMessageDialog (null, "輸入錯誤,[ 新密碼 ] 與 [ 確認密碼 ] " +
 "不正確,請重新輸入 ...", "錯誤",JOptionPane.ERROR_MESSAGE);
 return;
 }//Endif
 if(type == 0) 
 pwd0 = String.valueOf (tf31.getPassword ());//取修改操作的密碼
 else
 pwd0 = String.valueOf (tf32.getPassword ());//取刪除操作的密碼
 try {
 ResultSet rs = sunsql.executeQuery ("select pwd from pwd where delmark=0 and " +
 "userid='" + umName + "'");
 
 rs.next();
 if(!pwd0.equals(rs.getString(1))){ //判斷原密碼是否正確
 JOptionPane.showMessageDialog (null, "管理員ID [ " + umName + " ] 的 [ 原" +
 "密碼 ] 不正確,請重新輸入 ...", "錯誤",JOptionPane.ERROR_MESSAGE);
 
 return;
 }//Endif
 if(type == 0) { //執行修改密碼操作
 isID = sunsql.executeUpdate("update pwd set pwd='" + pwd1 + "' where " +
 "delmark=0 and userid='" + umName + "'");
 }else { //執行刪除操作
 isID = sunsql.executeUpdate("update pwd set delmark=1 where userid='" + umName + "'");
 }//Endif
 }
 catch (Exception ex) {
 }//End try
 if(isID == 0) { //判斷操作是否成功
 JOptionPane.showMessageDialog (null, "執行操作失敗,請檢查網絡連接是否正常 ...", "錯誤",JOptionPane.ERROR_MESSAGE);
 }
 tf31.setText(""); //清空密碼
 tf32.setText("");
 tf33.setText("");
 return;
 }
 
 //檢查計費設置是否合法
 private boolean isValidity() {
 if(!suntools.isNum(tf41.getText(), 1, 6, 9)) {
 JOptionPane.showMessageDialog(null, "[ 計費參數 1 ] 只能是數字,且范圍在 6-9 之間", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 tf41.requestFocus(true);
 return false;
 }else if(!suntools.isNum(tf42.getText(), 2, 11, 13)) {
 JOptionPane.showMessageDialog(null, "[ 計費參數 2 ] 只能是數字,且范圍在 11-13 之間", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 tf42.requestFocus(true);
 return false;
 }else if(!suntools.isNum(tf43.getText(), 2, 17, 19)) {
 JOptionPane.showMessageDialog(null, "[ 計費參數 3 ] 只能是數字,且范圍在 17-19 之間", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 tf43.requestFocus(true);
 return false;
 }else if(!suntools.isNum(tf44.getText(), 1, 0, 5)) {
 JOptionPane.showMessageDialog(null, "[ 鍾點計費參數 1 ] 只能是數字,且范圍在 0-5 之間", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 tf44.requestFocus(true);
 return false;
 }else if(!suntools.isNum(tf45.getText(), 1, 1, 5)) {
 JOptionPane.showMessageDialog(null, "[ 鍾點計費參數 2 ] 只能是數字,且范圍在 1-5 之間", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 tf45.requestFocus(true);
 return false;
 }else if(!suntools.isNum(tf46.getText(), 2, 20, 40)) {
 JOptionPane.showMessageDialog(null, "[ 鍾點計費參數 3 ] 只能是數字,且范圍在 20-40 之間", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 tf46.requestFocus(true);
 return false;
 }else if(!suntools.isNum(tf47.getText(), 2, 5, 15)) {
 JOptionPane.showMessageDialog(null, "[ 鍾點計費參數 4 ] 只能是數字,且范圍在 5-15 之間", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 tf47.requestFocus(true);
 return false;
 }//endif
 return true;
 }
 
 /**=======================================================================**
 * [## private boolean isState(int aRow[]) {} ]: 
 * 參數 :int aRom[] 表示要執行刪除操作的行號
 * 返回值 :boolean
 * 修飾符 :private
 * 功能 :檢查房間的狀態是否可以刪除
 **=======================================================================**
 */
 private boolean isState(int aRow[]) {
 int ar = aRow.length;
 ResultSet rs = null;
 String aState = "";
 try {
 for (int i = 0; i < ar; i++) {
 rs = sunsql.executeQuery("select state from roominfo where " +
 "delmark=0 and pk='" + dtm12.getValueAt(aRow[i], 0) + "'");
 rs.next();
 aState = rs.getString(1);
 if(aState.equals("占用")) {
 JOptionPane.showMessageDialog(null, "[ " + dtm12.getValueAt(aRow[i], 2) + 
 " ] 房間正處於占用狀態,無法執行刪除操作,系統取消了所有刪除操作", "提示", JOptionPane.INFORMATION_MESSAGE);
 return false;
 }else if(aState.equals("鍾點")) {
 JOptionPane.showMessageDialog(null, "[ " + dtm12.getValueAt(aRow[i], 2) + 
 " ] 房間正處於鍾點房狀態,無法執行刪除操作,系統取消了所有刪除操作", "提示", JOptionPane.INFORMATION_MESSAGE);
 return false;
 }else if(aState.equals("預訂")) {
 JOptionPane.showMessageDialog(null, "[ " + dtm12.getValueAt(aRow[i], 2) + 
 " ] 房間正處於預訂狀態,無法執行刪除操作,系統取消了所有刪除操作", "提示", JOptionPane.INFORMATION_MESSAGE);
 return false;
 }//Endif
 }//Endif
 }
 catch (Exception ex) {
 ex.printStackTrace();
 System.out.println ("Setup.isState(): false");
 }//End try
 return true;
 }
 
 /**=======================================================================**
 * ActionListener 監聽
 **=======================================================================**
 */
 public void actionPerformed(ActionEvent ae) {
 Object o = ae.getSource();
 if(o == bt11) {//=======================================================
 art.show(true); //添加房間類型
 buildDTM11(); //刷新表數據
 buildDTM12(""); //刷新表數據
 buildDTM22(); //刷新表數據
 
 }else if(o == bt12) {//=================================================
 if(initMrt()) { //傳數據給窗口
 mrt.show(true); //修改房間類型
 buildDTM11(); //刷新表數據
 buildDTM12(""); //刷新表數據
 buildDTM22(); //刷新表數據
 }//Endif
 
 }else if(o == bt13) {//=================================================
 int rRow[] = tb11.getSelectedRows(); //刪除房間類型
 int sysmark;
 for (int i = 0; i < rRow.length; i++) {
 //獲得得記錄的屬性標志,並轉成整型
 sysmark = Integer.parseInt(dtm11.getValueAt(rRow[i], 1) + "");
 if(sysmark == 1) {
 JOptionPane.showMessageDialog(null, "[ " + dtm11.getValueAt(rRow[i], 4) + 
 " ] 類型為系統級設置,不允許被刪除,系統終止了刪除操作 ...", "提示",
 JOptionPane.INFORMATION_MESSAGE);
 return; //不執行刪除返回窗口
 }//Endif
 }//Endfor
 String msg = "注意,刪除 [ 房間類型 ] 操作會將與 [ 房間類型 ] 相關" +
 "的所有 [ 房間信息 ] 一並刪除。\n您確定要刪除在表格中選中的類型條目嗎?";
 
 if(delInfo ("roomtype", dtm11, rRow, msg)) { //執行刪除操作
 buildDTM11(); //刷新類型表數據
 buildDTM12(""); //刷新房間表數據
 buildDTM22(); //刷新類型表數據
 journal = "執行了刪除房間類型的操作--刪除數量:" + rRow.length;
 Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_RT);//記錄操作日志
 }//Endif
 
 }else if(o == bt14) {//=================================================
 if(initDis(tb11, dtm11)) { //房間費打折
 dis.show(true);
 }//Endif
 }else if(o == bt15) {//=================================================
 sunsql.initJComboBox(AddRoomInfo.cb1, "select r_type from roomtype where delmark = 0");
 ari.show(true); //單個添加房間信息
 buildDTM12(""); //刷新表數據
 
 }else if(o == bt16) {//=================================================
 sunsql.initJComboBox(AddRoomInfos.cb, "select r_type from roomtype where delmark = 0");
 aris.show(true); //批量添加房間信息
 buildDTM12(""); //刷新表數據
 
 }else if(o == bt18) {//=================================================
 sunsql.initJComboBox(ModiRoomInfo.cb1, "select r_type from roomtype where delmark = 0");
 if(initMri()) { //傳數據給窗口
 mri.show(true); //修改房間信息
 buildDTM12(""); //刷新表數據
 }//Endif
 
 }else if(o == bt17) {//=================================================
 int rRow[] = tb12.getSelectedRows(); //刪除房間信息
 if(isState(rRow)) { //判斷房間的狀態是否可以刪除
 if(delInfo ("roominfo", dtm12, rRow, msg0)) { //執行刪除操作
 buildDTM12(""); //刷新房間表數據
 journal = "執行了刪除房間信息的操作--刪除數量:" + rRow.length;
 Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_RI);//記錄操作日志
 }//Endif
 }
 }else if(o == bt19) {//=================================================
 if(!suntools.isNum(tf11.getText(),2 ,5 ,30)) { //保存退房后房間狀態
 JOptionPane.showMessageDialog(null, "結算后更改房間狀態的時間框只能為數字,且范圍在 5 - 30 之間",
 "提示", JOptionPane.INFORMATION_MESSAGE);
 tf11.requestFocus(true);
 return;
 }
 sunini.setIniKey(ini[16], cb12.getSelectedIndex() + ""); //將設置保存至緩沖區
 sunini.setIniKey(ini[17], tf11.getText()); 
 sunini.saveIni(ini); //將緩沖區的設置保存至INI文件
 
 }else if(o == bt20) {//=================================================
 int cbIndex = cb11.getSelectedIndex(); //篩選信息
 if(cbIndex == cb11.getItemCount() - 1) { //顯示全部房間
 buildDTM12(""); //刷新房間表數據
 }else {
 String rt = "and a.r_type_id = '" + dtm11.getValueAt(cbIndex, 2) + "'";
 buildDTM12(rt); //根據指定房間類型刷新表數據
 }//Endif
 
 }else if(o == bt21) {//=================================================
 act.show(true); //添加客戶類型
 buildDTM21();
 
 }else if(o == bt22) {//=================================================
 if(initMct()) { //傳數據給窗口
 mct.show(true); //修改客戶類型
 buildDTM21(); //刷新表數據
 }//Endif
 
 }else if(o == bt23) {//=================================================
 int rRow[] = tb21.getSelectedRows(); //刪除客戶類型
 if(delInfo ("customertype", dtm21, rRow, msg0)) { //執行刪除操作
 buildDTM21(); //刷新房間表數據
 journal = "執行了刪除客戶類型的操作--刪除數量:" + rRow.length;
 Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_US);//記錄操作日志
 }//Endif
 
 }else if(o == bt24) {//=================================================
 if(initDis(tb22, dtm22)) { //房間費打折
 dis.show(true);
 }//Endif
 }else if(o == bt31) {//===================================//登記操作員信息
 if(String.valueOf(tf32.getPassword()).length() == 0) {
 JOptionPane.showMessageDialog(null, " [ 新密碼 ] 不能為空", "提示", 
 JOptionPane.INFORMATION_MESSAGE);
 return;
 }else if(String.valueOf(tf33.getPassword()).length() == 0) {
 JOptionPane.showMessageDialog(null, " [ 確認密碼 ] 不能為空", "提示", 
 JOptionPane.INFORMATION_MESSAGE);
 return;
 }//Endif
 umAdd (); //執行添加操作
 buildDTM31(); //刷新表數據
 journal = "添加了新的操作員信息-- [ " + cb31.getEditor ().getItem () + " ]";
 Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_CZ);//記錄操作日志
 
 }else if(o == bt32) {//==================================//修改操作員信息
 if(String.valueOf(tf31.getPassword()).length() == 0) {
 JOptionPane.showMessageDialog(null, " [ 新密碼 ] 不能為空", "提示", 
 JOptionPane.INFORMATION_MESSAGE);
 return;
 }else if(String.valueOf(tf32.getPassword()).length() == 0) {
 JOptionPane.showMessageDialog(null, " [ 新密碼 ] 不能為空", "提示", 
 JOptionPane.INFORMATION_MESSAGE);
 return;
 }else if(String.valueOf(tf33.getPassword()).length() == 0) {
 JOptionPane.showMessageDialog(null, " [ 確認密碼 ] 不能為空", "提示", 
 JOptionPane.INFORMATION_MESSAGE);
 return;
 }//Endif
 umUpdate (0); //執行修改密碼操作
 journal = "修改了操作員 [ " + cb31.getEditor ().getItem () + " ] 的設置";
 Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_CZ);//記錄操作日志
 
 }else if(o == bt33) {//=================================================//刪除操作員信息
 if(String.valueOf(tf32.getPassword()).length() == 0) {
 JOptionPane.showMessageDialog(null, " [ 新密碼 ] 不能為空", "提示", 
 JOptionPane.INFORMATION_MESSAGE);
 return;
 }else if(String.valueOf(tf33.getPassword()).length() == 0) {
 JOptionPane.showMessageDialog(null, " [ 確認密碼 ] 不能為空", "提示", 
 JOptionPane.INFORMATION_MESSAGE);
 return;
 }//Endif
 int wi = JOptionPane.showConfirmDialog(null,"您確認要刪除當前的用戶ID嗎?", 
 "提示", JOptionPane.YES_NO_OPTION);
 
 if(wi == JOptionPane.YES_OPTION) {
 umUpdate (1); //執行刪除用戶ID操作
 buildDTM31(); //刷新表數據
 journal = "刪除了操作員 [ " + cb31.getEditor ().getItem () + " ] 的設置";
 Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_CZ);//記錄操作日志
 }//Endif
 
 }else if(o == bt41) {//=================================================
 if(isValidity()) {
 int saveJf = JOptionPane.showConfirmDialog(null, "您 確 實 要 保 存 " +
 "當 前 的 計 費 設 置 嗎 ?","保存設置",JOptionPane.YES_NO_OPTION);
 if(saveJf == JOptionPane.YES_OPTION) { //保存計費設置
 sunini.setIniKey("In_Room", tf41.getText()); //將設置保存至緩沖區
 sunini.setIniKey("Out_Room1", tf42.getText());
 sunini.setIniKey("Out_Room2", tf43.getText());
 sunini.setIniKey("ClockRoom1", tf44.getText());
 sunini.setIniKey("ClockRoom2", tf45.getText());
 sunini.setIniKey("InsuHour1", tf46.getText());
 sunini.setIniKey("InsuHour2", tf47.getText());
 if(ck.isSelected()) { //不足一天按一天收費
 sunini.setIniKey("InsuDay","1");
 }else {
 sunini.setIniKey("InsuDay","0");
 }//Endif
 sunini.saveIni(ini); //將緩沖區的設置保存至INI文件
 journal = "修改了系統的計費設置";
 Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_JF);//記錄操作日志
 }//Endif
 }//Endif
 }else if(o == bt42) {//=================================================
 this.setVisible(false); //返回主窗口
 }else if(o == tf41) {
 tf42.requestFocus(true);
 }else if(o == tf42) {
 tf43.requestFocus(true);
 }else if(o == tf43) {
 tf44.requestFocus(true);
 }else if(o == tf44) {
 tf45.requestFocus(true);
 }else if(o == tf45) {
 tf46.requestFocus(true);
 }else if(o == tf46) {
 tf47.requestFocus(true);
 
 }else if(o == rb31) {//=================================================
 bt31.setEnabled (true); //操作范圍--添加新操作員
 bt32.setEnabled (false);
 bt33.setEnabled (false);
 rb34.setEnabled (true);
 rb35.setEnabled (true);
 tf31.setEditable(false);
 tf32.setEditable(true);
 tf33.setEditable(true);
 cb31.setEditable (true);
 
 }else if(o == rb32) { //操作范圍--操作員修改密碼
 bt31.setEnabled (false);
 bt32.setEnabled (true);
 bt33.setEnabled (false);
 rb34.setEnabled (false);
 rb35.setEnabled (false);
 tf31.setEditable(true);
 tf32.setEditable(true);
 tf33.setEditable(true);
 cb31.setEditable (false);
 
 }else if(o == rb33) { //操作范圍--刪除操作員
 bt31.setEnabled (false);
 bt32.setEnabled (false);
 bt33.setEnabled (true);
 rb34.setEnabled (false);
 rb35.setEnabled (false);
 tf31.setEditable(false);
 tf32.setEditable(true);
 tf33.setEditable(true);
 cb31.setEditable (false);
 }//Endif
 }//End actionPerformed
 
 
 /**=======================================================================**
 * MouseListener 監聽
 **=======================================================================**
 */
 public void mouseClicked (MouseEvent me) {
 }
 
 public void mousePressed (MouseEvent me) {
 }
 
 public void mouseReleased(MouseEvent me) {
 }
 
 public void mouseEntered (MouseEvent me) { //鼠標移進提示
 Object o = me.getSource ();
 if(o == bt11) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "添加新的房間類型                    ");
 }else if(o == bt12) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "修改指定的房間類型                   ");
 }else if(o == bt13) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "刪除指定的房間類型                   ");
 }else if(o == bt14) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "設置指定房間類型的消費折扣               ");
 }else if(o == bt15) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "為指定的房間類型添加新的客房              ");
 }else if(o == bt16) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "為指定的房間類型一次添加多個新客房           ");
 }else if(o == bt17) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "修改指定客房信息設置                  ");
 }else if(o == bt18) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "刪除指定的客房                     ");
 }else if(o == bt19) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "保存房間退房后的狀態                  ");
 }else if(o == bt20) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "以左邊指定的類型顯示房間信息              ");
 } if(o == bt21) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "添加新的客戶類型                    ");
 }else if(o == bt22) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "修改指定的客戶資料                   ");
 }else if(o == bt23) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "刪除指定的客戶資料                   ");
 }else if(o == bt24) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "設置指定房間類型的消費折扣               ");
 }else if(o == bt31) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "添加新的操作員                     ");
 }else if(o == bt32) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "修改指定的操作員密碼                  ");
 }else if(o == bt33) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "刪除指定的操作員                    ");
 }else if(o == bt41) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "保存當前的計費設置至INI配置文件             ");
 }else if(o == bt42) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "返回主窗口                       ");
 }
 }
 
 public void mouseExited (MouseEvent me) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "請選擇功能項 ...                     ");
 }
 
}

3.登錄窗口:

import javax.swing.*;
import javax.swing.border.*;
import java.awt.*;
import java.awt.event.*;
import java.sql.*;
import com.sunshine.sunsdk.sql.*;
import com.sunshine.sunsdk.swing.*;
import com.sunshine.sunsdk.system.*;
import com.sunshine.mainframe.*;
 
 
public class Login extends JFrame
implements ActionListener, KeyListener, ItemListener, FocusListener {
 
 JLabel top, bott;
 JComboBox cb;
 JPasswordField pf;
 JButton bt1, bt2;
 JPanel panelMain, panelInfo;
 String clue = " 提 示 : ";
 int flag = 0; //登記次數記數器
 
 /**=======================================================================**
 * [## public Login() {} ]: 構造函數
 * 參數 :無
 * 返回值 :無
 * 修飾符 :public
 * 功能 :組建登錄窗口
 **=======================================================================**
 */
 public Login() {
 super("系 統 登 錄");
 top = new JLabel (new ImageIcon("pic/login_top.gif"));
 bott = new JLabel();
 panelMain = new JPanel(new BorderLayout(10, 10));
 bott.setBorder(new LineBorder (new Color(184, 173, 151)));
 buildCenter();
 
 panelMain.add("North", top);
 panelMain.add("South", bott);
 panelMain.add(panelInfo);
 
 //加事件監聽
 bt1.addActionListener(this);
 bt2.addActionListener(this);
 bt1.addFocusListener (this);
 bt2.addFocusListener (this);
 bt1.addKeyListener (this);
 bt2.addKeyListener (this);
 cb.addItemListener (this);
 cb.addFocusListener(this);
 pf.addFocusListener(this);
 cb.addKeyListener (this);
 pf.addKeyListener (this);
 
 //加窗口監聽 new WindowAdapter適配器類
 this.addWindowListener(new WindowAdapter() {
 public void windowClosing(WindowEvent we) {
 quit();
 }//End windowClosing
 });
 
 this.setContentPane(panelMain); //設置窗口面板
 this.setSize(350, 235);
 this.setResizable (false); //設置窗口不可放大縮小
 this.setDefaultCloseOperation(JFrame.DO_NOTHING_ON_CLOSE);
 sunswing.setWindowCenter(this);
 this.setVisible(true);
 pf.requestFocus(true); //設置焦點給密碼框
 }
 
 /**=======================================================================**
 * [## private void buildCenter() {} ]: 制作用戶名密碼面板
 * 參數 :無
 * 返回值 :無
 * 修飾符 :private
 * 功能 :組建用戶名密碼面板,僅類內使用
 **=======================================================================**
 */
 private void buildCenter() {
 
 JLabel lb1, lb2;
 JPanel pa1, pa2, pa3;
 
 lb1 = new JLabel("用 戶 名 :");
 lb2 = new JLabel("登錄密碼 :");
 cb = new JComboBox();
 pf = new TJPasswordField (15);
 bt1 = new TJButton ("pic/key.gif", "登 錄", "登錄系統");
 bt2 = new TJButton ("pic/exit.gif", "退 出", "關閉系統");
 sunsql.initJComboBox (cb, "select userid from pwd where delmark=0");
 
 //定義面板為無部局
 panelInfo = new JPanel(null);
 //加入組件
 panelInfo.add(lb1);
 panelInfo.add(lb2);
 panelInfo.add(cb);
 panelInfo.add(pf);
 panelInfo.add(bt1);
 panelInfo.add(bt2);
 
 lb1.setBounds(50,14,60,20);
 lb2.setBounds(50,48,60,20);
 bt1.setBounds(68,77,86,28);
 bt2.setBounds(186,77,86,28);
 cb.setBounds (115,12,168,23);
 pf.setBounds (115,46,170,23);
 
 //設定邊框線
 panelInfo.setBorder(BorderFactory.createTitledBorder(""));
 }
 
 /**=======================================================================**
 * [## private void quit() {} ]: 系統退出
 * 參數 :無
 * 返回值 :無
 * 修飾符 :private
 * 功能 :關閉系統函數,僅類內使用
 **=======================================================================**
 */
 private void quit() {
 int flag = 0;
 String msg = "您 現 在 要 關 閉 系 統 嗎 ?";
 flag = JOptionPane.showConfirmDialog(null, msg, "提示", JOptionPane.YES_NO_OPTION);
 if(flag == JOptionPane.YES_OPTION) {
 this.setVisible(false);
 System.exit(0);
 }//End if(flag == JOptionPane.YES_OPTION)
 return;
 }
 
 /**=======================================================================**
 * [## private void dengLu() {} ]: 系統登錄
 * 參數 :無
 * 返回值 :無
 * 修飾符 :private
 * 功能 :密碼驗證通過,進入主操作界面,僅類內使用
 **=======================================================================**
 */
 private void dengLu() {
 String user = cb.getSelectedItem() + "";
 String pwd = String.valueOf(pf.getPassword());
 String code = "select pwd,puis from pwd where delmark=0 and userid='" + user + "'";
 ResultSet rs = sunsql.executeQuery (code);
 try {
 if(rs.next()) { //用戶名存在
 if(pwd.equals(rs.getString(1))) {
 bott.setText(clue + "登錄成功,正在進入系統 ...");
 String puis = rs.getString(2); //獲得操作員權限
 boolean flag = Journal.writeJournalInfo(user, "登錄本系統", Journal.TYPE_LG);
 if(flag) { //記錄日志
 new com.sunshine.mainframe.HotelFrame(user, puis); //進入主程序窗口(用戶名, 權限)
 this.setVisible(false);
 }else {
 String msg = "寫日志錯誤,請與系統管理員聯系 ...";
 JOptionPane.showMessageDialog(null, msg, "錯誤", JOptionPane.ERROR_MESSAGE);
 System.exit(0);
 }
 }
 else {
 bott.setText(clue + "用戶 [ " + user + " ] 的密碼不正確,請重新輸入 ...");
 flag++;
 if(flag == 3) { //三次密碼驗證
 JOptionPane.showMessageDialog(null, "您不是本系統的管理員,系統關閉 ...", "警告", JOptionPane.ERROR_MESSAGE);
 System.exit(0);
 }//End if(flag == 3)
 return;
 }//End if(pwd.equals(rs.getString(1)))
 }
 else {
 bott.setText(clue + "用戶ID [ " + user + " ] 不存在 ...");
 }//End if(rs.next()) 
 }
 catch (Exception ex) {
 ex.printStackTrace();
 }//End try
 }
 
 /**=======================================================================**
 * ActionListener 監聽
 **=======================================================================**
 */
 public void actionPerformed (ActionEvent ae) {
 //動作監聽
 if(ae.getSource() == bt1) { //登錄按鍵
 dengLu();
 }
 else {
 quit();
 }//End if(ae.getSource() == bt1)
 }
 
 /**=======================================================================**
 * ItemListener 監聽
 **=======================================================================**
 */
 public void itemStateChanged (ItemEvent ie) {
 pf.requestFocus(true);
 } 
 
 /**=======================================================================**
 * KeyListener 監聽
 **=======================================================================**
 */
 public void keyPressed (KeyEvent ke) {
 //鍵盤按下監聽
 int key = ke.getKeyCode();
 if(key == KeyEvent.VK_ENTER) {
 if(ke.getSource() == cb)
 pf.requestFocus(true); //將焦點從用戶名給密碼
 if(pf.getPassword().length > 0)
 dengLu(); //按Enter鍵登錄系統
 }
 else if(key == KeyEvent.VK_ESCAPE) { //按ESC鍵退出系統
 quit();
 }//End if
 }
 
 public void keyReleased (KeyEvent ke) {
 //鍵盤釋放監聽
 }
 
 public void keyTyped (KeyEvent ke) {
 //按鍵型監聽
 }
 
 /**=======================================================================**
 * FocusListener 監聽
 **=======================================================================**
 */
 public void focusGained (FocusEvent fe) {
 //焦點監聽
 if(fe.getSource() == cb) //窗口最下方的功能提示
 bott.setText(clue + "請選擇操作員名稱 ...");
 else
 if(fe.getSource() == pf)
 bott.setText(clue + "請輸入登錄密碼 ...");
 else
 if(fe.getSource() == bt1)
 bott.setText(clue + "登錄系統 ...");
 else
 if(fe.getSource() == bt2)
 bott.setText(clue + "退出系統 ...");
 }
 
 public void focusLost (FocusEvent fe) {
 //失去焦點監聽
 }
 
 /**=======================================================================**
 * [## public static void main(String sd[]) {} ]: 主函數
 * 參數 :String sd[] 
 * 返回值 :無
 * 修飾符 :public static
 * 功能 :程序入口
 **=======================================================================**
 */
 public static void main(String sd[]) {
 sunswing.setWindowStyle(sunini.getIniKey("Sys_style").charAt(0));
 new FStartWindow ("pic/Login.gif", new Frame(), 1200);
 new Login();
 }
 
}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM