国产无遮挡裸体免费直播视频,久久精品国产蜜臀av,动漫在线视频一区二区,欧亚日韩一区二区三区,久艹在线 免费视频,国产精品美女网站免费,正在播放 97超级视频在线观看,斗破苍穹年番在线观看免费,51最新乱码中文字幕

Java swing實(shí)現(xiàn)酒店管理系統(tǒng)

 更新時(shí)間:2019年02月21日 11:23:13   作者:明禮馨德  
這篇文章主要為大家詳細(xì)介紹了Java swing實(shí)現(xiàn)酒店管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

今天給大家提供一個(gè)由今天給大家提供一個(gè)由Java swing實(shí)現(xiàn)的酒店管理系統(tǒng),數(shù)據(jù)庫(kù)采用sqlserver,我會(huì)貼上部分代碼,完整的代碼請(qǐng)看文章最下方下載,下面看代碼:

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 關(guān)于我們.About;
import 團(tuán)體開(kāi)單.Team;
import 客戶(hù)管理.Customer;
import 客房預(yù)定.Engage;
import 賓客結(jié)賬.CheckOut;
import 散客開(kāi)單.Individual;
import 系統(tǒng)設(shè)置.Setup;
import 網(wǎng)絡(luò)設(shè)置.NetSetup;
import 菜單事件窗口.ApartBill;
import 菜單事件窗口.Change;
import 菜單事件窗口.GoOn;
import 菜單事件窗口.Record;
import 菜單事件窗口.UniteBill;
import 營(yíng)業(yè)查詢(xún).Query;
//加入公共類(lèi)庫(kù)
//加入模塊類(lèi)庫(kù)
//散客開(kāi)單
//團(tuán)體開(kāi)單
//賓客結(jié)帳
//預(yù)訂房間
//營(yíng)業(yè)查詢(xún)
//客戶(hù)管理
//網(wǎng)絡(luò)設(shè)置
//系統(tǒng)設(shè)置
//關(guān)于我們
//下拉菜單中的功能庫(kù)
 
 
 
public class HotelFrame 
extends JFrame 
implements ActionListener, MouseListener, Runnable {
 
 //用戶(hù)名,權(quán)限
 public static String userid, puil;
 public static JLabel lbA, lbB;
 public static String clue = " 提 示 : ";
 public static String face = " 當(dāng)前操作界面 : ";
 
 //聲名與菜單相關(guān)的類(lèi)
 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[] = {
 "零散賓客入住登記                    ",
 "團(tuán)體入住登記                      ",
 "關(guān)于本軟件的支持信息                  ",
 "賓客退房結(jié)算                      ",
 "為賓客預(yù)訂房間                     ",
 "查詢(xún)營(yíng)業(yè)情況                      ",
 "為酒店固定客戶(hù)設(shè)置參數(shù)                 ",
 "設(shè)置系統(tǒng)的網(wǎng)絡(luò)連接方式                 ",
 "設(shè)置系統(tǒng)參數(shù)                      ",
 "返回Windows                      "
 };
 
 //功能模塊
 /*#######################################################################*/
 Individual idv = new Individual(this); //散客開(kāi)單
 Team tm = new Team(this); //團(tuán)體開(kāi)單
 CheckOut co = new CheckOut(this); //賓客結(jié)帳
 Engage eg = new Engage(this); //客房預(yù)定
 Query qr = new Query(this); //營(yíng)業(yè)查詢(xún)
 Customer ct = new Customer(this); //客戶(hù)管理
 NetSetup ns = new NetSetup(this); //網(wǎng)絡(luò)設(shè)置
 Setup st = new Setup(this); //系統(tǒng)設(shè)置
 About ab = new About(this); //關(guān)于我們 
 GoOn go = new GoOn(this); //賓客續(xù)住
 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); //系統(tǒng)日志
 /*#######################################################################*/
 
 
 
 //構(gòu)造函數(shù)
 public HotelFrame (String us, String pu) {
 super ("陽(yáng)光酒店管理系統(tǒng) - ★★版");
 
 userid = us; //獲得操作員名稱(chēng)
 puil = pu; //獲得操作員權(quán)限
 
 panelMain = new JPanel (new BorderLayout()); //主面板
 
 //制作菜單
 buildMenuBar ();
 //制作工具欄
 buildToolBar ();
 //制作分割面板
 buildSpaneMain ();
 //制作窗口底端信息框
 buildBott ();
 
 //加入組件到主面板
 panelMain.add ("North", tb); //加入工具欄
 panelMain.add ("South", bott); //加入窗口底端信息框
 panelMain.add ("Center", spaneMain); //加入分割面板
 
 //加入菜單欄
 this.setJMenuBar (mb);
 
 //加事件監(jiān)聽(tīng)
 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)); //設(shè)置窗口最小尺寸
 this.setVisible (true);
 (new Thread(this)).start(); //啟動(dòng)房間狀態(tài)檢查線程
 }
 
 //制作菜單
 private void buildMenuBar () {
 //實(shí)例菜單欄
 mb = new JMenuBar ();
 
 //實(shí)例菜單
 m1 = new JMenu ("來(lái)賓登記 (B)");
 m2 = new JMenu ("收銀結(jié)算 (S)");
 m3 = new JMenu ("系統(tǒng)維護(hù) (W)");
 
 //實(shí)例菜單項(xiàng)
 mi11 = new JMenuItem ("散客開(kāi)單  (G)");
 mi12 = new JMenuItem ("團(tuán)體開(kāi)單  (M)");
 mi13 = new JMenuItem ("賓客續(xù)住  (Z)");
 mi14 = new JMenuItem ("更換房間  (A)");
 mi15 = new JMenuItem ("修改登記  (J)");
 mi16 = new JMenuItem ("房間狀態(tài)  (Z)");
 mi17 = new JMenuItem ("預(yù)訂管理  (T)");
 mi18 = new JMenuItem ("電子提醒  (L)");
 mi19 = new JMenuItem ("退出系統(tǒng)  (X)");
 mi21 = new JMenuItem ("賓客結(jié)帳  (J)");
 mi22 = new JMenuItem ("合并帳單  (E)");
 mi23 = new JMenuItem ("折分帳單  (F)");
 mi24 = new JMenuItem ("賓客消費(fèi)明細(xì)查詢(xún)");
 mi25 = new JMenuItem ("賓客退單明細(xì)查詢(xún)");
 mi31 = new JMenuItem ("網(wǎng)絡(luò)設(shè)置  (N)");
 mi32 = new JMenuItem ("系統(tǒng)設(shè)置  (X)");
 mi33 = new JMenuItem ("系統(tǒng)日志  (Z)");
 mi34 = new JMenuItem ("數(shù)據(jù)備份  (R)");
 mi35 = new JMenuItem ("軟件幫助  (H)");
 mi36 = new JMenuItem ("關(guān)于我們  (A)");
 ///////////////////////////////////////////
 mi16.setEnabled(false);//未開(kāi)發(fā)完畢的功能
 mi18.setEnabled(false);
 mi34.setEnabled(false);
 ////////////////////////////////////////////
 //組織菜單
 m1.add (mi11); //來(lái)賓登記
 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); //收銀結(jié)算
 m2.add (mi22);
 m2.add (mi23);
 //m2.addSeparator();
 //m2.add (mi24); //賓客消費(fèi)明細(xì)
 //m2.add (mi25);
 m3.add (mi31); //系統(tǒng)維護(hù)
 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", " 散客開(kāi)單 ", "零散賓客入住登記", true);
 bt2 = new TJButton ("pic/ToolBar/m02.gif", " 團(tuán)體開(kāi)單 ", "團(tuán)體入住登記", true);
 bt3 = new TJButton ("pic/ToolBar/m03.gif", " 關(guān)于我們 ", "軟件信息", true);
 bt4 = new TJButton ("pic/ToolBar/m04.gif", " 賓客結(jié)帳 ", "賓客退房結(jié)算", true);
 bt5 = new TJButton ("pic/ToolBar/m05.gif", " 客房預(yù)訂 ", "為賓客預(yù)定房間", true);
 bt6 = new TJButton ("pic/ToolBar/m06.gif", " 營(yíng)業(yè)查詢(xún) ", "查詢(xún)營(yíng)業(yè)情況", true);
 bt7 = new TJButton ("pic/ToolBar/m07.gif", " 客戶(hù)管理 ", "為酒店固定客戶(hù)設(shè)置", true);
 bt8 = new TJButton ("pic/ToolBar/m08.gif", " 網(wǎng)絡(luò)設(shè)置 ", "設(shè)置連接方式", true);
 bt9 = new TJButton ("pic/ToolBar/m09.gif", " 系統(tǒng)設(shè)置 ", "設(shè)置系統(tǒng)參數(shù)", true);
 btA = new TJButton ("pic/ToolBar/m10.gif", " 退出系統(tǒng) ", "返回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);
 
 //設(shè)置工具欄不可浮動(dòng)
 tb.setFloatable(false);
 }
 
 //制作主面板
 private void buildSpaneMain () {
 
 jp1 = new LeftTopPanel (); //這四個(gè)面板為功能接口//////////////
 jp2 = new LeftBottPanel(); //左下面板 快速通道
 jp3 = new RightTopPanel(); ///////////////////////////////
 jp4 = new RightBottPanel(); //右下面板 消費(fèi)信息表
 
 //聲名分割面板
 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);
 
 //設(shè)置面板最小尺寸
 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));
 
 //設(shè)置分割條是否有伸縮鍵
 spaneMain.setOneTouchExpandable (true);
 spaneRight.setOneTouchExpandable(true);
 
 //設(shè)置各面板的初起尺寸
 spaneMain.setDividerLocation (160);
 spaneLeft.setDividerLocation (450);
 spaneRight.setDividerLocation(450);
 
 //設(shè)置分隔條寬度
 spaneMain.setDividerSize (10);
 spaneLeft.setDividerSize (23);
 spaneRight.setDividerSize(23);
 }
 
 //制作bott欄
 private void buildBott () {
 JLabel lb1, lb2;
 
 lb1 = new JLabel(" 陽(yáng) 光 酒 店 管 理 系 統(tǒng) ");
 lb2 = new JLabel(" 當(dāng)前操作員 : " + userid + "  ");
 lbA = new JLabel(clue + "請(qǐng)選擇功能項(xiàng) ...                     ");
 lbB = new JLabel(face + "陽(yáng) 光 酒 店 管 理 系 統(tǒng) - ★★ 版 ");
 
 //加外框線
 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);
 }
 
 //加事件監(jiān)聽(tīng)
 private void addListener () {
 mi11.addActionListener (this); //來(lái)賓登記
 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); //收銀結(jié)算
 mi22.addActionListener (this);
 mi23.addActionListener (this);
 mi24.addActionListener (this);
 mi25.addActionListener (this);
 mi31.addActionListener (this); //系統(tǒng)維護(hù)
 mi32.addActionListener (this);
 mi33.addActionListener (this);
 mi34.addActionListener (this);
 mi35.addActionListener (this);
 mi36.addActionListener (this);
 bt1.addActionListener (this); //按鍵加動(dòng)作監(jiān)聽(tīng)
 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); //按鍵加鼠標(biāo)監(jiān)聽(tīng)
 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 () {} ]: 系統(tǒng)退出
 * 參數(shù) :無(wú)
 * 返回值 :無(wú)
 * 修飾符 :private
 * 功能 :關(guān)閉系統(tǒng)函數(shù),僅類(lèi)內(nèi)使用
 **=======================================================================**
 */
 private void quit () {
 int flag = 0;
 String msg = "您 現(xiàn) 在 要 關(guān) 閉 系 統(tǒng) 嗎 ?";
 flag = JOptionPane.showConfirmDialog (null, msg, "提示", JOptionPane.YES_NO_OPTION);
 if(flag == JOptionPane.YES_OPTION) {
 Journal.writeJournalInfo(userid, "退出本系統(tǒng)", Journal.TYPE_LG);//記錄操作日志
 this.setVisible (false);
 System.exit (0);
 }//End if(flag == JOptionPane.YES_OPTION)
 return;
 }
 
 //刷新左房間信息欄數(shù)據(jù)
 private void initLeftData() {
 jp1.title1.setText(""); //刷房間信息
 for (int i = 0; i < 8; i++) {
 jp1.lt[i].setText("");
 }//Endfor
 jp1.initRoomstate(); //刷新房間總狀態(tài)
 }
 
 //傳數(shù)據(jù)給散客開(kāi)單窗口
 private boolean initIDV() {
 try {
 //從房間信息表里獲得當(dāng)前房間的狀態(tài)和房間類(lèi)型編號(hào)
 ResultSet rs = sunsql.executeQuery("select state,r_type_id from roominfo " +
 "where delmark=0 and id='" + LeftTopPanel.title1.getText() + "'");
 
 if(!rs.next()) { //如果無(wú)結(jié)果集,提示用戶(hù)刷新房間數(shù)據(jù)
 if(LeftTopPanel.title1.getText().length() == 0) {
 JOptionPane.showMessageDialog(null,"請(qǐng)選定房間后,再為賓客開(kāi)設(shè)房間", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 }else {
 JOptionPane.showMessageDialog(null, "[ " + LeftTopPanel.title1.getText() + 
 " ] 房間信息已更改,請(qǐng)刷新房間信息,再為賓客開(kāi)設(shè)房間", "提示", JOptionPane.INFORMATION_MESSAGE);
 }
 return false;
 }else {
 if(!rs.getString(1).equals("可供")) { //只有狀態(tài)是可供房間,才能為賓客開(kāi)設(shè)
 JOptionPane.showMessageDialog(null, "請(qǐng)選擇空房間,再為賓客開(kāi)設(shè)房間", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 return false;
 }//Endif
 
 //傳房間號(hào)到開(kāi)單窗口
 Individual.lbA.setText(LeftTopPanel.title1.getText());
 //傳房間類(lèi)型到開(kāi)單窗口
 Individual.lbB.setText(LeftTopPanel.title0.getText().substring(0, 
 LeftTopPanel.title0.getText().length()-2));
 //傳房間單價(jià)到開(kāi)單窗口
 Individual.lbC.setText(LeftTopPanel.lt[1].getText());
 
 //房間類(lèi)型編號(hào)
 String clRoom = rs.getString(2);
 //獲得此類(lèi)型房間是否可以開(kāi)設(shè)鐘點(diǎn)房
 rs = sunsql.executeQuery("select cl_room from roomtype where " +
 "delmark=0 and id='" + clRoom + "'");
 rs.next();
 if(rs.getString(1).equals("N")) { //不能開(kāi)設(shè),則開(kāi)單窗口的鐘點(diǎn)選項(xiàng)不可用
 Individual.chk1.setSelected(false); //取消選中狀態(tài)
 Individual.chk1.setEnabled(false); //設(shè)置不可用
 }else {
 Individual.chk1.setEnabled(true); //可用
 }//Endif
 
 //傳賓客類(lèi)型數(shù)據(jù)給開(kāi)單窗口
 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("普通賓客");
 
 //初始化開(kāi)單房間表---------臨時(shí)表
 sunsql.executeUpdate("delete from roomnum"); //清空臨時(shí)表
 sunsql.executeUpdate("insert into roomnum(roomid) values('" + 
 LeftTopPanel.title1.getText() + "')"); //加入當(dāng)前房間信息
 //初始化開(kāi)單窗口的開(kāi)單房間表
 sunsql.initDTM(Individual.dtm2,"select roomid 房間編號(hào) from roomnum");
 
 //初始化追加房間表---------當(dāng)前類(lèi)型的除當(dāng)前房間的所有可供房間
 sunsql.executeUpdate("update roominfo set indimark=0"); //刷新所有房間的開(kāi)單狀態(tài)
 sunsql.executeUpdate("update roominfo set indimark=1 where id='" + 
 LeftTopPanel.title1.getText() + "'"); //設(shè)置當(dāng)前房間為開(kāi)單狀態(tài)
 //初始化開(kāi)單窗口的可供房間表
 sunsql.initDTM(Individual.dtm1,"select a.id 房間編號(hào)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;
 }
 
 //傳數(shù)據(jù)給團(tuán)體開(kāi)單窗口
 private boolean initTeam() {
 try {
 //初始化開(kāi)單房間表---------臨時(shí)表
 sunsql.executeUpdate("delete from roomnums"); //清空臨時(shí)表
 //初始化開(kāi)單窗口的開(kāi)單房間表
 Team.initDTM2();
 
 //初始化追加房間表---------當(dāng)前類(lèi)型的除當(dāng)前房間的所有可供房間
 sunsql.executeUpdate("update roominfo set indimark=0"); //刷新所有房間的開(kāi)單狀態(tài)
 
 //傳房間類(lèi)型數(shù)據(jù)給團(tuán)體開(kāi)單窗口
 ResultSet rs = sunsql.executeQuery("select r_type from roomtype where delmark=0");
 int ct = sunsql.recCount(rs);
 String type[] = new String[ct];
 
 //傳賓客房型數(shù)據(jù)給團(tuán)體開(kāi)單窗口
 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
 
 //傳賓客類(lèi)型數(shù)據(jù)給團(tuán)體開(kāi)單窗口
 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;
 }
 
 //傳數(shù)據(jù)給結(jié)算窗口
 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()) { //如果無(wú)結(jié)果集,提示用戶(hù)刷新房間數(shù)據(jù)
 if(LeftTopPanel.title1.getText().length() == 0) {
 JOptionPane.showMessageDialog(null,"請(qǐng)選定賓客入住的房間后,再為賓客結(jié)算費(fèi)用", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 }else {
 JOptionPane.showMessageDialog(null, "[ " + LeftTopPanel.title1.getText() + 
 " ] 房間信息已更改,請(qǐng)刷新房間信息,再為賓客開(kāi)設(shè)房間", "提示", JOptionPane.INFORMATION_MESSAGE);
 }//Endif
 return false;
 }else {
 //只有狀態(tài)是占用或鐘點(diǎn)房間,才能為賓客結(jié)算
 if(!rs.getString(1).equals("占用") && !rs.getString(1).equals("鐘點(diǎn)")) {
 JOptionPane.showMessageDialog(null, "請(qǐng)選擇賓客正在消費(fèi)的房間進(jìn)行結(jié)算費(fèi)用操作", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 return false;
 }//Endif
 
 //傳結(jié)算單號(hào)給結(jié)算窗口
 co.lbA.setText(suntools.getNumber(suntools.Number_JS));
 //傳結(jié)算房間給結(jié)算窗口
 co.lbB.setText(jp1.title1.getText());
 //傳結(jié)算賓客名稱(chēng)給結(jié)算窗口
 co.lbC.setText(jp1.lt[0].getText());
 //傳押金給結(jié)算窗口
 co.lbF.setText(jp1.lt[6].getText());
 
 //清空結(jié)算中間表
 sunsql.executeUpdate("delete from checkout_temp");
 
 //獲得主房間號(hào)
 rs = sunsql.executeQuery("select main_room,in_no from livein where " +
 "delmark=0 and r_no='" + co.lbB.getText() + "' and statemark='正在消費(fèi)'");
 
 if(!rs.next()) {
 JOptionPane.showMessageDialog(null, "操作失敗,請(qǐng)檢查網(wǎng)絡(luò)情況", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 return false;
 }//Endif
 
 String mainRoom = rs.getString(1); //取出主房間號(hào)
 co.inNo = rs.getString(2); //傳入住單號(hào)為結(jié)算窗口
 
 //獲得主房間狀態(tài),看是普通住宿還是鐘點(diǎn)房
 rs = sunsql.executeQuery("select state from roominfo where delmark=0 and id='" + mainRoom + "'"); 
 rs.next();
 int mrState = 0; //主房間狀態(tài) 0:普通入住 1:鐘點(diǎn)房
 if(rs.getString(1).equals("鐘點(diǎn)")) {
 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; //消費(fèi)總金額
 double shsh = 0; //實(shí)收金額
 double youh = 0; //優(yōu)惠金額
 for (int i = 0; i < ckoDTM.getRowCount(); i++) {
 //取出當(dāng)前房間的標(biāo)準(zhǔn)單價(jià)
 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); //普通入住單價(jià)
 //獲得入住天數(shù)
 days = suntools.getConsumeFactor(ckoDTM.getValueAt(i, 4) + "", Journal.getNowDTime());
 }else {
 rprice = rs.getDouble(2); //鐘點(diǎn)房單價(jià)
 days = suntools.getClockFactor(ckoDTM.getValueAt(i, 4) + "", Journal.getNowDTime());
 }//Endif
 
 double rd = rprice * days; //當(dāng)前房間的消費(fèi)總金額
 total = total + rd; //累加總消費(fèi)
 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; //當(dāng)前房間的打折后價(jià)格
 shsh = shsh + ddr; //應(yīng)收金額累加
 youh = youh + rd - ddr; //優(yōu)惠金額累加
 
 //向結(jié)算中間表加入數(shù)據(jù)
 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) + "')");
 }
 
 //傳消費(fèi)金額給結(jié)算窗口
 co.lbD.setText(total + "");
 //傳應(yīng)收金額給結(jié)算窗口
 co.lbE.setText(shsh + "");
 //傳實(shí)收金額
 co.tf1.setText(shsh + "");
 //傳優(yōu)惠金額給結(jié)算窗口
 co.lbG.setText(youh + "");
 //傳找零金額給結(jié)算窗口
 co.lbH.setText(Double.parseDouble(co.lbF.getText()) - shsh + "");
 
 //刷新結(jié)算中間表數(shù)據(jù)
 co.initDTM();
 
 co.tf2.requestFocus(true); //給賓客支付焦點(diǎn)
 
 }//Endif
 }
 catch (Exception ex) {
 JOptionPane.showMessageDialog(null, "操作失敗,請(qǐng)檢查網(wǎng)絡(luò)情況", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 ex.printStackTrace();
 System.out.println ("HotelFrame.initCKO(): false");
 return false;
 }//End try
 return true;
 }
 
 /**=======================================================================**
 * ActionListener 監(jiān)聽(tīng)
 **=======================================================================**
 */
 public void actionPerformed (ActionEvent ae) {
 Object o = ae.getSource ();
 if(o == bt1 || o ==mi11) {//============================================
 lbB.setText(face + "散 客 開(kāi) 單         -");
 if(initIDV()) { //傳數(shù)據(jù)給散客開(kāi)單窗口
 idv.show(); //散客開(kāi)單
 initLeftData(); //刷新左房間信息欄數(shù)據(jù)
 }//Endif
 }else if(o == bt2 || o == mi12) {//=====================================
 lbB.setText(face + "團(tuán) 體 開(kāi) 單         -");
 if(initTeam()) { //傳賓客類(lèi)型數(shù)據(jù)給團(tuán)體開(kāi)單窗口
 tm.show(); //團(tuán)體開(kāi)單
 initLeftData(); //刷新左房間信息欄數(shù)據(jù)
 }//Endif
 }else if(o == bt3 || o == mi36) {//=====================================
 lbB.setText(face + "關(guān) 于 我 們         -");
 ab.show(); //關(guān)于我們
 }else if(o == bt4 || o == mi21) {//=====================================
 lbB.setText(face + "賓 客 結(jié) 帳         -");
 if(initCKO()) { //傳數(shù)據(jù)給結(jié)算窗口
 co.show(); //賓客結(jié)帳
 initLeftData(); //刷新左房間信息欄數(shù)據(jù)
 }//Endif
 }else if(o == bt5 || o == mi17) {//=====================================
 lbB.setText(face + "客 房 預(yù) 訂         -");
 eg.show(); //客房預(yù)訂
 initLeftData(); //刷新左房間信息欄數(shù)據(jù)
 }else if(o == bt6) {//==================================================
 lbB.setText(face + "營(yíng) 業(yè) 查 詢(xún)         -");
 qr.show(); //營(yíng)業(yè)查詢(xún)
 }else if(o == bt7) {//==================================================
 if(puil.equals("普通操作員")) { //客戶(hù)管理
 String msg = "對(duì)不起,您的權(quán)限不能進(jìn)入 [ 客戶(hù)管理 ] 頁(yè)面,請(qǐng)用管理員ID登錄 ...";
 JOptionPane.showMessageDialog(null, msg, "提示", JOptionPane.INFORMATION_MESSAGE);
 return;
 }
 lbB.setText(face + "客 戶(hù) 管 理         -");
 ct.show();
 }else if(o == bt8 || o == mi31) {//=====================================
 if(puil.equals("普通操作員")) { //網(wǎng)絡(luò)設(shè)置
 String msg = "對(duì)不起,您的權(quán)限不能進(jìn)入 [ 網(wǎng)絡(luò)設(shè)置 ] 頁(yè)面,請(qǐng)用管理員ID登錄 ...";
 JOptionPane.showMessageDialog(null, msg, "提示", JOptionPane.INFORMATION_MESSAGE);
 return;
 }
 lbB.setText(face + "網(wǎng) 絡(luò) 設(shè) 置         -");
 ns.show();
 }else if(o == bt9 || o == mi32) {//=====================================
 if(puil.equals("普通操作員")) { //系統(tǒng)設(shè)置
 String msg = "對(duì)不起,您的權(quán)限不能進(jìn)入 [ 網(wǎng)絡(luò)設(shè)置 ] 頁(yè)面,請(qǐng)用管理員ID登錄 ...";
 JOptionPane.showMessageDialog(null, msg, "提示", JOptionPane.INFORMATION_MESSAGE);
 return;
 }
 lbB.setText(face + "系 統(tǒng) 設(shè) 置         -");
 st.buildDTM12(""); //刷新房間信息表的房間狀態(tài)
 st.show();
 initLeftData(); //刷新左房間信息欄數(shù)據(jù)
 }else if(o == btA || o == mi19) {//=====================================
 quit (); //退出系統(tǒng)
 }else if(o == mi13) {//=================================================
 lbB.setText(face + "賓 客 續(xù) 住         -");
 go.show(); //賓客續(xù)住
 }else if(o == mi14) {//=================================================
 lbB.setText(face + "更 換 房 間         -");
 cg.show(); //更換房間
 }else if(o == mi15) {//=================================================
 lbB.setText(face + "修 改 登 記         -");
 idv.show(); //修改登記-------還要修改
 }else if(o == mi16) {//=================================================
 //房間狀態(tài)
 }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 + "系 統(tǒng) 日 志         -");
 rc.initDTM(); //刷新日志列表
 rc.show(); //系統(tǒng)日志
 }else if(o == mi34) {//=================================================
 //數(shù)據(jù)備份
 }else if(o == mi35) {//=================================================
 //軟件幫助
 }
 lbB.setText(face + "陽(yáng) 光 酒 店 管 理 系 統(tǒng) - ★★ 版 ");
 }
 
 
 /**=======================================================================**
 * MouseListener 監(jiān)聽(tīng)
 **=======================================================================**
 */
 public void mouseClicked (MouseEvent me) {
 }
 
 public void mousePressed (MouseEvent me) {
 }
 
 public void mouseReleased(MouseEvent me) {
 }
 
 public void mouseEntered (MouseEvent me) { //鼠標(biāo)移進(jìn)提示
 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 + "請(qǐng)選擇功能項(xiàng) ...                     ");
 }
 
 
 /**=======================================================================**
 * [## public void run() {} ]: 
 * 參數(shù) :無(wú)
 * 返回值 :無(wú)
 * 修飾符 :public
 * 功能 :結(jié)算后檢查房間狀態(tài)線程
 **=======================================================================**
 */
 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;
 //注冊(cè)驅(qū)動(dòng)
 DriverManager.registerDriver (new com.microsoft.jdbc.sqlserver.SQLServerDriver());
 //獲得一個(gè)連接
 conn1 = DriverManager.getConnection (url1, user1, pwd1);
 }
 else {
 //注冊(cè)驅(qū)動(dòng) //JDBCODBC連接方式
 DriverManager.registerDriver (new sun.jdbc.odbc.JdbcOdbcDriver());
 //獲得一個(gè)連接
 conn1 = DriverManager.getConnection ("jdbc:odbc:" + sunini.getIniKey("LinkName"));
 }
 
 //建立高級(jí)載體
 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, "數(shù)據(jù)庫(kù)連接失敗...", "錯(cuò)誤", 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.系統(tǒng)設(shè)置:

/**
 *##############################################################################
 *
 * [ 項(xiàng)目名 ] : 陽(yáng)光酒店管理系統(tǒng)
 * [ 公司名 ] : 清華IT
 * [ 模塊名 ] : 系統(tǒng)設(shè)置模塊
 * [ 文件名 ] : Setup.java
 * [ 相關(guān)文件 ] : 
 * [ 文件實(shí)現(xiàn)功能] : 組織系統(tǒng)設(shè)置窗口
 * [ 作者 ] : 董豐
 * [ 版本 ] : 1.1
 * ----------------------------------------------------------------------------
 * [ 備注 ] : 
 * ----------------------------------------------------------------------------
 * [ 修改記錄 ] : 
 *
 * [ 日 期 ] [版本] [修改人] [修改內(nèi)容] 
 * 2006/04/19 1.0 董豐 創(chuàng)建
 * 2006/04/22 1.1 顧俊 實(shí)現(xiàn)數(shù)據(jù)保存
 * ##--------------------------------------------------------------------------
 * 版權(quán)所有(c) 2006-2007, SunshineSOFT Corporation
 * --------------------------------------------------------------------------##
 * 
 * [ 函數(shù)說(shuō)明 ] : 看類(lèi)內(nèi)各函數(shù)開(kāi)頭
 * 
 * [ 遺留問(wèn)題 ] : 
 *
 *##############################################################################
 */
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.*; //公共類(lèi)庫(kù)
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;
 //=========房間項(xiàng)目設(shè)置
 private JTable tb11, tb12;
 private DefaultTableModel dtm11, dtm12; //房間類(lèi)型列表//房間信息列表
 
 private JScrollPane sp11,sp12;
 private JComboBox cb11,cb12;
 //房間類(lèi)型,可供/清理狀態(tài)
 private JButton bt11, bt12, bt13, bt14, bt15, bt16, bt17, bt18, bt19, bt20;
 //添加, 修改,刪除LX,折扣,單個(gè),批量添加,刪除,修改FJ,保存,篩選
 private JTextField tf11;
 //=========客戶(hù)類(lèi)型設(shè)置
 private JTable tb21,tb22;
 private DefaultTableModel dtm21,dtm22;
 //客戶(hù)類(lèi)型列表,房間費(fèi)打折列表
 private JScrollPane sp21,sp22;
 private JButton bt21, bt22, bt23, bt24;
 //添加, 修改,刪除LX,房費(fèi)打折
 //=========操作員設(shè)置
 private JTable tb31;
 private DefaultTableModel dtm31;
 //操作員列表
 private JScrollPane sp31;
 private JComboBox cb31;//用戶(hù)名
 private JPasswordField tf31, tf32, tf33;
 //原密碼,新密碼,確認(rèn)密碼
 private JRadioButton rb31, rb32, rb33, rb34, rb35;
 //新用戶(hù)登記, 修改密碼,刪除用戶(hù),普通用戶(hù),管理員
 private JButton bt31, bt32, bt33;
 // 登記, 修改, 刪除
 //=========計(jì)費(fèi)設(shè)置
 private JTextField tf41, tf42, tf43, tf44, tf45, tf46, tf47; 
 private JCheckBox ck;
 private JButton bt41, bt42;
 
 //提示信息
 String msg0 = "您確定要?jiǎng)h除在表格中選中的資料條目嗎?";
 String msg1 = "請(qǐng)?jiān)谙鄳?yīng)的表格中選定條目,再點(diǎn)刪除鍵 ...";
 //日志信息
 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" };
 
 //實(shí)例化功能模塊
 //========================================================================//
 AddRoomType art = new AddRoomType (this); //添加房間類(lèi)型
 ModiRoomType mrt = new ModiRoomType(this); //添加房間類(lèi)型
 AddCustomerType act = new AddCustomerType(this); //添加客戶(hù)類(lèi)型
 ModiCustomerType mct = new ModiCustomerType(this); //添加客戶(hù)類(lèi)型
 Discount dis = new Discount(this); //折扣設(shè)置
 AddRoomInfo ari = new AddRoomInfo(this); //單個(gè)添加房間
 AddRoomInfos aris = new AddRoomInfos(this); //批量添加房間
 ModiRoomInfo mri = new ModiRoomInfo(this); //修改房間信息
 //========================================================================//
 
 /**=======================================================================**
 * [## public Setup(JFrame frame) {} ]: 構(gòu)造函數(shù)
 * 參數(shù) :JDialog對(duì)象表示本對(duì)話(huà)框的父窗口
 * 返回值 :無(wú)
 * 修飾符 :public
 * 功能 :組建系統(tǒng)設(shè)置模塊
 **=======================================================================**
 */
 public Setup(JFrame frame) {
 super (frame, "系統(tǒng)設(shè)置", true);
 top = new JLabel(); //假空格
 panelMain = new JPanel(new BorderLayout(0,10));
 tab(); //制作系統(tǒng)設(shè)置項(xiàng)目標(biāo)簽面板
 addListener(); //加入事件監(jiān)聽(tīng)
 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() {} ]: 加事件監(jiān)聽(tīng)
 * 參數(shù) :無(wú)
 * 返回值 :無(wú)
 * 修飾符 :private
 * 功能 :加事件監(jiān)聽(tīng)
 **=======================================================================**
 */
 private void addListener() {
 bt11.addActionListener(this); //加動(dòng)作監(jiān)聽(tīng)
 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); //操作員作操范圍監(jiān)聽(tīng)
 rb32.addActionListener(this);
 rb33.addActionListener(this);
 tf41.addActionListener(this); //計(jì)費(fèi)設(shè)置文本框加監(jiān)聽(tīng)
 tf42.addActionListener(this);
 tf43.addActionListener(this);
 tf44.addActionListener(this);
 tf45.addActionListener(this);
 tf46.addActionListener(this);
 bt11.addMouseListener(this); //加鼠標(biāo)監(jiān)聽(tīng)
 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() {} ]: 制作系統(tǒng)設(shè)置項(xiàng)目標(biāo)簽面板
 * 參數(shù) :無(wú)
 * 返回值 :無(wú)
 * 修飾符 :private
 * 功能 :制作系統(tǒng)設(shè)置項(xiàng)目標(biāo)簽面板
 **=======================================================================**
 */
 private void tab() {
 JPanel jp1,jp2,jp3,jp4;
 ///////////////////////////////////////////////-------模塊面板接口
 jp1 = fangjian(); //房間項(xiàng)目設(shè)置
 jp2 = kehu(); //客戶(hù)類(lèi)型設(shè)置
 jp3 = caozuo(); //操作員設(shè)置
 jp4 = jiFei(); //計(jì)費(fèi)設(shè)置
 //////////////////////////////////////////////////////////////////
 tp = new JTabbedPane();
 tp.addTab("房間項(xiàng)目設(shè)置", new ImageIcon("pic/u01.gif"), jp1);
 tp.addTab("客戶(hù)類(lèi)型設(shè)置", new ImageIcon("pic/u02.gif"), jp2);
 tp.addTab("操作員設(shè)置", new ImageIcon("pic/u03.gif"), jp3);
 tp.addTab("計(jì)費(fèi)設(shè)置", new ImageIcon("pic/u04.gif"), jp4);
 }
 
 /**=======================================================================**
 * [## private JPanel fangjian() {} ]: 
 * 參數(shù) :無(wú)
 * 返回值 :JPanel
 * 修飾符 :private
 * 功能 :房間項(xiàng)目設(shè)置
 **=======================================================================**
 */
 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()); //放置房間類(lèi)型列表及四個(gè)按鈕
 pBn = new JPanel(new FlowLayout(FlowLayout.LEFT,10,0));//放置下拉列表
 pBc = new JPanel(new BorderLayout()); //放置房間信息列表及四個(gè)按鈕
 pTcc = new JPanel(new GridLayout(1,1));//放置房間類(lèi)型列表
 pTcs = new JPanel(new FlowLayout(FlowLayout.CENTER,20,5));//放置四個(gè)按鈕
 pBcc = new JPanel(new GridLayout(1,1));//放置房間信息列表
 pBcs = new JPanel(new FlowLayout(FlowLayout.CENTER,20,5));//放置四個(gè)按鈕
 
 //保存按鈕等 ...
 JLabel lb1,lb2,lb3;
 lb1 = new JLabel("結(jié)帳后房間狀態(tài)變?yōu)? ");
 lb2 = new JLabel(" 結(jié)帳后");
 lb3 = new JLabel("分鐘后變?yōu)榭晒顟B(tài) ");
 tf11 = new TJTextField(sunini.getIniKey(ini[17]),5); //根據(jù)INI文件給初值
 tf11.setHorizontalAlignment(JTextField.RIGHT);
 cb12 = new JComboBox();
 cb12.addItem(" 可供狀態(tài) ");
 cb12.addItem(" 清理狀態(tài) "); //根據(jù)INI文件給初值
 cb12.setSelectedIndex(Integer.parseInt(sunini.getIniKey(ini[16])));
 bt19 = new TJButton ("pic/save.gif", " 保 存 ", "保存設(shè)置");
 pTn.add(lb1);
 pTn.add(cb12);
 pTn.add(lb2);
 pTn.add(tf11);
 pTn.add(lb3);
 pTn.add(bt19);
 pTn.setBorder(BorderFactory.createTitledBorder(""));
 
 //房間類(lèi)型列表及四個(gè)按鈕
 bt11 = new TJButton ("pic/new.gif", "添加類(lèi)型", "添加房間類(lèi)型");
 bt12 = new TJButton ("pic/modi0.gif", "修改類(lèi)型", "修改房間類(lèi)型");
 bt13 = new TJButton ("pic/del.gif", "刪除類(lèi)型", "刪除房間類(lèi)型");
 bt14 = new TJButton ("pic/modi3.gif", "房費(fèi)打折", "設(shè)置房間費(fèi)折扣");
 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("房間類(lèi)型"));
 
 //完成上半部分
 pTop.add("North",pTn);
 pTop.add(pTc);
 
 
 //下拉列表
 JLabel lb0 = new JLabel("按包廂類(lèi)型過(guò)濾: ");
 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(); //初始化房間類(lèi)型列表和下拉列表的值
 buildDTM12(""); //初始化房間號(hào)列表
 
 
 //房間信息列表及四個(gè)按鈕
 bt15 = new TJButton ("pic/new.gif", "單個(gè)添加", "添加單個(gè)房間信息");
 bt16 = new TJButton ("pic/book.gif", "批量添加", "批量添加房間信息");
 bt17 = new TJButton ("pic/del.gif", "刪除房間", "刪除某個(gè)房間信息");
 bt18 = new TJButton ("pic/modi0.gif", "修改房間", "修改某個(gè)房間信息");
 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() {} ]: 
 * 參數(shù) :無(wú)
 * 返回值 :無(wú)
 * 修飾符 :private
 * 功能 :房間類(lèi)型列表和ComboBox
 **=======================================================================**
 */
 private void buildDTM11() {
 String sqlCode2 = "select pk,sysmark,id,foregift,r_type 房間類(lèi)型," +
 "price 預(yù)設(shè)單價(jià),cl_price " + "'鐘點(diǎn)價(jià)格/小時(shí)'" + ",bed 床位數(shù)量,cl_room "+
 "'能否按鐘點(diǎn)計(jì)費(fèi)(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); //設(shè)置顯示全部
 }
 
 /**=======================================================================**
 * [## private void buildDTM12(String rType) {} ]: 
 * 參數(shù) :String rType為刷新參數(shù)
 * 返回值 :無(wú)
 * 修飾符 :private
 * 功能 :房間信息表
 **=======================================================================**
 */
 public void buildDTM12(String rType) {
 String sqlCode = "select a.pk,a.r_type_id,a.id 房間號(hào),b.r_type 房間類(lèi)型," +
 "a.state 房間狀態(tài),a.location 所在區(qū)域,a.r_tel 房間電話(huà) 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() {} ]: 
 * 參數(shù) :無(wú)
 * 返回值 :無(wú)
 * 修飾符 :private
 * 功能 :客戶(hù)類(lèi)型設(shè)置
 **=======================================================================**
 */
 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());//客戶(hù)類(lèi)型面板
 p2 = new JPanel(new BorderLayout());//房間費(fèi)打折面板
 p1b = new JPanel(new FlowLayout(FlowLayout.CENTER,30,5));//客戶(hù)類(lèi)型按鈕面板
 p2b = new JPanel(); //房間費(fèi)打折按鈕面板
 
 buildDTM21(); //初始化客戶(hù)類(lèi)型表
 bt21 = new TJButton ("pic/new.gif", "添加類(lèi)型", "添加客戶(hù)類(lèi)型");
 bt22 = new TJButton ("pic/modi0.gif", "修改類(lèi)型", "修改客戶(hù)類(lèi)型");
 bt23 = new TJButton ("pic/del.gif", "刪除類(lèi)型", "刪除客戶(hù)類(lèi)型");
 p1b.add(bt21);
 p1b.add(bt22);
 p1b.add(bt23);
 p1.add(sp21);
 p1.add("South",p1b);
 p1.setBorder ( BorderFactory.createTitledBorder ("客戶(hù)類(lèi)型") );
 
 buildDTM22(); //初始化房間打折表
 bt24 = new TJButton ("pic/modi3.gif", " 房間費(fèi)打折 ", "設(shè)置房間費(fèi)折扣");
 p2b.add(bt24);
 p2.add(sp22);
 p2.add("South",p2b);
 p2.setBorder ( BorderFactory.createTitledBorder ("房間費(fèi)打折") );
 
 pkehu = new JPanel(new GridLayout(2,1,0,10));
 pkehu.add(p1);
 pkehu.add(p2);
 
 return pkehu;
 }
 
 /**=======================================================================**
 * [## private JPanel caozuo() {} ]: 
 * 參數(shù) :無(wú)
 * 返回值 :JPanel
 * 修飾符 :private
 * 功能 :操作員設(shè)置
 **=======================================================================**
 */
 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));//詳細(xì)信息,操作范圍,操作權(quán)限面板
 panelBott2 = new JPanel(new FlowLayout (FlowLayout.CENTER,20,5));//按鈕面板
 
 bt31 = new TJButton ("pic/new.gif", " 登 記 ", "保存當(dāng)前用戶(hù)信息", false);
 bt32 = new TJButton ("pic/key.gif", " 修 改 ", "修改密碼", false);
 bt33 = new TJButton ("pic/del.gif", " 刪 除 ", "刪除當(dāng)前用戶(hù)", 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面板
 * 參數(shù) :無(wú)
 * 返回值 :JPanel表示組織好的面板
 * 修飾符 :private
 * 功能 :組建對(duì)話(huà)框的用戶(hù)名和密碼面板
 **=======================================================================**
 */
 private JPanel bottLeft () {
 JLabel lb1, lb2, lb3, lb4;
 JPanel tl, jp1, jp2;
 
 lb1 = new JLabel ("用 戶(hù) 名: ");
 lb2 = new JLabel ("原 密 碼: ");
 lb3 = new JLabel ("新 密 碼: ");
 lb4 = new JLabel ("確認(rèn)密碼: ");
 
 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));
 
 //初始化用戶(hù)名下拉框
 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 (" 詳細(xì)信息 "));
 return tl;
 }
 
 /**=======================================================================**
 * [## private JPanel topRight () {} ]: 制作Top_Right面板
 * 參數(shù) :無(wú)
 * 返回值 :JPanel表示組織好的面板
 * 修飾符 :private
 * 功能 :組建對(duì)話(huà)框操作面板
 **=======================================================================**
 */
 private JPanel bottRight () {
 JPanel tr, jp1, jp2;
 ButtonGroup bg1,bg2;
 
 rb31 = new JRadioButton ("新用戶(hù)登記", true);
 rb32 = new JRadioButton ("修改密碼");
 rb33 = new JRadioButton ("刪除用戶(hù)");
 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);
 
 //加單選組 操作權(quán)限
 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 (" 操作權(quán)限 "));
 
 tr.add (jp1);
 tr.add (jp2);
 
 return tr;
 }
 
 /**=======================================================================**
 * [## private void buildDTM21() {} ]: 
 * 參數(shù) :無(wú)
 * 返回值 :無(wú)
 * 修飾符 :private
 * 功能 :初始化客戶(hù)類(lèi)型列表
 **=======================================================================**
 */
 private void buildDTM21() {
 String sqlCode = "select pk,id 客戶(hù)類(lèi)型編號(hào),id,c_type 客戶(hù)類(lèi)型,discount " +
 "打折比率 from customertype where delmark = 0 and dis_attr = '購(gòu)物折扣' and id!='SYSMARK'";
 sunsql.initDTM(dtm21,sqlCode);
 tb21.removeColumn(tb21.getColumn("pk"));
 tb21.removeColumn(tb21.getColumn("id"));
 }
 
 /**=======================================================================**
 * [## private void buildDTM22() {} ]: 
 * 參數(shù) :無(wú)
 * 返回值 :無(wú)
 * 修飾符 :private
 * 功能 :初始化房間打折費(fèi)列表
 **=======================================================================**
 */
 private void buildDTM22() {
 String sqlCode = "select pk,sysmark,id,foregift,r_type 房間類(lèi)型,price 預(yù)設(shè)單價(jià) 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() {} ]: 
 * 參數(shù) :無(wú)
 * 返回值 :無(wú)
 * 修飾符 :private
 * 功能 :初始化操作員列表
 **=======================================================================**
 */
 private void buildDTM31() {
 String sqlCode = "select pk,userid 用戶(hù)登錄ID,puis 用戶(hù)權(quán)限 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() {} ]: 
 * 參數(shù) :無(wú)
 * 返回值 :JPanel
 * 修飾符 :private
 * 功能 :計(jì)費(fèi)設(shè)置
 **=======================================================================**
 */
 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;
 //定義標(biāo)簽
 lb1 = new JLabel("  客人開(kāi)房時(shí)間在");
 lb2 = new JLabel("點(diǎn)之后按新的一天開(kāi)始計(jì)費(fèi)");
 lb3 = new JLabel("  客人退房時(shí)間在");
 lb4 = new JLabel("點(diǎn)之后計(jì)價(jià)天數(shù)自動(dòng)追加半天");
 lb5 = new JLabel("  客人退房時(shí)間在");
 lb6 = new JLabel("點(diǎn)之后計(jì)價(jià)天數(shù)自動(dòng)追加一天");
 lb7 = new JLabel("  開(kāi)房后");
 lb8 = new JLabel("分鐘開(kāi)始計(jì)費(fèi)");
 lb9 = new JLabel("  最少按");
 lb10 = new JLabel("小時(shí)計(jì)費(fèi),小于這個(gè)時(shí)間的按此時(shí)間計(jì)費(fèi)");
 lb11 = new JLabel("  若不足一小時(shí)但超過(guò)");
 lb12 = new JLabel("分鐘的部分按1小時(shí)計(jì)費(fèi)");
 lb13 = new JLabel("  不足上面分鐘數(shù)但超過(guò)");
 lb14 = new JLabel("分鐘的部分按半小時(shí)計(jì)費(fèi)");
 lb15 = new JLabel("注:此設(shè)置僅限于標(biāo)準(zhǔn)計(jì)費(fèi)的鐘點(diǎn)房!    ");
 lb16 = new JLabel("  ");
 lb15.setForeground(new Color(255, 138, 0));
 //初始化計(jì)時(shí)計(jì)費(fèi)設(shè)置
 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);
 //設(shè)置文本框右對(duì)齊
 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);
 //不足一天是否按一天計(jì)價(jià)
 ck = new JCheckBox("入住時(shí)間不足一天的按一天計(jì)費(fèi)");
 if(sunini.getIniKey("InsuDay").equals("1")) {
 ck.setSelected(true);
 }
 bt41 = new TJButton ("pic/save.gif", " 保 存 ", "保存當(dāng)前設(shè)置");
 bt42 = new TJButton ("pic/exit.gif", " 返 回 ", "返回主窗口");
 
 panelJF = new JPanel(new BorderLayout()); //計(jì)費(fèi)主面板
 jfTop = new JPanel(new GridLayout(2, 1)); //放左右面板
 jfLeft = new JPanel(new GridLayout(4, 1)); //計(jì)費(fèi)左面板
 jfRight = new JPanel(new GridLayout(5, 1)); //計(jì)費(fèi)右面板
 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);
 
 //組織兩個(gè)表到一起
 jfTop.add(jfLeft);
 jfTop.add(jfRight);
 
 //組織按鍵面板
 jfBott.add(bt41);
 jfBott.add(bt42);
 
 //加入主面板
 panelJF.add("Center", jfTop);
 panelJF.add("South", jfBott);
 
 jfLeft.setBorder(BorderFactory.createTitledBorder("普通房間標(biāo)準(zhǔn)計(jì)費(fèi)"));
 jfRight.setBorder ( BorderFactory.createTitledBorder ("鐘點(diǎn)房標(biāo)準(zhǔn)計(jì)費(fèi)") );
 return panelJF;
 }
 
 /**=======================================================================**
 * [## private boolean initMrt() {} ]: 
 * 參數(shù) :無(wú)
 * 返回值 :boolean
 * 修飾符 :private
 * 功能 :傳數(shù)據(jù)給修改房間類(lèi)型窗口
 **=======================================================================**
 */
 private boolean initMrt() {
 int row = tb11.getSelectedRow();
 if(row == -1) {
 JOptionPane.showMessageDialog(null, "請(qǐng)?jiān)谏厦骖?lèi)型表中指定房間類(lèi)型," +
 "才能執(zhí)行修改操作", "提示", JOptionPane.INFORMATION_MESSAGE);
 return false;
 }
 ModiRoomType.tf0.setText(dtm11.getValueAt(row,2) + ""); //類(lèi)型編號(hào)
 ModiRoomType.tf1.setText(dtm11.getValueAt(row,4) + ""); //類(lèi)型名稱(chēng)
 ModiRoomType.tf2.setText(dtm11.getValueAt(row,7) + ""); //床位數(shù)量
 ModiRoomType.tf3.setText(dtm11.getValueAt(row,5) + ""); //預(yù)設(shè)單價(jià)
 ModiRoomType.tf4.setText(dtm11.getValueAt(row,3) + ""); //預(yù)設(shè)押金
 ModiRoomType.tf5.setText(dtm11.getValueAt(row,6) + ""); //鐘點(diǎn)計(jì)費(fèi)
 String cl_room = dtm11.getValueAt(row, 8) + "";
 if(cl_room.equals("Y")) {
 ModiRoomType.chk.setSelected(true); //允許提供鐘點(diǎn)服務(wù)
 }
 else {
 ModiRoomType.chk.setSelected(false); //不允許提供鐘點(diǎn)服務(wù)
 ModiRoomType.tf5.setEnabled(false); //設(shè)置鐘點(diǎn)計(jì)費(fèi)不可用
 }
 return true;
 }
 
 /**=======================================================================**
 * [## private boolean initMri() {} ]: 
 * 參數(shù) :無(wú)
 * 返回值 :boolean
 * 修飾符 :private
 * 功能 :傳數(shù)據(jù)給修改房間信息窗口
 **=======================================================================**
 */
 private boolean initMri() {
 int row = tb12.getSelectedRow();
 if(row == -1) {
 JOptionPane.showMessageDialog(null, "請(qǐng)?jiān)谏厦娣块g信息表中指定房間號(hào)," +
 "才能執(zhí)行修改操作", "提示", JOptionPane.INFORMATION_MESSAGE);
 return false;
 }
 ModiRoomInfo.tf1.setText(dtm12.getValueAt(row, 2) + ""); //房間編號(hào)
 ModiRoomInfo.tf2.setText(dtm12.getValueAt(row, 5) + ""); //所在區(qū)域
 ModiRoomInfo.tf3.setText(dtm12.getValueAt(row, 6) + ""); //房間電話(huà)
 ModiRoomInfo.pk = dtm12.getValueAt(row, 0) + ""; //獲得當(dāng)前行的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)); //房間類(lèi)型
 }
 catch (Exception ex) {
 System.out.println ("ModiRoomInfo.initMri(): Modi false");
 }//End try
 return true;
 }
 
 /**=======================================================================**
 * [## private boolean initMct() {} ]: 
 * 參數(shù) :無(wú)
 * 返回值 :boolean
 * 修飾符 :private
 * 功能 :傳數(shù)據(jù)給修改客戶(hù)類(lèi)型窗口
 **=======================================================================**
 */
 private boolean initMct() {
 int row = tb21.getSelectedRow();
 if(row == -1) {
 JOptionPane.showMessageDialog(null, "請(qǐng)?jiān)谏厦骖?lèi)型表中指定客戶(hù)類(lèi)型," +
 "才能執(zhí)行修改操作", "提示", JOptionPane.INFORMATION_MESSAGE);
 return false;
 }
 ModiCustomerType.tf1.setText(dtm21.getValueAt(row,1) + ""); //客戶(hù)類(lèi)型編號(hào)
 ModiCustomerType.tf2.setText(dtm21.getValueAt(row,3) + ""); //客戶(hù)類(lèi)型名稱(chēng)
 ModiCustomerType.tf3.setText(dtm21.getValueAt(row,4) + ""); //客戶(hù)類(lèi)型折扣
 ModiCustomerType.pk = dtm21.getValueAt(row, 0) + ""; //獲得當(dāng)前行的PK
 return true;
 }
 
 /**=======================================================================**
 * [## private boolean initDis(JTable dtb, DefaultTableModel ddtm) {} ]: 
 * 參數(shù) :JTable 與 DefaultTableModel 為項(xiàng)目與折扣中的表
 * 返回值 :boolean
 * 修飾符 :private
 * 功能 :傳數(shù)據(jù)給打折設(shè)置窗口
 **=======================================================================**
 */
 private boolean initDis(JTable dtb, DefaultTableModel ddtm) {
 int row = dtb.getSelectedRow();
 if(row == -1) {
 JOptionPane.showMessageDialog(null, "請(qǐng)?jiān)谙鄳?yīng)列表中指定房間類(lèi)型," +
 "才能進(jìn)行打折設(shè)置操作", "提示", JOptionPane.INFORMATION_MESSAGE);
 return false;
 }
 try {
 Discount.rt = ddtm.getValueAt(row, 2) + ""; //獲得房間編號(hào)
 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); //普通賓客不打折選項(xiàng)
 Discount.tf1.setEnabled(false);
 }else {
 Discount.cb1.setSelectedIndex(0); //普通賓客打折選項(xiàng)
 Discount.tf1.setEnabled(true);
 }//Endif
 Discount.tf1.setText(temp + ""); //普通賓客的折扣
 }
 catch (Exception ex) {
 }
 Discount.lb1.setText(ddtm.getValueAt(row, 4) + ""); //房間類(lèi)型名稱(chēng)
 Discount.lb2.setText(ddtm.getValueAt(row, 5) + ""); //房間價(jià)格
 //初始化表格的DTM
 sunsql.initDTM(Discount.dtm, "select c_type 客戶(hù)等級(jí),discount 享受折扣, " +
 "dis_price 折扣價(jià)格 from customertype where delmark=0 and dis_attr='" + 
 ddtm.getValueAt(row, 2) + "' and id!='SYSMARK'");
 //初始化會(huì)員等級(jí)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) {} ]: 
 * 參數(shù) :Sring tName 表示要執(zhí)行刪除的表名
 * DTM delDtm 表示相關(guān)聯(lián)的DTM
 * int dr[] 要被執(zhí)行刪除的行數(shù)
 * String m 提示信息
 * 返回值 :boolean
 * 修飾符 :private
 * 功能 :房間類(lèi)型、房間信息和客戶(hù)類(lèi)型的刪操作
 **=======================================================================**
 */
 private boolean delInfo (String tName, DefaultTableModel delDtm, int dr[], String m) {
 int rowCount = dr.length;
 int r =0; //DTM行指針
 
 if(tName.equals ("roomtype")) { //如果刪除房間類(lèi)型,則刪除與房間類(lèi)型相關(guān)的房間信息與客戶(hù)折扣設(shè)置
 rowCount = rowCount * 3;
 }//Endif
 
 if(rowCount > 0) { //判斷選擇記錄數(shù)
 int isDel = JOptionPane.showConfirmDialog (null, m, "提示", JOptionPane.YES_NO_OPTION);
 if(isDel == JOptionPane.YES_OPTION) {
 String sqlCode[] = new String[rowCount];
 //生成SQL語(yǔ)句
 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")) { //如果刪除房間類(lèi)型,則同時(shí)刪除相關(guān)房間信息
 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
 //以事務(wù)模式執(zhí)行SQL語(yǔ)句組, 確保操作正確, 返回值為成功執(zhí)行SQL語(yǔ)句的條數(shù)
 isDel = sunsql.runTransaction(sqlCode); 
 if(isDel != rowCount) { //如果成功執(zhí)行的條數(shù) = 數(shù)組長(zhǎng)度,則表示更新成功
 String mm = "在執(zhí)行第 [ " + (isDel + 1) + " ] 條記錄的刪除操作時(shí)出錯(cuò),數(shù)據(jù)有可能被其它終端修改\n或者是網(wǎng)絡(luò)不通暢 ...";
 JOptionPane.showMessageDialog(null, mm, "錯(cuò)誤",JOptionPane.ERROR_MESSAGE);
 //更新失敗,返回false
 return false;
 }//Endif
 return true; //更新成功,返回true
 }//Endif
 }
 else //如果沒(méi)有選中記錄,則提示一下
 JOptionPane.showMessageDialog(null, msg1, "提示",JOptionPane.INFORMATION_MESSAGE);
 return false;
 }
 
 /**=======================================================================**
 * [## private void umAdd () {} ]: 添加操作
 * 參數(shù) :無(wú)
 * 返回值 :無(wú)
 * 修飾符 :private
 * 功能 :添加新的用戶(hù)ID
 **=======================================================================**
 */
 private void umAdd () {
 String pwd1 = String.valueOf(tf32.getPassword());
 String pwd2 = String.valueOf(tf33.getPassword());
 String pu = "普通操作員"; //用戶(hù)權(quán)限
 if(!pwd1.equals (pwd2)) { //兩次密碼不相等
 JOptionPane.showMessageDialog (null, "輸入錯(cuò)誤,[ 新密碼 ] 與 [ 確認(rèn)密碼 ] " +
 "不正確,請(qǐng)重新輸入 ...", "錯(cuò)誤",JOptionPane.ERROR_MESSAGE);
 return;
 }//Endif
 String umName = cb31.getEditor ().getItem () + "";//獲得用戶(hù)名
 try {
 ResultSet rs = sunsql.executeQuery ("select userid from pwd where delmark=0 " +
 "and userid='" + umName + "'");
 
 int isID = sunsql.recCount(rs);
 if(isID > 0){ //當(dāng)前要加入的用戶(hù)名是否存在
 JOptionPane.showMessageDialog (null, "管理員ID [ " + umName + " ] 已存在," +
 "請(qǐng)重新輸入 ...", "錯(cuò)誤",JOptionPane.ERROR_MESSAGE);
 return;
 }//Endif
 if(rb35.isSelected()) //獲得是否是管理員權(quán)限
 pu = "管理員";
 long pk = sunsql.getPrimaryKey();//從服務(wù)獲得主鍵
 //記入數(shù)據(jù)庫(kù)
 isID = sunsql.executeUpdate("insert into pwd(pk,userid,pwd,puis) values(" + pk + 
 ",'" + umName + "','" + pwd1 + "','" + pu + "')");
 
 if(isID == 0) {
 JOptionPane.showMessageDialog (null, "添加操作失敗,請(qǐng)檢查網(wǎng)絡(luò)連接是否正常 " +
 "...", "錯(cuò)誤",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) {} ]: 更新刪除操作
 * 參數(shù) :int 變量表示操作類(lèi)型 0:表示修改密碼 1:表示刪除記錄
 * 返回值 :無(wú)
 * 修飾符 :private
 * 功能 :修改密碼和刪除用戶(hù)ID
 **=======================================================================**
 */
 private void umUpdate (int type) {
 String umName = cb31.getSelectedItem() + ""; //獲得用戶(hù)名
 String pwd0;
 String pwd1 = String.valueOf (tf32.getPassword ());
 String pwd2 = String.valueOf (tf33.getPassword ());
 
 int isID = 0; //用戶(hù)是否存在
 if(!pwd1.equals (pwd2)) { //兩次密碼不相等
 JOptionPane.showMessageDialog (null, "輸入錯(cuò)誤,[ 新密碼 ] 與 [ 確認(rèn)密碼 ] " +
 "不正確,請(qǐng)重新輸入 ...", "錯(cuò)誤",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 + " ] 的 [ 原" +
 "密碼 ] 不正確,請(qǐng)重新輸入 ...", "錯(cuò)誤",JOptionPane.ERROR_MESSAGE);
 
 return;
 }//Endif
 if(type == 0) { //執(zhí)行修改密碼操作
 isID = sunsql.executeUpdate("update pwd set pwd='" + pwd1 + "' where " +
 "delmark=0 and userid='" + umName + "'");
 }else { //執(zhí)行刪除操作
 isID = sunsql.executeUpdate("update pwd set delmark=1 where userid='" + umName + "'");
 }//Endif
 }
 catch (Exception ex) {
 }//End try
 if(isID == 0) { //判斷操作是否成功
 JOptionPane.showMessageDialog (null, "執(zhí)行操作失敗,請(qǐng)檢查網(wǎng)絡(luò)連接是否正常 ...", "錯(cuò)誤",JOptionPane.ERROR_MESSAGE);
 }
 tf31.setText(""); //清空密碼
 tf32.setText("");
 tf33.setText("");
 return;
 }
 
 //檢查計(jì)費(fèi)設(shè)置是否合法
 private boolean isValidity() {
 if(!suntools.isNum(tf41.getText(), 1, 6, 9)) {
 JOptionPane.showMessageDialog(null, "[ 計(jì)費(fèi)參數(shù) 1 ] 只能是數(shù)字,且范圍在 6-9 之間", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 tf41.requestFocus(true);
 return false;
 }else if(!suntools.isNum(tf42.getText(), 2, 11, 13)) {
 JOptionPane.showMessageDialog(null, "[ 計(jì)費(fèi)參數(shù) 2 ] 只能是數(shù)字,且范圍在 11-13 之間", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 tf42.requestFocus(true);
 return false;
 }else if(!suntools.isNum(tf43.getText(), 2, 17, 19)) {
 JOptionPane.showMessageDialog(null, "[ 計(jì)費(fèi)參數(shù) 3 ] 只能是數(shù)字,且范圍在 17-19 之間", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 tf43.requestFocus(true);
 return false;
 }else if(!suntools.isNum(tf44.getText(), 1, 0, 5)) {
 JOptionPane.showMessageDialog(null, "[ 鐘點(diǎn)計(jì)費(fèi)參數(shù) 1 ] 只能是數(shù)字,且范圍在 0-5 之間", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 tf44.requestFocus(true);
 return false;
 }else if(!suntools.isNum(tf45.getText(), 1, 1, 5)) {
 JOptionPane.showMessageDialog(null, "[ 鐘點(diǎn)計(jì)費(fèi)參數(shù) 2 ] 只能是數(shù)字,且范圍在 1-5 之間", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 tf45.requestFocus(true);
 return false;
 }else if(!suntools.isNum(tf46.getText(), 2, 20, 40)) {
 JOptionPane.showMessageDialog(null, "[ 鐘點(diǎn)計(jì)費(fèi)參數(shù) 3 ] 只能是數(shù)字,且范圍在 20-40 之間", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 tf46.requestFocus(true);
 return false;
 }else if(!suntools.isNum(tf47.getText(), 2, 5, 15)) {
 JOptionPane.showMessageDialog(null, "[ 鐘點(diǎn)計(jì)費(fèi)參數(shù) 4 ] 只能是數(shù)字,且范圍在 5-15 之間", 
 "提示", JOptionPane.INFORMATION_MESSAGE);
 tf47.requestFocus(true);
 return false;
 }//endif
 return true;
 }
 
 /**=======================================================================**
 * [## private boolean isState(int aRow[]) {} ]: 
 * 參數(shù) :int aRom[] 表示要執(zhí)行刪除操作的行號(hào)
 * 返回值 :boolean
 * 修飾符 :private
 * 功能 :檢查房間的狀態(tài)是否可以刪除
 **=======================================================================**
 */
 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) + 
 " ] 房間正處于占用狀態(tài),無(wú)法執(zhí)行刪除操作,系統(tǒng)取消了所有刪除操作", "提示", JOptionPane.INFORMATION_MESSAGE);
 return false;
 }else if(aState.equals("鐘點(diǎn)")) {
 JOptionPane.showMessageDialog(null, "[ " + dtm12.getValueAt(aRow[i], 2) + 
 " ] 房間正處于鐘點(diǎn)房狀態(tài),無(wú)法執(zhí)行刪除操作,系統(tǒng)取消了所有刪除操作", "提示", JOptionPane.INFORMATION_MESSAGE);
 return false;
 }else if(aState.equals("預(yù)訂")) {
 JOptionPane.showMessageDialog(null, "[ " + dtm12.getValueAt(aRow[i], 2) + 
 " ] 房間正處于預(yù)訂狀態(tài),無(wú)法執(zhí)行刪除操作,系統(tǒng)取消了所有刪除操作", "提示", JOptionPane.INFORMATION_MESSAGE);
 return false;
 }//Endif
 }//Endif
 }
 catch (Exception ex) {
 ex.printStackTrace();
 System.out.println ("Setup.isState(): false");
 }//End try
 return true;
 }
 
 /**=======================================================================**
 * ActionListener 監(jiān)聽(tīng)
 **=======================================================================**
 */
 public void actionPerformed(ActionEvent ae) {
 Object o = ae.getSource();
 if(o == bt11) {//=======================================================
 art.show(true); //添加房間類(lèi)型
 buildDTM11(); //刷新表數(shù)據(jù)
 buildDTM12(""); //刷新表數(shù)據(jù)
 buildDTM22(); //刷新表數(shù)據(jù)
 
 }else if(o == bt12) {//=================================================
 if(initMrt()) { //傳數(shù)據(jù)給窗口
 mrt.show(true); //修改房間類(lèi)型
 buildDTM11(); //刷新表數(shù)據(jù)
 buildDTM12(""); //刷新表數(shù)據(jù)
 buildDTM22(); //刷新表數(shù)據(jù)
 }//Endif
 
 }else if(o == bt13) {//=================================================
 int rRow[] = tb11.getSelectedRows(); //刪除房間類(lèi)型
 int sysmark;
 for (int i = 0; i < rRow.length; i++) {
 //獲得得記錄的屬性標(biāo)志,并轉(zhuǎn)成整型
 sysmark = Integer.parseInt(dtm11.getValueAt(rRow[i], 1) + "");
 if(sysmark == 1) {
 JOptionPane.showMessageDialog(null, "[ " + dtm11.getValueAt(rRow[i], 4) + 
 " ] 類(lèi)型為系統(tǒng)級(jí)設(shè)置,不允許被刪除,系統(tǒng)終止了刪除操作 ...", "提示",
 JOptionPane.INFORMATION_MESSAGE);
 return; //不執(zhí)行刪除返回窗口
 }//Endif
 }//Endfor
 String msg = "注意,刪除 [ 房間類(lèi)型 ] 操作會(huì)將與 [ 房間類(lèi)型 ] 相關(guān)" +
 "的所有 [ 房間信息 ] 一并刪除。\n您確定要?jiǎng)h除在表格中選中的類(lèi)型條目嗎?";
 
 if(delInfo ("roomtype", dtm11, rRow, msg)) { //執(zhí)行刪除操作
 buildDTM11(); //刷新類(lèi)型表數(shù)據(jù)
 buildDTM12(""); //刷新房間表數(shù)據(jù)
 buildDTM22(); //刷新類(lèi)型表數(shù)據(jù)
 journal = "執(zhí)行了刪除房間類(lèi)型的操作--刪除數(shù)量:" + rRow.length;
 Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_RT);//記錄操作日志
 }//Endif
 
 }else if(o == bt14) {//=================================================
 if(initDis(tb11, dtm11)) { //房間費(fèi)打折
 dis.show(true);
 }//Endif
 }else if(o == bt15) {//=================================================
 sunsql.initJComboBox(AddRoomInfo.cb1, "select r_type from roomtype where delmark = 0");
 ari.show(true); //單個(gè)添加房間信息
 buildDTM12(""); //刷新表數(shù)據(jù)
 
 }else if(o == bt16) {//=================================================
 sunsql.initJComboBox(AddRoomInfos.cb, "select r_type from roomtype where delmark = 0");
 aris.show(true); //批量添加房間信息
 buildDTM12(""); //刷新表數(shù)據(jù)
 
 }else if(o == bt18) {//=================================================
 sunsql.initJComboBox(ModiRoomInfo.cb1, "select r_type from roomtype where delmark = 0");
 if(initMri()) { //傳數(shù)據(jù)給窗口
 mri.show(true); //修改房間信息
 buildDTM12(""); //刷新表數(shù)據(jù)
 }//Endif
 
 }else if(o == bt17) {//=================================================
 int rRow[] = tb12.getSelectedRows(); //刪除房間信息
 if(isState(rRow)) { //判斷房間的狀態(tài)是否可以刪除
 if(delInfo ("roominfo", dtm12, rRow, msg0)) { //執(zhí)行刪除操作
 buildDTM12(""); //刷新房間表數(shù)據(jù)
 journal = "執(zhí)行了刪除房間信息的操作--刪除數(shù)量:" + rRow.length;
 Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_RI);//記錄操作日志
 }//Endif
 }
 }else if(o == bt19) {//=================================================
 if(!suntools.isNum(tf11.getText(),2 ,5 ,30)) { //保存退房后房間狀態(tài)
 JOptionPane.showMessageDialog(null, "結(jié)算后更改房間狀態(tài)的時(shí)間框只能為數(shù)字,且范圍在 5 - 30 之間",
 "提示", JOptionPane.INFORMATION_MESSAGE);
 tf11.requestFocus(true);
 return;
 }
 sunini.setIniKey(ini[16], cb12.getSelectedIndex() + ""); //將設(shè)置保存至緩沖區(qū)
 sunini.setIniKey(ini[17], tf11.getText()); 
 sunini.saveIni(ini); //將緩沖區(qū)的設(shè)置保存至INI文件
 
 }else if(o == bt20) {//=================================================
 int cbIndex = cb11.getSelectedIndex(); //篩選信息
 if(cbIndex == cb11.getItemCount() - 1) { //顯示全部房間
 buildDTM12(""); //刷新房間表數(shù)據(jù)
 }else {
 String rt = "and a.r_type_id = '" + dtm11.getValueAt(cbIndex, 2) + "'";
 buildDTM12(rt); //根據(jù)指定房間類(lèi)型刷新表數(shù)據(jù)
 }//Endif
 
 }else if(o == bt21) {//=================================================
 act.show(true); //添加客戶(hù)類(lèi)型
 buildDTM21();
 
 }else if(o == bt22) {//=================================================
 if(initMct()) { //傳數(shù)據(jù)給窗口
 mct.show(true); //修改客戶(hù)類(lèi)型
 buildDTM21(); //刷新表數(shù)據(jù)
 }//Endif
 
 }else if(o == bt23) {//=================================================
 int rRow[] = tb21.getSelectedRows(); //刪除客戶(hù)類(lèi)型
 if(delInfo ("customertype", dtm21, rRow, msg0)) { //執(zhí)行刪除操作
 buildDTM21(); //刷新房間表數(shù)據(jù)
 journal = "執(zhí)行了刪除客戶(hù)類(lèi)型的操作--刪除數(shù)量:" + rRow.length;
 Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_US);//記錄操作日志
 }//Endif
 
 }else if(o == bt24) {//=================================================
 if(initDis(tb22, dtm22)) { //房間費(fèi)打折
 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, " [ 確認(rèn)密碼 ] 不能為空", "提示", 
 JOptionPane.INFORMATION_MESSAGE);
 return;
 }//Endif
 umAdd (); //執(zhí)行添加操作
 buildDTM31(); //刷新表數(shù)據(jù)
 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, " [ 確認(rèn)密碼 ] 不能為空", "提示", 
 JOptionPane.INFORMATION_MESSAGE);
 return;
 }//Endif
 umUpdate (0); //執(zhí)行修改密碼操作
 journal = "修改了操作員 [ " + cb31.getEditor ().getItem () + " ] 的設(shè)置";
 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, " [ 確認(rèn)密碼 ] 不能為空", "提示", 
 JOptionPane.INFORMATION_MESSAGE);
 return;
 }//Endif
 int wi = JOptionPane.showConfirmDialog(null,"您確認(rèn)要?jiǎng)h除當(dāng)前的用戶(hù)ID嗎?", 
 "提示", JOptionPane.YES_NO_OPTION);
 
 if(wi == JOptionPane.YES_OPTION) {
 umUpdate (1); //執(zhí)行刪除用戶(hù)ID操作
 buildDTM31(); //刷新表數(shù)據(jù)
 journal = "刪除了操作員 [ " + cb31.getEditor ().getItem () + " ] 的設(shè)置";
 Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_CZ);//記錄操作日志
 }//Endif
 
 }else if(o == bt41) {//=================================================
 if(isValidity()) {
 int saveJf = JOptionPane.showConfirmDialog(null, "您 確 實(shí) 要 保 存 " +
 "當(dāng) 前 的 計(jì) 費(fèi) 設(shè) 置 嗎 ?","保存設(shè)置",JOptionPane.YES_NO_OPTION);
 if(saveJf == JOptionPane.YES_OPTION) { //保存計(jì)費(fèi)設(shè)置
 sunini.setIniKey("In_Room", tf41.getText()); //將設(shè)置保存至緩沖區(qū)
 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()) { //不足一天按一天收費(fèi)
 sunini.setIniKey("InsuDay","1");
 }else {
 sunini.setIniKey("InsuDay","0");
 }//Endif
 sunini.saveIni(ini); //將緩沖區(qū)的設(shè)置保存至INI文件
 journal = "修改了系統(tǒng)的計(jì)費(fèi)設(shè)置";
 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 監(jiān)聽(tīng)
 **=======================================================================**
 */
 public void mouseClicked (MouseEvent me) {
 }
 
 public void mousePressed (MouseEvent me) {
 }
 
 public void mouseReleased(MouseEvent me) {
 }
 
 public void mouseEntered (MouseEvent me) { //鼠標(biāo)移進(jìn)提示
 Object o = me.getSource ();
 if(o == bt11) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "添加新的房間類(lèi)型                    ");
 }else if(o == bt12) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "修改指定的房間類(lèi)型                   ");
 }else if(o == bt13) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "刪除指定的房間類(lèi)型                   ");
 }else if(o == bt14) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "設(shè)置指定房間類(lèi)型的消費(fèi)折扣               ");
 }else if(o == bt15) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "為指定的房間類(lèi)型添加新的客房              ");
 }else if(o == bt16) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "為指定的房間類(lèi)型一次添加多個(gè)新客房           ");
 }else if(o == bt17) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "修改指定客房信息設(shè)置                  ");
 }else if(o == bt18) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "刪除指定的客房                     ");
 }else if(o == bt19) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "保存房間退房后的狀態(tài)                  ");
 }else if(o == bt20) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "以左邊指定的類(lèi)型顯示房間信息              ");
 } if(o == bt21) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "添加新的客戶(hù)類(lèi)型                    ");
 }else if(o == bt22) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "修改指定的客戶(hù)資料                   ");
 }else if(o == bt23) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "刪除指定的客戶(hù)資料                   ");
 }else if(o == bt24) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "設(shè)置指定房間類(lèi)型的消費(fèi)折扣               ");
 }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 + 
 "保存當(dāng)前的計(jì)費(fèi)設(shè)置至INI配置文件             ");
 }else if(o == bt42) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "返回主窗口                       ");
 }
 }
 
 public void mouseExited (MouseEvent me) {
 HotelFrame.lbA.setText (HotelFrame.clue + 
 "請(qǐng)選擇功能項(xiàng) ...                     ");
 }
 
}

3.登錄窗口:

/**
 *##############################################################################
 *
 * [ 項(xiàng)目名 ] : 陽(yáng)光酒店管理系統(tǒng)
 * [ 公司名 ] : 清華IT
 * [ 模塊名 ] : 系統(tǒng)登陸窗口
 * [ 文件名 ] : Login.java
 * [ 相關(guān)文件 ] : 
 * [ 文件實(shí)現(xiàn)功能] : 系統(tǒng)登陸窗口
 * [ 作者 ] : 顧俊
 * [ 版本 ] : 1.1
 * ----------------------------------------------------------------------------
 * [ 備注 ] : 
 * ----------------------------------------------------------------------------
 * [ 修改記錄 ] : 
 *
 * [ 日 期 ] [版本] [修改人] [修改內(nèi)容] 
 * 2006/04/02 1.0 顧俊 創(chuàng)建
 * 2006/04/06 1.1 顧俊 增加注釋
 * 2006/04/19 1.2 顧俊 自動(dòng)記錄登錄日志
 * ##--------------------------------------------------------------------------
 * 版權(quán)所有(c) 2006-2007, SunshineSOFT Corporation
 * --------------------------------------------------------------------------##
 * 
 * [ 函數(shù)說(shuō)明 ] :
 *
 * [## public Login() {} ]:
 * 功能: 構(gòu)造函數(shù) 組建登錄窗口
 *
 * [## private void buildCenter() {} ]:
 * 功能: 組建用戶(hù)名密碼面板,僅類(lèi)內(nèi)使用
 *
 * [## private void quit() {} ]: 
 * 功能: 關(guān)閉系統(tǒng)函數(shù),僅類(lèi)內(nèi)使用
 *
 * [## private void dengLu() {} ]:
 * 功能: 密碼驗(yàn)證通過(guò),進(jìn)入主操作界面,僅類(lèi)內(nèi)使用
 *
 * [ 遺留問(wèn)題 ] : 
 *
 *##############################################################################
 */
//package com.sunshine.login;
 
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; //登記次數(shù)記數(shù)器
 
 /**=======================================================================**
 * [## public Login() {} ]: 構(gòu)造函數(shù)
 * 參數(shù) :無(wú)
 * 返回值 :無(wú)
 * 修飾符 :public
 * 功能 :組建登錄窗口
 **=======================================================================**
 */
 public Login() {
 super("系 統(tǒng) 登 錄");
 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);
 
 //加事件監(jiān)聽(tīng)
 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);
 
 //加窗口監(jiān)聽(tīng) new WindowAdapter適配器類(lèi)
 this.addWindowListener(new WindowAdapter() {
 public void windowClosing(WindowEvent we) {
 quit();
 }//End windowClosing
 });
 
 this.setContentPane(panelMain); //設(shè)置窗口面板
 this.setSize(350, 235);
 this.setResizable (false); //設(shè)置窗口不可放大縮小
 this.setDefaultCloseOperation(JFrame.DO_NOTHING_ON_CLOSE);
 sunswing.setWindowCenter(this);
 this.setVisible(true);
 pf.requestFocus(true); //設(shè)置焦點(diǎn)給密碼框
 }
 
 /**=======================================================================**
 * [## private void buildCenter() {} ]: 制作用戶(hù)名密碼面板
 * 參數(shù) :無(wú)
 * 返回值 :無(wú)
 * 修飾符 :private
 * 功能 :組建用戶(hù)名密碼面板,僅類(lèi)內(nèi)使用
 **=======================================================================**
 */
 private void buildCenter() {
 
 JLabel lb1, lb2;
 JPanel pa1, pa2, pa3;
 
 lb1 = new JLabel("用 戶(hù) 名 :");
 lb2 = new JLabel("登錄密碼 :");
 cb = new JComboBox();
 pf = new TJPasswordField (15);
 bt1 = new TJButton ("pic/key.gif", "登 錄", "登錄系統(tǒng)");
 bt2 = new TJButton ("pic/exit.gif", "退 出", "關(guān)閉系統(tǒng)");
 sunsql.initJComboBox (cb, "select userid from pwd where delmark=0");
 
 //定義面板為無(wú)部局
 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);
 
 //設(shè)定邊框線
 panelInfo.setBorder(BorderFactory.createTitledBorder(""));
 }
 
 /**=======================================================================**
 * [## private void quit() {} ]: 系統(tǒng)退出
 * 參數(shù) :無(wú)
 * 返回值 :無(wú)
 * 修飾符 :private
 * 功能 :關(guān)閉系統(tǒng)函數(shù),僅類(lèi)內(nèi)使用
 **=======================================================================**
 */
 private void quit() {
 int flag = 0;
 String msg = "您 現(xiàn) 在 要 關(guān) 閉 系 統(tǒng) 嗎 ?";
 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() {} ]: 系統(tǒng)登錄
 * 參數(shù) :無(wú)
 * 返回值 :無(wú)
 * 修飾符 :private
 * 功能 :密碼驗(yàn)證通過(guò),進(jìn)入主操作界面,僅類(lèi)內(nèi)使用
 **=======================================================================**
 */
 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()) { //用戶(hù)名存在
 if(pwd.equals(rs.getString(1))) {
 bott.setText(clue + "登錄成功,正在進(jìn)入系統(tǒng) ...");
 String puis = rs.getString(2); //獲得操作員權(quán)限
 boolean flag = Journal.writeJournalInfo(user, "登錄本系統(tǒng)", Journal.TYPE_LG);
 if(flag) { //記錄日志
 new com.sunshine.mainframe.HotelFrame(user, puis); //進(jìn)入主程序窗口(用戶(hù)名, 權(quán)限)
 this.setVisible(false);
 }else {
 String msg = "寫(xiě)日志錯(cuò)誤,請(qǐng)與系統(tǒng)管理員聯(lián)系 ...";
 JOptionPane.showMessageDialog(null, msg, "錯(cuò)誤", JOptionPane.ERROR_MESSAGE);
 System.exit(0);
 }
 }
 else {
 bott.setText(clue + "用戶(hù) [ " + user + " ] 的密碼不正確,請(qǐng)重新輸入 ...");
 flag++;
 if(flag == 3) { //三次密碼驗(yàn)證
 JOptionPane.showMessageDialog(null, "您不是本系統(tǒng)的管理員,系統(tǒng)關(guān)閉 ...", "警告", JOptionPane.ERROR_MESSAGE);
 System.exit(0);
 }//End if(flag == 3)
 return;
 }//End if(pwd.equals(rs.getString(1)))
 }
 else {
 bott.setText(clue + "用戶(hù)ID [ " + user + " ] 不存在 ...");
 }//End if(rs.next()) 
 }
 catch (Exception ex) {
 ex.printStackTrace();
 }//End try
 }
 
 /**=======================================================================**
 * ActionListener 監(jiān)聽(tīng)
 **=======================================================================**
 */
 public void actionPerformed (ActionEvent ae) {
 //動(dòng)作監(jiān)聽(tīng)
 if(ae.getSource() == bt1) { //登錄按鍵
 dengLu();
 }
 else {
 quit();
 }//End if(ae.getSource() == bt1)
 }
 
 /**=======================================================================**
 * ItemListener 監(jiān)聽(tīng)
 **=======================================================================**
 */
 public void itemStateChanged (ItemEvent ie) {
 pf.requestFocus(true);
 } 
 
 /**=======================================================================**
 * KeyListener 監(jiān)聽(tīng)
 **=======================================================================**
 */
 public void keyPressed (KeyEvent ke) {
 //鍵盤(pán)按下監(jiān)聽(tīng)
 int key = ke.getKeyCode();
 if(key == KeyEvent.VK_ENTER) {
 if(ke.getSource() == cb)
 pf.requestFocus(true); //將焦點(diǎn)從用戶(hù)名給密碼
 if(pf.getPassword().length > 0)
 dengLu(); //按Enter鍵登錄系統(tǒng)
 }
 else if(key == KeyEvent.VK_ESCAPE) { //按ESC鍵退出系統(tǒng)
 quit();
 }//End if
 }
 
 public void keyReleased (KeyEvent ke) {
 //鍵盤(pán)釋放監(jiān)聽(tīng)
 }
 
 public void keyTyped (KeyEvent ke) {
 //按鍵型監(jiān)聽(tīng)
 }
 
 /**=======================================================================**
 * FocusListener 監(jiān)聽(tīng)
 **=======================================================================**
 */
 public void focusGained (FocusEvent fe) {
 //焦點(diǎn)監(jiān)聽(tīng)
 if(fe.getSource() == cb) //窗口最下方的功能提示
 bott.setText(clue + "請(qǐng)選擇操作員名稱(chēng) ...");
 else
 if(fe.getSource() == pf)
 bott.setText(clue + "請(qǐng)輸入登錄密碼 ...");
 else
 if(fe.getSource() == bt1)
 bott.setText(clue + "登錄系統(tǒng) ...");
 else
 if(fe.getSource() == bt2)
 bott.setText(clue + "退出系統(tǒng) ...");
 }
 
 public void focusLost (FocusEvent fe) {
 //失去焦點(diǎn)監(jiān)聽(tīng)
 }
 
 /**=======================================================================**
 * [## public static void main(String sd[]) {} ]: 主函數(shù)
 * 參數(shù) :String sd[] 
 * 返回值 :無(wú)
 * 修飾符 :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();
 }
 
}

獲取地址:Java swing實(shí)現(xiàn)酒店管理系統(tǒng)

更多學(xué)習(xí)資料請(qǐng)關(guān)注專(zhuān)題《管理系統(tǒng)開(kāi)發(fā)》。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論

91天堂精品一区二区| 国产福利在线视频一区| 3337p日本欧洲大胆色噜噜| 久久久精品999精品日本| 成人激情文学网人妻| 亚洲 欧美 精品 激情 偷拍 | 精彩视频99免费在线| 男人的天堂av日韩亚洲| 77久久久久国产精产品| 五十路丰满人妻熟妇| 日日操综合成人av| 93精品视频在线观看| 岛国青草视频在线观看| 亚洲精品中文字幕下载| 亚洲成a人片777777| 欧美黑人与人妻精品| 欧美日韩激情啪啪啪| 国产性色生活片毛片春晓精品| 亚洲av男人的天堂你懂的| 久久久91蜜桃精品ad| 超碰97人人澡人人| 91破解版永久免费| 美女少妇亚洲精选av| 人妻无码中文字幕专区| 日本高清成人一区二区三区| 免费在线播放a级片| 精品高跟鞋丝袜一区二区| 中文字幕无码日韩专区免费| 久久久久只精品国产三级| 密臀av一区在线观看| 国产精品一区二区av国| 超污视频在线观看污污污| 中文字幕之无码色多多| 91大神福利视频网| 亚洲护士一区二区三区| 好太好爽好想要免费| 宅男噜噜噜666免费观看| 国产精品入口麻豆啊啊啊| 丝袜肉丝一区二区三区四区在线看| 国产视频网站一区二区三区| 国产在线自在拍91国语自产精品| 欧美黑人与人妻精品| 国产精品熟女久久久久浪潮| 999九九久久久精品| 免费国产性生活视频| 91久久综合男人天堂| 在线新三级黄伊人网| 久久亚洲天堂中文对白| 中文字幕在线永久免费播放| 国产综合高清在线观看| 大屁股熟女一区二区三区| 欧美日韩在线精品一区二区三| 都市激情校园春色狠狠| 在线新三级黄伊人网| 男人的天堂一区二区在线观看| 毛片av在线免费看| 亚洲一区二区人妻av| 久久永久免费精品人妻专区| 成人乱码一区二区三区av| 五十路熟女人妻一区二| 久久精品视频一区二区三区四区 | 欧美久久一区二区伊人| 亚洲国产精品久久久久久6| 久久麻豆亚洲精品av| 国产性感美女福利视频| 国产真实灌醉下药美女av福利| 偷拍美女一区二区三区| 97瑟瑟超碰在线香蕉| 一区二区三区麻豆福利视频| 国产又粗又猛又爽又黄的视频美国| 91麻豆精品秘密入口在线观看| 久久久久久99国产精品| 91久久人澡人人添人人爽乱| 国产日韩欧美美利坚蜜臀懂色| 中文字幕日韩精品日本| 天天干天天操天天爽天天摸| 天天日天天鲁天天操| 11久久久久久久久久久| 亚洲欧美在线视频第一页| 又粗又长 明星操逼小视频| 91精品国产综合久久久蜜| 99热碰碰热精品a中文| 天天日天天干天天爱| 亚洲精品国品乱码久久久久| 中出中文字幕在线观看| 欧洲欧美日韩国产在线| 97人妻无码AV碰碰视频| 亚洲人妻30pwc| 一区二区三区综合视频| 无忧传媒在线观看视频| 初美沙希中文字幕在线| av网址国产在线观看| 337p日本大胆欧美人| 免费男阳茎伸入女阳道视频| 亚洲精品在线资源站| 91啪国自产中文字幕在线| 操的小逼流水的文章| 搡老妇人老女人老熟女| 视频一区二区三区高清在线| v888av在线观看视频| 日日夜夜精品一二三| 日本最新一二三区不卡在线 | 欧美偷拍自拍色图片| 中文字幕免费福利视频6| 这里有精品成人国产99| 亚洲午夜高清在线观看| 超pen在线观看视频公开97| 欧美视频一区免费在线| 黑人3p华裔熟女普通话| 国产亚洲精品品视频在线| 57pao国产一区二区| 在线观看国产免费麻豆| 在线免费观看靠比视频的网站| 偷拍自拍 中文字幕| 美味人妻2在线播放| 亚洲欧洲av天堂综合| 精品久久久久久久久久久久人妻 | 国产欧美精品一区二区高清 | 美女福利写真在线观看视频| 国产丰满熟女成人视频| 欧美视频中文一区二区三区| 人妻少妇一区二区三区蜜桃| 中文字幕在线乱码一区二区| 激情五月婷婷综合色啪| eeuss鲁片一区二区三区| 97超碰最新免费在线观看| 2020韩国午夜女主播在线| 欧美aa一级一区三区四区| 日韩伦理短片在线观看| 国产高清精品极品美女| 国产亚洲成人免费在线观看| 99精品国自产在线人| 青青草国内在线视频精选| 国产真实灌醉下药美女av福利| gay gay男男瑟瑟在线网站| 欧美区一区二区三视频| 日本真人性生活视频免费看| 亚洲综合乱码一区二区| 在线观看av观看av| 午夜在线观看岛国av,com| 五月天色婷婷在线观看视频免费| 亚洲精品高清自拍av| 国产女人叫床高潮大片视频| 搡老熟女一区二区在线观看| 视频一区二区在线免费播放| 日本精品视频不卡一二三| 日本成人一区二区不卡免费在线| 亚洲精品三级av在线免费观看| 在线播放国产黄色av| 岳太深了紧紧的中文字幕| 精品亚洲国产中文自在线| 亚洲精品麻豆免费在线观看 | 国产乱子伦一二三区| 精品一区二区三区欧美| 美女少妇亚洲精选av| 人妻丰满熟妇综合网| 特黄老太婆aa毛毛片| asmr福利视频在线观看| av网址国产在线观看| 含骚鸡巴玩逼逼视频| 日韩欧美一级aa大片| 亚洲一区二区久久久人妻| 精品视频国产在线观看| 97小视频人妻一区二区| 91精品免费久久久久久| 亚洲成高清a人片在线观看| 热久久只有这里有精品| 日本最新一二三区不卡在线| 99热久久这里只有精品8| 福利片区一区二体验区| 亚洲激情唯美亚洲激情图片| 大鸡巴插入美女黑黑的阴毛| 欧美另类重口味极品在线观看| 国产精品福利小视频a| 午夜精品福利一区二区三区p | 丰满少妇人妻xxxxx| 日韩美女综合中文字幕pp| 免费黄色成人午夜在线网站| 青青色国产视频在线| 国产精品自拍偷拍a| 久久久精品国产亚洲AV一 | 在线免费观看靠比视频的网站| 久久久超爽一二三av| 亚洲丝袜老师诱惑在线观看| 青青草原色片网站在线观看| 日韩人妻丝袜中文字幕| 欧美视频中文一区二区三区| 岛国黄色大片在线观看| 另类av十亚洲av| 国产欧美精品一区二区高清| 538精品在线观看视频| gay gay男男瑟瑟在线网站| 亚洲av无硬久久精品蜜桃| 欧美黑人性暴力猛交喷水| 超级碰碰在线视频免费观看| 男生舔女生逼逼视频| 久久久久久久久久久久久97| 国产成人午夜精品福利| 日本在线一区二区不卡视频| 视频 一区二区在线观看| 开心 色 六月 婷婷| 插小穴高清无码中文字幕| 馒头大胆亚洲一区二区| 亚洲成高清a人片在线观看| 直接能看的国产av| 天天躁日日躁狠狠躁av麻豆| 青青草亚洲国产精品视频| 日本又色又爽又黄又粗| 天堂v男人视频在线观看| 91啪国自产中文字幕在线| 五月天中文字幕内射| 国产精品成久久久久三级蜜臀av | 精彩视频99免费在线| 日本少妇高清视频xxxxx| 免费大片在线观看视频网站| 精品国产成人亚洲午夜| 福利一二三在线视频观看| 操的小逼流水的文章| 老司机免费视频网站在线看| 男人操女人逼逼视频网站| 亚洲精品亚洲人成在线导航| 激情色图一区二区三区| 亚洲高清国产自产av| 天干天天天色天天日天天射 | 在线亚洲天堂色播av电影| 国产一区二区火爆视频| 久久一区二区三区人妻欧美| 伊人网中文字幕在线视频| 人妻少妇性色欲欧美日韩| 自拍偷拍亚洲欧美在线视频| 亚洲另类综合一区小说| 人妻凌辱欧美丰满熟妇| 国产精品久久久久久美女校花| 狠狠躁狠狠爱网站视频| 91老师蜜桃臀大屁股| 成人色综合中文字幕| 91精品一区二区三区站长推荐| 日韩北条麻妃一区在线| av完全免费在线观看av| 不卡日韩av在线观看| av线天堂在线观看| 亚洲熟色妇av日韩熟色妇在线| 亚洲av极品精品在线观看| 在线观看视频网站麻豆| 99精品久久久久久久91蜜桃| 黄色在线观看免费观看在线| 美女吃鸡巴操逼高潮视频| 精品一区二区三区三区88| 动漫精品视频在线观看| 精品91高清在线观看| 国产老熟女伦老熟妇ⅹ| 在线免费观看99视频| 精产国品久久一二三产区区别| 一个色综合男人天堂| 免费成人va在线观看| 国产福利在线视频一区| 亚洲一区自拍高清免费视频| 人妻av无码专区久久绿巨人| 国产熟妇人妻ⅹxxxx麻豆| 中文字幕免费福利视频6| 精品国产亚洲av一淫| 98视频精品在线观看| 国产午夜男女爽爽爽爽爽视频 | 国产精品国色综合久久| 女生自摸在线观看一区二区三区| 欧美爆乳肉感大码在线观看 | 我想看操逼黄色大片| 大鸡巴操b视频在线| 无忧传媒在线观看视频| 国产九色91在线观看精品| 天天干天天操天天爽天天摸| 91高清成人在线视频| 国产一区二区欧美三区| av网址国产在线观看| 好了av中文字幕在线| 1000小视频在线| 欧洲国产成人精品91铁牛tv| 青青青青青手机视频| 韩国亚洲欧美超一级在线播放视频| 成人蜜桃美臀九一一区二区三区| 操的小逼流水的文章| 欧美 亚洲 另类综合| 国产av自拍偷拍盛宴| 精品国产亚洲av一淫| 最新欧美一二三视频| 超碰97人人做人人爱| 天天日天天添天天爽| avjpm亚洲伊人久久| 青青青视频手机在线观看| 成人av中文字幕一区| 91亚洲精品干熟女蜜桃频道| 久久亚洲天堂中文对白| 久久一区二区三区人妻欧美| 久草福利电影在线观看| 欧美精品一二三视频| 日本美女性生活一级片| 欧美亚洲牲夜夜综合久久| 北条麻妃av在线免费观看| 日韩成人免费电影二区| 2021久久免费视频| 亚洲在线免费h观看网站| 在线播放 日韩 av| 国产精品熟女久久久久浪潮| 欧美伊人久久大香线蕉综合| 超碰97免费人妻麻豆| 国产麻豆剧果冻传媒app| 日韩精品一区二区三区在线播放| 无忧传媒在线观看视频| 亚洲精品亚洲人成在线导航| 亚洲成人国产av在线| 在线免费视频 自拍| xxx日本hd高清| 亚洲中文字幕校园春色| 青青青青操在线观看免费| 欧美成人一二三在线网| 国产妇女自拍区在线观看| 夫妻在线观看视频91| 视频一区二区在线免费播放| 黄片大全在线观看观看| 亚洲少妇人妻无码精品| 亚洲免费福利一区二区三区| 五月天色婷婷在线观看视频免费| 中国产一级黄片免费视频播放| 91人妻精品一区二区久久| 亚洲青青操骚货在线视频| 全国亚洲男人的天堂| 天天日天天舔天天射进去| 美女张开腿让男生操在线看| 亚洲av无乱一区二区三区性色| 超级福利视频在线观看| 亚洲中文字幕国产日韩| 1024久久国产精品| 成人国产影院在线观看| 久久久制服丝袜中文字幕| 国产成人综合一区2区| 制服丝袜在线人妻中文字幕| 午夜大尺度无码福利视频| 日韩欧美中文国产在线| 精品黑人一区二区三区久久国产| 端庄人妻堕落挣扎沉沦| 91老师蜜桃臀大屁股| 成人性爱在线看四区| 中文字幕欧美日韩射射一| 中文字幕av第1页中文字幕| 无码国产精品一区二区高潮久久4| 新婚人妻聚会被中出| 早川濑里奈av黑人番号| 亚洲高清一区二区三区视频在线 | 亚洲精品精品国产综合| 黄色在线观看免费观看在线| 国产成人自拍视频在线免费观看| 88成人免费av网站| 日韩国产乱码中文字幕| 3337p日本欧洲大胆色噜噜| 熟女俱乐部一二三区| 欧美一区二区三区高清不卡tv| 伊人日日日草夜夜草| 黄色资源视频网站日韩| 国产chinesehd精品麻豆| 国产精品自拍偷拍a| 日韩欧美国产一区不卡| 91在线免费观看成人| 丝袜国产专区在线观看| 亚洲乱码中文字幕在线| 综合一区二区三区蜜臀| 久久久久五月天丁香社区| 国产福利小视频免费观看| 在线 中文字幕 一区| 动漫精品视频在线观看| 一区二区三区精品日本| 色av色婷婷人妻久久久精品高清| 一区二区三区四区五区性感视频 | 国产精品一区二区av国| 天天色天天爱天天爽| 国产精品中文av在线播放| 精品亚洲国产中文自在线| 99的爱精品免费视频| 欧美精产国品一二三产品区别大吗| 啊啊啊想要被插进去视频| 91亚洲国产成人精品性色| 玩弄人妻熟妇性色av少妇| 国产成人精品久久二区91| 99久久成人日韩欧美精品| 风流唐伯虎电视剧在线观看| 在线免费观看亚洲精品电影| 97少妇精品在线观看| 婷婷久久一区二区字幕网址你懂得| 欧美亚洲国产成人免费在线| 国产成人无码精品久久久电影| 亚洲高清一区二区三区视频在线| 热思思国产99re| 久青青草视频手机在线免费观看| 日韩一区二区电国产精品| 国产av自拍偷拍盛宴| 99精品国产免费久久| 少妇与子乱在线观看| 美女福利写真在线观看视频| 少妇人妻100系列| 97人妻无码AV碰碰视频| 蜜桃久久久久久久人妻| 日本美女成人在线视频| 成人蜜臀午夜久久一区| 国产精品中文av在线播放| 日本xx片在线观看| 欧美老鸡巴日小嫩逼| 免费男阳茎伸入女阳道视频| 色花堂在线av中文字幕九九| 国产伦精品一区二区三区竹菊| 国产精品国产三级国产午| 亚洲自拍偷拍综合色| 开心 色 六月 婷婷| 亚洲天堂第一页中文字幕| 国产视频一区二区午夜| wwwxxx一级黄色片| 成人资源在线观看免费官网| 视频啪啪啪免费观看| 日韩人妻丝袜中文字幕| 国产女孩喷水在线观看| 懂色av蜜桃a v| 国产大鸡巴大鸡巴操小骚逼小骚逼| 青娱乐最新视频在线| 91‖亚洲‖国产熟女| 中文字幕日韩精品日本| 国产精品久久久黄网站| 成人动漫大肉棒插进去视频| 亚洲中文字幕综合小综合| 老师让我插进去69AV| 动漫av网站18禁| 93视频一区二区三区| 成人免费做爰高潮视频| 国产性感美女福利视频| 欧美成人黄片一区二区三区| 亚洲一区二区三区在线高清| 国产亚洲精品品视频在线| 国产揄拍高清国内精品对白| 日本福利午夜电影在线观看| 毛片av在线免费看| 亚洲中文字幕人妻一区| 久久久久久久精品成人热| 亚洲人妻av毛片在线| 亚洲激情偷拍一区二区| 日韩精品中文字幕福利| 亚洲精品国产在线电影| 国产精品人妻66p| 亚洲国产成人最新资源| 成年人的在线免费视频| 亚洲视频在线视频看视频在线| 午夜影院在线观看视频羞羞羞| 91中文字幕免费在线观看| 日韩在线视频观看有码在线| 国产精品人妻66p| 一区二区久久成人网| 天干天天天色天天日天天射| 亚洲伊人av天堂有码在线| 日韩av熟妇在线观看| 2025年人妻中文字幕乱码在线| 亚洲1区2区3区精华液| 亚洲嫩模一区二区三区| 日韩亚国产欧美三级涩爱| 中文字幕无码一区二区免费| 一区二区久久成人网| 51国产偷自视频在线播放| 国产三级精品三级在线不卡| 在线观看欧美黄片一区二区三区| 无套猛戳丰满少妇人妻| 亚洲国产欧美国产综合在线| 国产日韩欧美视频在线导航| 国产日韩欧美美利坚蜜臀懂色| 日本av在线一区二区三区| 欧美老妇精品另类不卡片| 啪啪啪操人视频在线播放| 99久久99久国产黄毛片| 免费费一级特黄真人片| 国产又粗又猛又爽又黄的视频在线 | 夜夜骑夜夜操夜夜奸| 91试看福利一分钟| av一本二本在线观看| 欧美日韩情色在线观看| 综合色区亚洲熟妇shxstz| 久草视频中文字幕在线观看| 亚洲熟妇无码一区二区三区| 91‖亚洲‖国产熟女| 日本一道二三区视频久久| 沈阳熟妇28厘米大战黑人| 国产视频在线视频播放| 91免费黄片可看视频| 国产精品久久久久国产三级试频| 亚洲免费av在线视频| 青青草亚洲国产精品视频| 欧美专区日韩专区国产专区| 在线国产日韩欧美视频| 蜜桃久久久久久久人妻| 少妇深喉口爆吞精韩国| 国产品国产三级国产普通话三级| 精品人人人妻人人玩日产欧| 日本韩国在线观看一区二区| 欧美日本在线视频一区| 最新中文字幕乱码在线| 91免费观看国产免费| 又粗又硬又猛又黄免费30| 日韩无码国产精品强奸乱伦| 成人资源在线观看免费官网| 天天日天天干天天爱| 最新97国产在线视频| 人人妻人人爽人人添夜| 五十路熟女人妻一区二区9933 | chinese国产盗摄一区二区 | 日本在线一区二区不卡视频| 青娱乐最新视频在线| 午夜蜜桃一区二区三区| 黑人解禁人妻叶爱071| 91精品国产综合久久久蜜| 78色精品一区二区三区| 制丝袜业一区二区三区| 久久久久久9999久久久久| 国产福利小视频大全| 日本午夜福利免费视频| 欧美综合婷婷欧美综合| 少妇系列一区二区三区视频| 婷婷六月天中文字幕| 蜜桃臀av蜜桃臀av| 欧美精品亚洲精品日韩在线| 成人18禁网站在线播放| 淫秽激情视频免费观看| 国产又粗又硬又猛的毛片视频 | 天天躁日日躁狠狠躁av麻豆| weyvv5国产成人精品的视频| 在线免费91激情四射 | 中文字幕日本人妻中出| 国产精品系列在线观看一区二区 | 日本三极片视频网站观看| sejizz在线视频| 欧美黑人与人妻精品| 狠狠操操操操操操操操操| 亚洲人成精品久久久久久久| 久久一区二区三区人妻欧美| 1区2区3区不卡视频| 欧美亚洲少妇福利视频| 插小穴高清无码中文字幕| 欧美一区二区三区高清不卡tv| 日本成人不卡一区二区| 欧美日本在线视频一区| 天天躁日日躁狠狠躁av麻豆| 66久久久久久久久久久| 亚洲免费av在线视频| 亚洲欧美激情人妻偷拍| 大屁股熟女一区二区三区| 最新国产亚洲精品中文在线| 中文乱理伦片在线观看| 男人在床上插女人视频| 欧美日韩中文字幕欧美| 欧美偷拍自拍色图片| 国产普通话插插视频| 少妇露脸深喉口爆吞精| 亚洲国产美女一区二区三区软件| 亚洲欧美人精品高清| 熟女人妻在线观看视频| 色婷婷六月亚洲综合香蕉| 在线免费91激情四射| 亚洲男人让女人爽的视频| 精彩视频99免费在线| 日本精品美女在线观看| 青青擦在线视频国产在线| 自拍偷拍日韩欧美亚洲| 91国内视频在线观看| 亚洲精品欧美日韩在线播放| www久久久久久久久久久| 国产精品久久久久久久女人18| 国产精品大陆在线2019不卡| 黄色片一级美女黄色片| 久久一区二区三区人妻欧美| 日本av熟女在线视频| 青草青永久在线视频18| av在线资源中文字幕| 国产女人被做到高潮免费视频| 五月天久久激情视频| 国产va在线观看精品| 韩国亚洲欧美超一级在线播放视频| 日视频免费在线观看| 久草免费人妻视频在线| nagger可以指黑人吗| av亚洲中文天堂字幕网| 亚洲区美熟妇久久久久| avjpm亚洲伊人久久| 男人天堂av天天操| 国产精品黄页网站视频| 无码日韩人妻精品久久| 欧美国产亚洲中英文字幕| 在线不卡日韩视频播放| 91老熟女连续高潮对白| 亚洲欧美日韩视频免费观看| 无忧传媒在线观看视频| 大鸡巴操b视频在线| 91自产国产精品视频| 日本少妇高清视频xxxxx| 精品av国产一区二区三区四区| 中文字幕日本人妻中出| 日韩美女精品视频在线观看网站| 伊人成人综合开心网| 欧美黑人性暴力猛交喷水| 青草青永久在线视频18| 天天夜天天日天天日| 五十路熟女人妻一区二区9933| 果冻传媒av一区二区三区| 快插进小逼里大鸡吧视频| 人人妻人人爽人人添夜| 人妻无码色噜噜狠狠狠狠色| 强行扒开双腿猛烈进入免费版 | 99热这里只有国产精品6| 黑人借宿ntr人妻的沦陷2| 一区二区三区国产精选在线播放| 青青草国内在线视频精选| 欧洲精品第一页欧洲精品亚洲| 中文亚洲欧美日韩无线码| 国产aⅴ一线在线观看| 人妻丝袜精品中文字幕| 午夜久久久久久久精品熟女| 国产亚洲欧美45p| 亚洲精品精品国产综合| 香蕉片在线观看av| 日韩国产乱码中文字幕| 青青伊人一精品视频| 最后99天全集在线观看| 黄色视频在线观看高清无码| japanese日本熟妇另类| 亚洲精品无码久久久久不卡| AV无码一区二区三区不卡| 亚洲第一黄色在线观看| 一区二区三区毛片国产一区| 天天日天天添天天爽| 欧美成人一二三在线网| 亚洲一区二区三区五区| 一区二区在线视频中文字幕| 天天日天天干天天要| 青青草国内在线视频精选| 91久久国产成人免费网站| 亚洲公开视频在线观看| 91片黄在线观看喷潮| 一色桃子人妻一区二区三区| 日本少妇的秘密免费视频| 成人资源在线观看免费官网| 中文字幕奴隷色的舞台50| 亚洲精品国品乱码久久久久| 亚洲精品无码久久久久不卡| 精品av久久久久久久| 色婷婷久久久久swag精品| 年轻的人妻被夫上司侵犯| 国产精品中文av在线播放| 国产精品3p和黑人大战| 亚洲国产成人最新资源| 欧美 亚洲 另类综合| 亚洲综合乱码一区二区| 玩弄人妻熟妇性色av少妇| 国产亚洲视频在线观看| 精品一区二区三四区| 亚洲av自拍偷拍综合| 漂亮 人妻被中出中文| 北条麻妃肉色丝袜视频| 天堂av狠狠操蜜桃| 特一级特级黄色网片| 亚洲午夜高清在线观看| 亚洲成人情色电影在线观看| 日日操综合成人av| 青青草原色片网站在线观看| 成年人中文字幕在线观看| 骚货自慰被发现爆操| 国产一级麻豆精品免费| 久久丁香花五月天色婷婷| 午夜在线观看岛国av,com| 亚洲伊人av天堂有码在线| 午夜免费体验区在线观看| 久久久制服丝袜中文字幕| 超黄超污网站在线观看| 国产V亚洲V天堂无码欠欠| yy96视频在线观看| 天天躁日日躁狠狠躁躁欧美av | 51精品视频免费在线观看| 亚洲 中文字幕在线 日韩| 综合精品久久久久97| 欧美一级色视频美日韩| 69精品视频一区二区在线观看| 午夜激情高清在线观看| 日韩欧美一级精品在线观看| 亚洲一区制服丝袜美腿| 男女第一次视频在线观看| 91在线视频在线精品3| 亚洲一区二区三区久久午夜| 91 亚洲视频在线观看| 国产一区二区久久久裸臀| 欧美精品中文字幕久久二区| 蜜桃臀av蜜桃臀av| 欧洲日韩亚洲一区二区三区| 亚洲欧美福利在线观看| 亚洲粉嫩av一区二区三区| 99热国产精品666| 久草视频在线免播放| 大屁股肉感人妻中文字幕在线| 国产精品视频男人的天堂| 熟女在线视频一区二区三区| 欧美精品 日韩国产| 啪啪啪啪啪啪啪啪av| 亚洲欧美清纯唯美另类| 扒开腿挺进肉嫩小18禁视频| 阴茎插到阴道里面的视频| 一区二区三区欧美日韩高清播放| 性欧美激情久久久久久久| 大香蕉玖玖一区2区| 黄色大片免费观看网站| 欧美精品黑人性xxxx| 欧美久久一区二区伊人| 久久精品久久精品亚洲人| 亚洲欧美综合另类13p| 人人妻人人爽人人澡人人精品| 国产自拍在线观看成人| 偷拍自拍福利视频在线观看| 姐姐的朋友2在线观看中文字幕| 天天操天天弄天天射| 精品一区二区亚洲欧美| 麻豆性色视频在线观看| 国产欧美精品一区二区高清 | 久久热这里这里只有精品| av日韩在线观看大全| 伊人成人综合开心网| 后入美女人妻高清在线| 午夜频道成人在线91| 人人人妻人人澡人人| 偷拍自拍 中文字幕| 中国熟女一区二区性xx| 91九色porny蝌蚪国产成人| 黄色无码鸡吧操逼视频| av森泽佳奈在线观看| 国产乱弄免费视频观看| 亚洲午夜在线视频福利| 午夜场射精嗯嗯啊啊视频| 中文字幕无码一区二区免费| 精品国产午夜视频一区二区| av俺也去在线播放| 77久久久久国产精产品| 中文字幕—97超碰网| 国产一区二区火爆视频 | 成人免费做爰高潮视频| 亚洲天堂成人在线观看视频网站| 91天堂精品一区二区| 国产亚洲成人免费在线观看| 欧美日本在线观看一区二区| 亚洲精品福利网站图片| 中文字幕av熟女人妻| 91久久综合男人天堂| 首之国产AV医生和护士小芳| 国产亚洲精品欧洲在线观看| 含骚鸡巴玩逼逼视频| 久久久久久cao我的性感人妻| 91精品国产麻豆国产| 日本女大学生的黄色小视频| 老司机欧美视频在线看| 亚洲高清视频在线不卡| 精品视频中文字幕在线播放| 蜜臀av久久久久久久| 国产精品黄片免费在线观看| 一区二区视频视频视频| 色哟哟国产精品入口| 成人精品在线观看视频| 久久久精品精品视频视频| 久久机热/这里只有| 中文字幕第1页av一天堂网| 宅男噜噜噜666国产| 欧美xxx成人在线| 中英文字幕av一区| 国产在线拍揄自揄视频网站| 又大又湿又爽又紧A视频| 日韩欧美国产一区ab| 久草电影免费在线观看| 动漫av网站18禁| 中文 成人 在线 视频| 亚洲福利午夜久久久精品电影网| 成年美女黄网站18禁久久| 黑人3p华裔熟女普通话| 一区二区三区激情在线| 91久久综合男人天堂| 亚洲少妇人妻无码精品| 日韩欧美一级精品在线观看| 一区二区视频视频视频| 中文字幕AV在线免费看 | 97人妻总资源视频| 国产va精品免费观看| 午夜久久久久久久精品熟女| 国产激情av网站在线观看| 亚洲成人情色电影在线观看| 九九热99视频在线观看97| 青娱乐蜜桃臀av色| 久精品人妻一区二区三区| 天天干天天啪天天舔| 国产一区二区欧美三区| 19一区二区三区在线播放| 都市激情校园春色狠狠| 中文字幕第三十八页久久| 好太好爽好想要免费| 91免费观看国产免费| 中文字幕一区二区人妻电影冢本 | 97人人模人人爽人人喊| a v欧美一区=区三区| 久久久久久久久久久免费女人| 亚洲男人在线天堂网| 一级黄色片夫妻性生活| 在线观看视频网站麻豆| 大香蕉玖玖一区2区| 黑人借宿ntr人妻的沦陷2| 久久久超爽一二三av| 福利在线视频网址导航| 亚洲欧美一区二区三区电影| 国产日本欧美亚洲精品视| 国产精品三级三级三级| 精品一区二区三区欧美| 日本成人不卡一区二区| 38av一区二区三区| 午夜场射精嗯嗯啊啊视频| 国产污污污污网站在线| 亚洲在线观看中文字幕av| 蜜桃久久久久久久人妻| 99热久久极品热亚洲| 好吊操视频这里只有精品| 国产日韩精品一二三区久久久| av中文字幕电影在线看| 国产性感美女福利视频| 日本午夜爽爽爽爽爽视频在线观看 | 亚洲护士一区二区三区| 日韩中文字幕在线播放第二页| 欧美精品黑人性xxxx| 欧美精品国产综合久久| 青青青艹视频在线观看| 精品国产污污免费网站入口自 | AV天堂一区二区免费试看| 午夜福利人人妻人人澡人人爽| 大香蕉大香蕉大香蕉大香蕉大香蕉| 午夜精品在线视频一区| 一区二区三区久久中文字幕| 免费一级黄色av网站| 班长撕开乳罩揉我胸好爽| 亚洲午夜电影在线观看| 亚洲 清纯 国产com| 自拍偷拍亚洲另类色图| 亚洲国产成人av在线一区| 色综合久久久久久久久中文| av天堂加勒比在线| 狠狠躁夜夜躁人人爽天天久天啪| 91亚洲精品干熟女蜜桃频道| 自拍偷拍亚洲欧美在线视频| 精品91自产拍在线观看一区| 宅男噜噜噜666国产| 日本高清在线不卡一区二区| 色花堂在线av中文字幕九九 | 扒开让我视频在线观看| 香蕉aⅴ一区二区三区| 久久久久久国产精品| 亚洲国产精品免费在线观看| 国产精品久久久久久美女校花| 亚洲蜜臀av一区二区三区九色| 一区二区三区视频,福利一区二区| 欧美另类重口味极品在线观看| 少妇露脸深喉口爆吞精| 欧美一区二区三区在线资源| 国产自拍在线观看成人| 天天日天天日天天射天天干| 黑人性生活视频免费看| aiss午夜免费视频| 国产熟妇人妻ⅹxxxx麻豆| 中国老熟女偷拍第一页| 日日操综合成人av| www,久久久,com| 天美传媒mv视频在线观看| 国产精品黄片免费在线观看| 免费看国产又粗又猛又爽又黄视频| 最新国产精品网址在线观看| 老鸭窝日韩精品视频观看| 成人国产激情自拍三区| 色综合久久久久久久久中文| 午夜在线一区二区免费| 欧美专区第八页一区在线播放| 欧美亚洲牲夜夜综合久久| 免费岛国喷水视频在线观看| 51国产偷自视频在线播放| 亚洲麻豆一区二区三区| 久久精品36亚洲精品束缚| 国产精品免费不卡av| 国产一区二区欧美三区 | 97成人免费在线观看网站| 人妻爱爱 中文字幕| 一级a看免费观看网站| 亚洲图片偷拍自拍区| 中文字幕免费福利视频6| 动色av一区二区三区| 中文字幕国产专区欧美激情| 任我爽精品视频在线播放| 亚洲公开视频在线观看| 东京热男人的av天堂| 亚洲av成人免费网站| 国产又大又黄免费观看| 亚洲国产免费av一区二区三区| 少妇人妻100系列| 青青青青草手机在线视频免费看 | 最新日韩av传媒在线| 999久久久久999| 亚洲欧美综合在线探花| 国产剧情演绎系列丝袜高跟| ka0ri在线视频| 免费观看污视频网站| 男人和女人激情视频| 热99re69精品8在线播放| 久久精品国产23696| 中文字幕一区二区三区人妻大片 | www,久久久,com| 2018最新中文字幕在线观看| 中文字幕一区二区三区蜜月| 91精品国产黑色丝袜| 中文字幕国产专区欧美激情| 午夜的视频在线观看| 国产精品sm调教视频| 亚洲人妻视频在线网| 国产日韩欧美美利坚蜜臀懂色| 激情五月婷婷免费视频| 天天操天天干天天日狠狠插 | 视频 一区二区在线观看| 日噜噜噜夜夜噜噜噜天天噜噜噜| 日韩精品电影亚洲一区| asmr福利视频在线观看| 国产精品黄页网站视频| 成年人中文字幕在线观看| 日本午夜福利免费视频| 欧美成人精品欧美一级黄色| 亚洲国产欧美一区二区三区久久 | 老熟妇凹凸淫老妇女av在线观看| 国产精品中文av在线播放| 熟女俱乐部一二三区| 最新中文字幕乱码在线| 深夜男人福利在线观看| 日日操综合成人av| 天天日天天透天天操| 亚洲av天堂在线播放| 天天通天天透天天插| 国产一区成人在线观看视频| av成人在线观看一区| 亚洲高清免费在线观看视频| 成人av电影免费版| 日韩不卡中文在线视频网站| 亚洲码av无色中文| 国产黄色大片在线免费播放| 青娱乐在线免费视频盛宴| 国产使劲操在线播放| 国产精品福利小视频a| 九色视频在线观看免费| 99久久成人日韩欧美精品| 美女小视频网站在线| 天天躁日日躁狠狠躁躁欧美av| 国产日韩精品一二三区久久久| 不卡一不卡二不卡三| 黄色男人的天堂视频| 亚洲 国产 成人 在线| 韩国男女黄色在线观看| 精品乱子伦一区二区三区免费播| 日本免费一级黄色录像| 天天日天天干天天爱| 亚洲成人av一区在线| 日本av熟女在线视频| 久久精品国产23696| 国产伊人免费在线播放| 亚洲中文字幕人妻一区| 婷婷久久久综合中文字幕| 福利视频一区二区三区筱慧| 国产乱弄免费视频观看| 日本午夜久久女同精女女| 熟女视频一区,二区,三区| 日本三极片中文字幕| 亚洲在线观看中文字幕av| 久久久极品久久蜜桃| 亚洲综合图片20p| 婷婷色国产黑丝少妇勾搭AV| 经典国语激情内射视频| 精品久久婷婷免费视频| 中文字幕在线一区精品| 久久免费看少妇高潮完整版| 激情啪啪啪啪一区二区三区| 自拍偷拍亚洲精品第2页| gogo国模私拍视频| 中文字幕av一区在线观看| 337p日本大胆欧美人| 综合页自拍视频在线播放| av中文字幕网址在线| 青青青青青免费视频| 午夜蜜桃一区二区三区| 日本熟妇一区二区x x| 福利一二三在线视频观看| 大香蕉大香蕉在线看| 国产高潮无码喷水AV片在线观看| 欧美亚洲国产成人免费在线| 操日韩美女视频在线免费看| 天天夜天天日天天日| 欧美亚洲中文字幕一区二区三区| 国产成人自拍视频播放| 99精品国自产在线人| 啪啪啪啪啪啪啪啪啪啪黄色| 天天日天天添天天爽| 精品国产在线手机在线| 国产亚州色婷婷久久99精品| 日本熟妇丰满厨房55| 初美沙希中文字幕在线 | 日韩中文字幕在线播放第二页| 中文字幕一区二区三区蜜月| 青娱乐蜜桃臀av色| 欧美亚洲一二三区蜜臀| 亚洲成a人片777777| 国产精品女邻居小骚货| 亚洲日产av一区二区在线| 久久这里只有精品热视频 | 天天综合天天综合天天网| 11久久久久久久久久久| 中文字幕av熟女人妻| 亚洲精品av在线观看| 亚洲一区二区三区uij| 成人亚洲精品国产精品| 亚洲熟妇久久无码精品| 国产精品久久久黄网站| 手机看片福利盒子日韩在线播放| 精品人妻伦一二三区久| 白白操白白色在线免费视频 | 日本欧美视频在线观看三区| 日本少妇的秘密免费视频| 一区二区三区 自拍偷拍| 久精品人妻一区二区三区 | 激情五月婷婷综合色啪| 把腿张开让我插进去视频| 日韩av熟妇在线观看| 亚洲av日韩av网站| 久久香蕉国产免费天天| 久久一区二区三区人妻欧美| 丰满少妇翘臀后进式| 日本最新一二三区不卡在线| 水蜜桃国产一区二区三区| 欧美麻豆av在线播放| 日本人妻少妇18—xx| 亚洲午夜电影之麻豆| 日本免费午夜视频网站| 日韩成人性色生活片| 曰本无码人妻丰满熟妇啪啪| 欧美精品资源在线观看| 亚洲成人激情av在线| 这里只有精品双飞在线播放| 大香蕉伊人国产在线| 五月天中文字幕内射| 亚洲精品国偷自产在线观看蜜桃| 亚洲一区二区三区久久受| 福利片区一区二体验区| 99精品亚洲av无码国产另类| 福利在线视频网址导航| 亚洲成人午夜电影在线观看| 亚洲狠狠婷婷综合久久app| 99精品国产aⅴ在线观看| 亚洲精品三级av在线免费观看| 国产麻豆剧果冻传媒app| 一区二区三区综合视频| 日韩欧美高清免费在线| 99re国产在线精品| 日韩av熟妇在线观看| 九色视频在线观看免费| 91福利在线视频免费观看| 国产在线一区二区三区麻酥酥| 肏插流水妹子在线乐播下载| 在线观看一区二区三级| 中文字幕之无码色多多| 人妻激情图片视频小说| 日日夜夜大香蕉伊人| jiujiure精品视频在线| 成年人午夜黄片视频资源| 国产+亚洲+欧美+另类| 家庭女教师中文字幕在线播放| 午夜精品福利91av| 黑人变态深video特大巨大| 亚洲午夜电影之麻豆| 开心 色 六月 婷婷| 啊啊好大好爽啊啊操我啊啊视频 | av天堂资源最新版在线看| 亚洲精品无码久久久久不卡 | 精品suv一区二区69| 午夜久久香蕉电影网| 丝袜亚洲另类欧美变态| av中文字幕电影在线看| 一区二区熟女人妻视频| 欧美日韩一区二区电影在线观看| 超级碰碰在线视频免费观看| 最新中文字幕免费视频| 操人妻嗷嗷叫视频一区二区| 成人蜜桃美臀九一一区二区三区| 亚洲码av无色中文| 视频一区 视频二区 视频| 欧美日韩国产一区二区三区三州| 亚洲av色香蕉一区二区三区| av在线免费中文字幕| av老司机精品在线观看| 78色精品一区二区三区| 久久人人做人人妻人人玩精品vr| 国产日本精品久久久久久久| okirakuhuhu在线观看| 早川濑里奈av黑人番号| 欧美另类一区二区视频| 天天操天天干天天艹| 91人妻人人做人人爽在线| www天堂在线久久| 在线观看操大逼视频| 一区二区三区四区中文| 东游记中文字幕版哪里可以看到| 国产实拍勾搭女技师av在线| 蜜桃专区一区二区在线观看| 午夜精品九一唐人麻豆嫩草成人| 国产91久久精品一区二区字幕| 成人av中文字幕一区| 中文字幕一区二 区二三区四区| 欧美一级片免费在线成人观看 | 久久久久久久久久性潮| 18禁美女羞羞免费网站| 亚洲精品在线资源站| 亚洲女人的天堂av| 亚洲中文字幕乱码区| 久久综合老鸭窝色综合久久| 国产+亚洲+欧美+另类| 色伦色伦777国产精品| 中文字幕高清免费在线人妻| 97人妻无码AV碰碰视频| 香蕉av影视在线观看| 天天射夜夜操综合网| 黑人巨大精品欧美视频| 午夜国产免费福利av| 福利片区一区二体验区| av俺也去在线播放| 日本黄色特一级视频| 天天躁日日躁狠狠躁躁欧美av | 色在线观看视频免费的| 午夜激情精品福利视频| 欧美日韩人妻久久精品高清国产 | 中文乱理伦片在线观看| 欧美一区二区中文字幕电影| 日本韩国亚洲综合日韩欧美国产 | 欧美性感尤物人妻在线免费看| 精品一区二区三区午夜| 天天插天天狠天天操| 韩国女主播精品视频网站| 国产成人精品av网站| 丝袜长腿第一页在线| h国产小视频福利在线观看| 国产三级影院在线观看| 久久久久久国产精品| 国产剧情演绎系列丝袜高跟| 亚洲高清国产一区二区三区| 无码国产精品一区二区高潮久久4 日韩欧美一级精品在线观看 | 非洲黑人一级特黄片| 又黄又刺激的午夜小视频| 88成人免费av网站| 久久精品在线观看一区二区| 国产成人一区二区三区电影网站| 五月色婷婷综合开心网4438| 337p日本大胆欧美人| 国产精品视频欧美一区二区| 99精品视频在线观看婷婷| 91综合久久亚洲综合| 久久艹在线观看视频| 91色秘乱一区二区三区| 亚洲激情偷拍一区二区| 最新的中文字幕 亚洲| 馒头大胆亚洲一区二区| 日韩欧美一级aa大片| 午夜在线观看一区视频| 999九九久久久精品| asmr福利视频在线观看| 久久这里只有精品热视频 | 激情啪啪啪啪一区二区三区 | 国产chinesehd精品麻豆| av无限看熟女人妻另类av| 大鸡巴后入爆操大屁股美女 | 北条麻妃肉色丝袜视频| 自拍偷拍日韩欧美一区二区| 婷婷激情四射在线观看视频| 青青青艹视频在线观看| 国产成人一区二区三区电影网站| 天天干天天插天天谢| 在线观看免费视频色97| 绝顶痉挛大潮喷高潮无码| av在线免费中文字幕| 99热这里只有精品中文| 天天日天天干天天爱| 亚洲在线观看中文字幕av| 精品欧美一区二区vr在线观看| 国产夫妻视频在线观看免费| 亚洲第一黄色在线观看| 天天日天天干天天爱| 100%美女蜜桃视频| 日韩成人综艺在线播放| 好吊操视频这里只有精品| 天天干夜夜操啊啊啊| 成人激情文学网人妻| 农村胖女人操逼视频| 91九色国产熟女一区二区| 亚洲av男人的天堂你懂的| 超黄超污网站在线观看| 密臀av一区在线观看| 久碰精品少妇中文字幕av| 欧美黄色录像免费看的| 99热色原网这里只有精品| 久久免看30视频口爆视频| 亚洲精品麻豆免费在线观看 | 欧美国产亚洲中英文字幕| 蜜臀成人av在线播放| 成年人免费看在线视频| 亚洲区美熟妇久久久久| 把腿张开让我插进去视频| 亚洲高清免费在线观看视频| 直接能看的国产av| 最新激情中文字幕视频| 视频久久久久久久人妻| 丝袜美腿视频诱惑亚洲无 | 88成人免费av网站| 亚洲欧美日韩视频免费观看| 亚洲成人激情av在线| 男生舔女生逼逼视频| 亚洲中文字幕乱码区| 亚洲国际青青操综合网站| 精品欧美一区二区vr在线观看 | 亚洲国产成人无码麻豆艾秋| 爱爱免费在线观看视频| 欧美另类z0z变态| 99精品免费观看视频| 岛国免费大片在线观看| 亚洲成人情色电影在线观看| 强行扒开双腿猛烈进入免费版| 午夜av一区二区三区| 亚洲国产最大av综合| 福利片区一区二体验区| 大屁股熟女一区二区三区| 亚洲av午夜免费观看| 国产极品美女久久久久久| 人妻丝袜诱惑我操她视频| 国产自拍在线观看成人| sspd152中文字幕在线| 国产夫妻视频在线观看免费 | 91麻豆精品91久久久久同性| 在线 中文字幕 一区| 888欧美视频在线| 欧美成人黄片一区二区三区| 精内国产乱码久久久久久| 久久精品视频一区二区三区四区| 成人在线欧美日韩国产| 欧美第一页在线免费观看视频| 97人妻无码AV碰碰视频| 亚洲国产在人线放午夜| 沈阳熟妇28厘米大战黑人| 在线免费视频 自拍| 免费无码人妻日韩精品一区二区| 国产成人自拍视频播放| 欧美黄色录像免费看的| 日韩欧美中文国产在线| 在线观看av亚洲情色| 老熟妇凹凸淫老妇女av在线观看| 天天日天天透天天操| 黄片色呦呦视频免费看| 啪啪啪啪啪啪啪啪av| 熟女国产一区亚洲中文字幕| 亚洲午夜福利中文乱码字幕| 99久久成人日韩欧美精品| 天天操天天射天天操天天天| 不卡精品视频在线观看| 美女小视频网站在线| 四川五十路熟女av| 99热久久极品热亚洲| 天天操天天干天天日狠狠插 | 久久精品国产999| 红桃av成人在线观看| 亚洲无码一区在线影院| 国际av大片在线免费观看| 精品区一区二区三区四区人妻| 韩国爱爱视频中文字幕| 色偷偷伊人大杳蕉综合网| 综合国产成人在线观看| 888欧美视频在线| 天天日天天添天天爽| 久久精品美女免费视频| 国产日韩一区二区在线看| 国产极品精品免费视频| 日本一区精品视频在线观看| 日本男女操逼视频免费看| 黄色无码鸡吧操逼视频| 国产之丝袜脚在线一区二区三区 | 成人sm视频在线观看| av视网站在线观看| 国产成人一区二区三区电影网站| 在线观看视频污一区| 欧美3p在线观看一区二区三区| 午夜的视频在线观看| 蜜桃专区一区二区在线观看| 97精品成人一区二区三区| 日本性感美女三级视频| 亚洲国产成人无码麻豆艾秋| 色狠狠av线不卡香蕉一区二区 | 日韩av中文在线免费观看| brazzers欧熟精品系列| 中文字幕一区的人妻欧美日韩| 国产日韩一区二区在线看 | 国产chinesehd精品麻豆| 亚洲1卡2卡三卡4卡在线观看| jiuse91九色视频| 91国产在线免费播放| 美日韩在线视频免费看| 亚洲天堂精品福利成人av| 日本一区二区三区免费小视频| 91超碰青青中文字幕| 绝色少妇高潮3在线观看| 国产精品黄片免费在线观看| 97青青青手机在线视频| 免费观看国产综合视频| 红桃av成人在线观看| 天天日夜夜操天天摸| 亚洲一区制服丝袜美腿| 制服丝袜在线人妻中文字幕| 国产之丝袜脚在线一区二区三区| 精品久久婷婷免费视频| 亚洲人妻视频在线网| 日曰摸日日碰夜夜爽歪歪| 黄色成年网站午夜在线观看| 日韩熟女系列一区二区三区| av完全免费在线观看av| 又粗又硬又猛又爽又黄的| 只有精品亚洲视频在线观看| 亚洲成av人无码不卡影片一| 少妇人妻久久久久视频黄片| 91精品高清一区二区三区| 久久久久久久99精品| lutube在线成人免费看| 色av色婷婷人妻久久久精品高清| av欧美网站在线观看| 亚洲国产在线精品国偷产拍| 91小伙伴中女熟女高潮| 东游记中文字幕版哪里可以看到| 国产一区成人在线观看视频| 欧美黄片精彩在线免费观看| 超碰公开大香蕉97| 国产精品sm调教视频| 人妻少妇亚洲一区二区| 国际av大片在线免费观看| 国产成人小视频在线观看无遮挡| 久久精品国产999| 蜜桃色婷婷久久久福利在线| 91福利视频免费在线观看| 2017亚洲男人天堂| 一区二区熟女人妻视频| 精品久久久久久高潮| 中文字幕欧美日韩射射一| 粉嫩av懂色av蜜臀av| 久久美欧人妻少妇一区二区三区| 国内自拍第一页在线观看| 日本女人一级免费片| 操的小逼流水的文章| 狠狠躁狠狠爱网站视频| 国产精品一区二区三区蜜臀av| 91国产在线免费播放| 在线视频免费观看网| 丝袜亚洲另类欧美变态| 青青热久免费精品视频在线观看| 19一区二区三区在线播放| 男人和女人激情视频| 天天躁夜夜躁日日躁a麻豆| 亚洲卡1卡2卡三卡四老狼| 国产精品三级三级三级| 女蜜桃臀紧身瑜伽裤| 国产三级片久久久久久久| 夜夜骑夜夜操夜夜奸| 黄片三级三级三级在线观看| 91免费福利网91麻豆国产精品| 中文字幕AV在线免费看 | 91麻豆精品久久久久| 中文字幕日韩人妻在线三区| 亚洲少妇人妻无码精品| 中文字幕网站你懂的| 国产白袜脚足J棉袜在线观看| 亚洲精品午夜aaa久久| 日韩二区视频一线天婷婷五| 天天操天天弄天天射| 久久久久久久亚洲午夜综合福利| 521精品视频在线观看| 日本阿v视频在线免费观看| 一区二区熟女人妻视频| 黄色片黄色片wyaa| 日本少妇精品免费视频| 91中文字幕免费在线观看| 欧美一区二区三区激情啪啪啪| 亚洲国产在人线放午夜| 天堂av在线官网中文| 亚洲中文字字幕乱码| 青青青青在线视频免费观看| 国产福利小视频大全| 五色婷婷综合狠狠爱| 黑人3p华裔熟女普通话| 自拍偷拍亚洲另类色图| 岛国毛片视频免费在线观看| 九色porny九色9l自拍视频| 男生舔女生逼逼的视频| 亚洲av成人免费网站| 亚洲av自拍偷拍综合| 中文字幕1卡1区2区3区| 成人久久精品一区二区三区| 欧美成人黄片一区二区三区| 黄色的网站在线免费看| 91香蕉成人app下载| 亚洲高清国产拍青青草原| 亚洲高清国产拍青青草原| 中文字幕人妻三级在线观看| 亚洲午夜伦理视频在线| 51国产偷自视频在线播放| 91免费观看国产免费| 日韩三级电影华丽的外出| 2025年人妻中文字幕乱码在线| 亚洲欧美国产综合777| 蜜桃臀av蜜桃臀av| 亚洲国产在人线放午夜| 啊用力插好舒服视频| 韩国三级aaaaa高清视频| 精品国产污污免费网站入口自| 只有精品亚洲视频在线观看| 久久久久国产成人精品亚洲午夜| 久久精品国产23696| 亚洲 国产 成人 在线| 久久精品在线观看一区二区| 91天堂精品一区二区| 欧美第一页在线免费观看视频| 97欧洲一区二区精品免费| 免费一级特黄特色大片在线观看| 狍和女人的王色毛片| 中文字幕在线一区精品| 91成人精品亚洲国产| 啊啊好慢点插舔我逼啊啊啊视频| 一区国内二区日韩三区欧美| 区一区二区三国产中文字幕| 一区二区三区日本伦理| 午夜精品一区二区三区更新| 中国把吊插入阴蒂的视频| 国产精品视频男人的天堂| 欧美精品 日韩国产| 欧美亚洲少妇福利视频| 国产麻豆剧传媒精品国产av蜜桃| 巨乳人妻日下部加奈被邻居中出| 日韩成人性色生活片| 一区二区三区另类在线| 美女被肏内射视频网站| 国产午夜福利av导航| 久久精品36亚洲精品束缚| 欧美aa一级一区三区四区| 青青草精品在线视频观看| 91九色porny国产蝌蚪视频| 欧美地区一二三专区| 干逼又爽又黄又免费的视频| 精品一区二区三区三区色爱| 91av精品视频在线| 人妻久久无码中文成人| 自拍 日韩 欧美激情| 国产美女午夜福利久久| 97人妻总资源视频| 阴茎插到阴道里面的视频| 青青青视频自偷自拍38碰| 好男人视频在线免费观看网站| 精品亚洲在线免费观看| 99精品免费久久久久久久久a| 日本少妇人妻xxxxx18| 白嫩白嫩美女极品国产在线观看| 亚洲国产成人最新资源| 天天做天天干天天操天天射| 2020中文字幕在线播放| 9l人妻人人爽人人爽| 青青草精品在线视频观看| 成人在线欧美日韩国产| 91高清成人在线视频| 日韩欧美国产精品91| 国产精品国产三级国产精东| 久久这里只有精彩视频免费| 亚洲伊人av天堂有码在线| 91麻豆精品秘密入口在线观看| 亚洲av自拍天堂网| 边摸边做超爽毛片18禁色戒 | av一本二本在线观看| 人妻少妇中文有码精品| 3D动漫精品啪啪一区二区下载| 啪啪啪啪啪啪啪啪啪啪黄色| 国产夫妻视频在线观看免费| 欧美香蕉人妻精品一区二区| 国产黄色大片在线免费播放| 欧美综合婷婷欧美综合| 天天干天天操天天玩天天射| 国产黄色a级三级三级三级| 精品一区二区三区欧美| 亚洲1069综合男同| 日韩三级电影华丽的外出| 大香蕉日本伊人中文在线| 丝袜国产专区在线观看| 综合激情网激情五月五月婷婷| 国产精品女邻居小骚货| 成人18禁网站在线播放| 亚洲福利午夜久久久精品电影网 | 亚洲 欧美 精品 激情 偷拍| 亚洲一级特黄特黄黄色录像片| 日韩二区视频一线天婷婷五| 一区二区三区综合视频| 97国产在线观看高清| 91精品国产观看免费| 热久久只有这里有精品| 57pao国产一区二区| aiss午夜免费视频| 男女啪啪视频免费在线观看| 九一传媒制片厂视频在线免费观看 | 国产在线91观看免费观看| 中出中文字幕在线观看| 夜色17s精品人妻熟女| 99热色原网这里只有精品| 福利一二三在线视频观看| 午夜免费观看精品视频| 日韩剧情片电影在线收看| 一级黄片大鸡巴插入美女| 日韩在线中文字幕色| 亚洲精品色在线观看视频| 18禁美女羞羞免费网站| 欧美精品资源在线观看| 青娱乐蜜桃臀av色| 久精品人妻一区二区三区| 2022精品久久久久久中文字幕| 天天干夜夜操天天舔| 不卡日韩av在线观看| 人人人妻人人澡人人| 成人性黑人一级av| 中文字幕最新久久久| 国产91精品拍在线观看| 亚洲一区二区三区精品视频在线 | 中文字幕一区二区自拍| 人人妻人人爽人人澡人人精品| 亚洲午夜高清在线观看| 日韩国产乱码中文字幕| 欧美久久久久久三级网| 日韩欧美在线观看不卡一区二区| 黑人大几巴狂插日本少妇| 人妻无码色噜噜狠狠狠狠色| www日韩a级s片av| 国产麻豆剧传媒精品国产av蜜桃| 2021天天色天天干| 欧美xxx成人在线| 欧美精品一区二区三区xxxx| 一区二区三区久久久91| 粉嫩小穴流水视频在线观看| 在线网站你懂得老司机| 精品人妻伦一二三区久| 国产一区av澳门在线观看| 性色av一区二区三区久久久 | 日韩美av高清在线| 天天色天天舔天天射天天爽| av中文字幕福利网| 久久精品在线观看一区二区| 午夜在线一区二区免费| 亚洲中文字字幕乱码| 亚洲av无乱一区二区三区性色| 熟女人妻三十路四十路人妻斩| 91人妻人人做人人爽在线| 2022精品久久久久久中文字幕| 国产又粗又猛又爽又黄的视频在线 | 亚洲一级av大片免费观看| 国产精品中文av在线播放| 国产日韩一区二区在线看| 黑人解禁人妻叶爱071| 色哟哟在线网站入口| 熟女妇女老妇一二三区| 揄拍成人国产精品免费看视频 | 在线免费观看国产精品黄色| 女同互舔一区二区三区| 欧美xxx成人在线| 新97超碰在线观看| 91高清成人在线视频| 亚洲伊人久久精品影院一美女洗澡| 在线免费91激情四射| 天天干夜夜操天天舔| 最新欧美一二三视频| 日本熟妇色熟妇在线观看| 骚逼被大屌狂草视频免费看| 涩涩的视频在线观看视频| 亚洲av可乐操首页| 大学生A级毛片免费视频| 亚洲国产成人无码麻豆艾秋| 9久在线视频只有精品| 啊用力插好舒服视频| 2025年人妻中文字幕乱码在线| 久久久91蜜桃精品ad| 欧美日韩不卡一区不区二区| 天堂资源网av中文字幕| 亚洲av日韩av网站| 大胆亚洲av日韩av| 国产无遮挡裸体免费直播视频| 91香蕉成人app下载| 欧美综合婷婷欧美综合| 偷拍自拍国产在线视频| 亚洲第一黄色在线观看| 亚洲精品麻豆免费在线观看| 国产精品伦理片一区二区| 亚洲一区二区三区在线高清| 中文字幕中文字幕 亚洲国产| 黄色无码鸡吧操逼视频| 国产视频一区二区午夜| 成年午夜免费无码区| 日韩北条麻妃一区在线| 中文字幕国产专区欧美激情| 黄色黄色黄片78在线| 国产精品熟女久久久久浪潮| 欧美一级视频一区二区| 日日夜夜大香蕉伊人| 欧美激情精品在线观看| 91片黄在线观看喷潮| 91p0rny九色露脸熟女| 亚洲少妇高潮免费观看| 91亚洲手机在线视频播放| 国产使劲操在线播放| 免费费一级特黄真人片| 日本精品视频不卡一二三| 久久麻豆亚洲精品av| 黑人性生活视频免费看| 亚洲公开视频在线观看| av在线资源中文字幕| 国产精彩福利精品视频| 91精品视频在线观看免费| 88成人免费av网站| 老司机99精品视频在线观看| 在线视频国产欧美日韩| 欧美视频不卡一区四区| 青青青青青青青青青青草青青| 久久精品国产999| 欧美日韩不卡一区不区二区| 亚洲国产欧美一区二区丝袜黑人| 成年人啪啪视频在线观看| weyvv5国产成人精品的视频| 美女骚逼日出水来了| 操操网操操伊剧情片中文字幕网| 日本18禁久久久久久| 777奇米久久精品一区| 日韩在线中文字幕色| 91she九色精品国产| sejizz在线视频| 国产亚洲成人免费在线观看| 91av中文视频在线| 青青青青草手机在线视频免费看| 适合午夜一个人看的视频| 亚洲最大黄了色网站| 99精品国产自在现线观看| 日韩精品一区二区三区在线播放| 欧洲国产成人精品91铁牛tv| 国产精品国色综合久久| 五十路熟女人妻一区二区9933| 亚洲va国产va欧美va在线| 91社福利《在线观看| 亚洲免费在线视频网站| 欧美性受xx黑人性猛交| 黄色大片免费观看网站| 亚洲丝袜老师诱惑在线观看| h国产小视频福利在线观看| 美女吃鸡巴操逼高潮视频| 五月天中文字幕内射| 精品久久久久久久久久久久人妻| 97精品人妻一区二区三区精品| 不卡日韩av在线观看| 国产实拍勾搭女技师av在线| 绝顶痉挛大潮喷高潮无码| 国产亚洲成人免费在线观看 | 天天日天天天天天天天天天天| 国产欧美精品一区二区高清| 天美传媒mv视频在线观看| 最新97国产在线视频| 超碰公开大香蕉97| 中文人妻AV久久人妻水| 蜜桃久久久久久久人妻| 少妇高潮一区二区三区| 亚洲综合色在线免费观看| 欧美一区二区三区乱码在线播放 | 天天操天天爽天天干| 婷婷色中文亚洲网68| 又色又爽又黄又刺激av网站| 精品黑人一区二区三区久久国产| 伊人日日日草夜夜草| 自拍偷拍亚洲欧美在线视频| 精品视频中文字幕在线播放 | 在线不卡成人黄色精品| 五十路熟女人妻一区二| 久草视频在线一区二区三区资源站 | 成人动漫大肉棒插进去视频| 成年午夜影片国产片| 日本丰满熟妇大屁股久久| 中文字幕人妻被公上司喝醉在线| 国产使劲操在线播放| 欧美综合婷婷欧美综合| 中文字幕人妻被公上司喝醉在线| 沈阳熟妇28厘米大战黑人| 一区二区三区麻豆福利视频| 久久久久久九九99精品| av天堂加勒比在线| 日本黄在免费看视频| 国产亚洲精品视频合集| 色av色婷婷人妻久久久精品高清 | 国产1区,2区,3区| 2022中文字幕在线| 欧美激情电影免费在线| 五月精品丁香久久久久福利社| 女蜜桃臀紧身瑜伽裤| 五十路熟女人妻一区二| 五十路丰满人妻熟妇| 小穴多水久久精品免费看| 99精品国产aⅴ在线观看| 特黄老太婆aa毛毛片| 78色精品一区二区三区| av老司机亚洲一区二区| 欧美日韩在线精品一区二区三| 9国产精品久久久久老师| 婷婷五月亚洲综合在线| 青青青青青操视频在线观看| 一区二区视频在线观看免费观看| 97小视频人妻一区二区| 中文字幕国产专区欧美激情| 视频 一区二区在线观看| 农村胖女人操逼视频| 91‖亚洲‖国产熟女| 日本脱亚入欧是指什么| 2022精品久久久久久中文字幕| 91人妻精品久久久久久久网站 | 欧美黑人与人妻精品| 黄色中文字幕在线播放| 久草视频在线看免费| 把腿张开让我插进去视频 | 日韩无码国产精品强奸乱伦| 国产成人无码精品久久久电影| 日本韩国亚洲综合日韩欧美国产| 少妇高潮无套内谢麻豆| 色花堂在线av中文字幕九九| 特一级特级黄色网片| 91快播视频在线观看| 青娱乐极品视频青青草| japanese日本熟妇另类| 国产精品久久9999| 亚洲熟女久久久36d| 免费看高清av的网站| 亚洲国产精品久久久久久6| 中国熟女@视频91| 亚洲图库另类图片区| 同居了嫂子在线播高清中文| 91久久国产成人免费网站| 中文字母永久播放1区2区3区| 精品久久久久久久久久久a√国产| 一区二区三区av高清免费| 国内资源最丰富的网站| av日韩在线免费播放| 天天日天天爽天天干| 沙月文乃人妻侵犯中文字幕在线| 国产性色生活片毛片春晓精品| 久久丁香婷婷六月天| 中文字幕第三十八页久久| 91快播视频在线观看| 香港三日本三韩国三欧美三级| 狠狠地躁夜夜躁日日躁| 亚洲精品 日韩电影| 黑人3p华裔熟女普通话| 黄色在线观看免费观看在线| 亚洲一级av无码一级久久精品| 人妻无码色噜噜狠狠狠狠色| 亚洲精品一区二区三区老狼| 91九色国产熟女一区二区| 1769国产精品视频免费观看| 久久久久五月天丁香社区| 国产成人一区二区三区电影网站 | 熟女人妻在线观看视频| 精品区一区二区三区四区人妻 | 66久久久久久久久久久| 国产精品自偷自拍啪啪啪| jiuse91九色视频| 亚洲色偷偷综合亚洲AV伊人| 国产精品3p和黑人大战| 在线免费观看欧美小视频| 成年人黄色片免费网站| 亚洲av男人的天堂你懂的| 成人精品视频99第一页| 搡老妇人老女人老熟女| 久久免看30视频口爆视频| 成人av在线资源网站| 国产亚洲视频在线二区| 欧美日本国产自视大全| 国产夫妻视频在线观看免费| 大尺度激情四射网站| 男女之间激情网午夜在线| 久久久久久99国产精品| 欧美黑人性暴力猛交喷水| 午夜青青草原网在线观看| 搞黄色在线免费观看| 免费在线播放a级片| 欧美黑人性暴力猛交喷水| 天堂中文字幕翔田av| 男大肉棒猛烈插女免费视频| 国产三级精品三级在线不卡| 中文字幕人妻一区二区视频| 国产福利在线视频一区| 日日夜夜精品一二三| 午夜在线精品偷拍一区二| 亚洲一区av中文字幕在线观看| 国产精品免费不卡av| 噜噜色噜噜噜久色超碰| 国产福利小视频免费观看| 国产精品污污污久久| 插小穴高清无码中文字幕| 亚洲va天堂va国产va久| 精品久久久久久久久久中文蒉| av成人在线观看一区| 精品美女在线观看视频在线观看| 亚洲午夜在线视频福利| 天天摸天天日天天操| 亚洲一区二区三区偷拍女厕91| 色综合久久无码中文字幕波多| 激情综合治理六月婷婷| 97精品成人一区二区三区| 日本女人一级免费片| 把腿张开让我插进去视频| 任我爽精品视频在线播放| 免费福利av在线一区二区三区| 一级黄片久久久久久久久| 亚洲成人情色电影在线观看| 日本后入视频在线观看| 中文字幕之无码色多多| 亚洲精品色在线观看视频| 天天色天天操天天舔| 欧美3p在线观看一区二区三区| 日韩黄色片在线观看网站| 只有精品亚洲视频在线观看| 狠狠躁夜夜躁人人爽天天天天97| 久久热这里这里只有精品| 大香蕉玖玖一区2区| 日本一二三中文字幕| 精品视频一区二区三区四区五区| 黄片三级三级三级在线观看| 欧美日本aⅴ免费视频| 天天干天天啪天天舔| 99精品国产自在现线观看| 青草亚洲视频在线观看| 国产日本欧美亚洲精品视| 亚洲福利午夜久久久精品电影网| 国产性生活中老年人视频网站| 亚洲美女自偷自拍11页| 日韩加勒比东京热二区| 午夜精品久久久久麻豆影视| 中文字幕之无码色多多| 青青青视频自偷自拍38碰| 熟妇一区二区三区高清版| 91试看福利一分钟| 91老师蜜桃臀大屁股| 亚洲 欧美 精品 激情 偷拍| 精品美女久久久久久| 中文 成人 在线 视频| 天天摸天天亲天天舔天天操天天爽| 制丝袜业一区二区三区| 亚洲国产欧美一区二区三区久久| 91极品新人『兔兔』精品新作| 熟女视频一区,二区,三区| 伊人综合免费在线视频| 1769国产精品视频免费观看| 欧美aa一级一区三区四区| 青青热久免费精品视频在线观看 | 可以在线观看的av中文字幕| 好男人视频在线免费观看网站| 久久www免费人成一看片| 黄色片年轻人在线观看| 欧美韩国日本国产亚洲| 少妇人妻真实精品视频| 自拍偷拍日韩欧美亚洲| 日韩二区视频一线天婷婷五| 在线观看免费岛国av| 直接能看的国产av| 99热碰碰热精品a中文| 蜜桃久久久久久久人妻| 香港三日本三韩国三欧美三级| 懂色av蜜桃a v| 成人综合亚洲欧美一区| 日日爽天天干夜夜操| 91在线免费观看成人| 亚洲天堂有码中文字幕视频| 91精品免费久久久久久| 久久久久只精品国产三级| 午夜免费观看精品视频| 日韩三级黄色片网站| 国产亚州色婷婷久久99精品| 黄色中文字幕在线播放| 大香蕉福利在线观看| 人妻丝袜榨强中文字幕| 亚洲福利精品视频在线免费观看| 欧美viboss性丰满| 欧美国品一二三产区区别| 绝顶痉挛大潮喷高潮无码| 日韩av熟妇在线观看| 国产麻豆91在线视频| 人妻无码中文字幕专区| 北条麻妃肉色丝袜视频| 日本韩国亚洲综合日韩欧美国产| 超碰公开大香蕉97| 欧美中文字幕一区最新网址| 日韩二区视频一线天婷婷五| 久久久制服丝袜中文字幕| 亚洲精品高清自拍av| 欧美日本国产自视大全| 亚洲午夜精品小视频| 亚洲天堂精品福利成人av| 岛国青草视频在线观看| 亚洲第17页国产精品| 亚洲第一伊人天堂网| 国产一区二区久久久裸臀| 亚洲成人激情视频免费观看了| 亚洲综合乱码一区二区| 丰满的子国产在线观看| 免费av岛国天堂网站| 影音先锋女人av噜噜色| 天天操天天干天天插| 99热国产精品666| 欧美精品久久久久久影院| 91精品国产91青青碰| 国产麻豆剧果冻传媒app| 美女福利视频网址导航| 亚洲熟妇久久无码精品| 国产在线观看免费人成短视频| 午夜av一区二区三区| 丰满的子国产在线观看| 少妇人妻二三区视频| 在线观看日韩激情视频| 日韩精品电影亚洲一区| 韩国男女黄色在线观看| 黄色黄色黄片78在线| 中文字幕欧美日韩射射一| 18禁精品网站久久| 国产女人被做到高潮免费视频| 天天操天天操天天碰| 在线观看操大逼视频| 日本高清在线不卡一区二区| 极品性荡少妇一区二区色欲| 欧美一区二区三区激情啪啪啪| 性色av一区二区三区久久久| 91久久综合男人天堂| 日本黄在免费看视频| 精品美女在线观看视频在线观看| 中文字幕在线乱码一区二区| 五月天色婷婷在线观看视频免费| 一区二区三区日韩久久| 最新国产精品网址在线观看| 国产 在线 免费 精品| 中文字幕日韩无敌亚洲精品| 亚洲女人的天堂av| 午夜毛片不卡免费观看视频| 91免费观看国产免费| 亚洲一级特黄特黄黄色录像片| 日本美女性生活一级片| 偷拍自拍 中文字幕| 国产黄色片蝌蚪九色91| 四川五十路熟女av| 亚洲高清免费在线观看视频| 国产 在线 免费 精品| 国产又粗又猛又爽又黄的视频美国| 韩国男女黄色在线观看| 自拍偷拍日韩欧美亚洲| 一本久久精品一区二区| 在线可以看的视频你懂的| 免费在线福利小视频| 欧美色呦呦最新网址| 91精品激情五月婷婷在线| 日韩在线中文字幕色| 亚洲第一黄色在线观看| 91亚洲国产成人精品性色| 天天操夜夜操天天操天天操| 日本美女成人在线视频| 青青青aaaa免费| 国产精品伦理片一区二区| 玩弄人妻熟妇性色av少妇| 欧美成人综合视频一区二区| 亚洲综合在线观看免费| 成年美女黄网站18禁久久| 熟女俱乐部一二三区| 一区二区三区在线视频福利| 国产免费高清视频视频| 男人天堂色男人av| 啊啊好大好爽啊啊操我啊啊视频 | 视频二区在线视频观看| 视频久久久久久久人妻| 亚洲码av无色中文| 老司机在线精品福利视频| 青娱乐最新视频在线| 国产日韩精品一二三区久久久| 偷拍自拍 中文字幕| 亚洲综合色在线免费观看| av破解版在线观看| 亚洲男人让女人爽的视频| 人妻自拍视频中国大陆| 大学生A级毛片免费视频| 18禁免费av网站| 51国产成人精品视频| 啊啊啊想要被插进去视频| 日日夜夜精品一二三| 中文字幕免费福利视频6| 在线制服丝袜中文字幕| 干逼又爽又黄又免费的视频| 精品美女久久久久久| 91大神福利视频网| 久久这里只有精品热视频| 九一传媒制片厂视频在线免费观看| 3D动漫精品啪啪一区二区下载| 青草亚洲视频在线观看| 国产一区成人在线观看视频| 97超碰国语国产97超碰| 国产又粗又黄又硬又爽| 特大黑人巨大xxxx| 青青青青青免费视频| 最新国产亚洲精品中文在线| 亚洲国产香蕉视频在线播放| 五月色婷婷综合开心网4438| 2017亚洲男人天堂| 欧美美女人体视频一区| 中文字幕欧美日韩射射一| 啪啪啪啪啪啪啪啪av| 亚洲男人的天堂a在线| 成人sm视频在线观看| 国产乱弄免费视频观看| 精品亚洲中文字幕av| 国产视频精品资源网站| 精品人妻一二三区久久| 在线不卡成人黄色精品| 国产无遮挡裸体免费直播视频| 久久久91蜜桃精品ad| 大尺度激情四射网站| 婷婷五月亚洲综合在线| 一二三区在线观看视频| 天天干狠狠干天天操| 亚洲第一黄色在线观看| 亚洲免费福利一区二区三区| 97黄网站在线观看| 国产普通话插插视频| 老有所依在线观看完整版| 女同久久精品秋霞网| 美女福利视频网址导航| 美女福利写真在线观看视频| 涩涩的视频在线观看视频| 亚洲欧美清纯唯美另类| 福利视频网久久91| 动漫av网站18禁| 青春草视频在线免费播放| 国产一区二区久久久裸臀| 国产品国产三级国产普通话三级| huangse网站在线观看| 久久久久只精品国产三级| 风流唐伯虎电视剧在线观看| 亚洲1卡2卡三卡4卡在线观看 | 国产日韩精品一二三区久久久| 精品首页在线观看视频| free性日本少妇| 在线观看视频网站麻豆| 又粗又长 明星操逼小视频| 成人蜜桃美臀九一一区二区三区| 精品人妻一二三区久久| 亚洲精品国偷自产在线观看蜜桃| 熟女人妻在线观看视频| 男人操女人逼逼视频网站| 人妻av无码专区久久绿巨人 | 欧美精品亚洲精品日韩在线| 91九色porny蝌蚪国产成人| 老司机你懂得福利视频| 91传媒一区二区三区| 人妻丝袜av在线播放网址| 97黄网站在线观看| 久久午夜夜伦痒痒想咳嗽P| 中文字幕成人日韩欧美| 欧美一区二区三区高清不卡tv| 色天天天天射天天舔| 亚洲av一妻不如妾| 动色av一区二区三区| 人妻另类专区欧美制服| 国产精品视频欧美一区二区| 久久久久久久亚洲午夜综合福利| 精品一区二区三区三区色爱| 成人av免费不卡在线观看| 无码日韩人妻精品久久| 男人的天堂av日韩亚洲| av大全在线播放免费| av破解版在线观看| 偷拍自拍国产在线视频| 亚洲成a人片777777| 蜜桃色婷婷久久久福利在线| 五十路在线观看完整版| 少妇人妻久久久久视频黄片| 自拍偷拍亚洲精品第2页| 欧美视频中文一区二区三区| 国产精彩对白一区二区三区| 中文字幕综合一区二区| 春色激情网欧美成人| 色综合色综合色综合色| 国产精品黄色的av| 亚洲另类在线免费观看| 91久久精品色伊人6882| 99精品久久久久久久91蜜桃| 国产一区二区三免费视频| 亚洲av黄色在线网站| 中文字幕一区二区人妻电影冢本 | 亚洲成人激情av在线| 欧美精品 日韩国产| 日韩视频一区二区免费观看| 亚洲精品中文字幕下载| 亚洲av无乱一区二区三区性色| 91精品国产91久久自产久强| 国产日韩精品一二三区久久久 | 欧美精品资源在线观看| 99精品国产自在现线观看| 中文字幕在线乱码一区二区| 美味人妻2在线播放| www天堂在线久久| 日韩av熟妇在线观看| 欧美国产亚洲中英文字幕| 青青伊人一精品视频| 国产丰满熟女成人视频| 高清一区二区欧美系列| 亚洲一级 片内射视正片| 日韩精品电影亚洲一区| 91超碰青青中文字幕| 亚洲精品 日韩电影| 亚洲国产精品美女在线观看| h国产小视频福利在线观看| 久久久久久久精品老熟妇| 中文字幕 码 在线视频| 天天干天天操天天扣| 视频 一区二区在线观看| 国产精品国色综合久久| 啊啊啊想要被插进去视频| 偷拍自拍视频图片免费| 乱亲女秽乱长久久久| 久久精品亚洲国产av香蕉| 国产成人精品一区在线观看| 免费在线观看视频啪啪| 精产国品久久一二三产区区别| 91精品综合久久久久3d动漫 | www日韩毛片av| 中国老熟女偷拍第一页| 超级av免费观看一区二区三区| 99国内小视频在现欢看| 日日日日日日日日夜夜夜夜夜夜| 蜜臀av久久久久久久| chinese国产盗摄一区二区| av网址国产在线观看| 操人妻嗷嗷叫视频一区二区| 国产欧美精品免费观看视频| 午夜激情久久不卡一区二区| 高清成人av一区三区| 一级黄色av在线观看| 久久永久免费精品人妻专区| 亚洲人成精品久久久久久久| 97精品成人一区二区三区| 日韩av大胆在线观看| 在线不卡日韩视频播放| 蜜桃色婷婷久久久福利在线| 91麻豆精品久久久久| 51国产成人精品视频| 国产一区自拍黄视频免费观看| 93人妻人人揉人人澡人人| 99热99这里精品6国产| 97小视频人妻一区二区| 欧美va不卡视频在线观看| 麻豆性色视频在线观看| 国产乱子伦一二三区| 伊人成人综合开心网| 日本人妻少妇18—xx| 亚洲 欧美 精品 激情 偷拍 | 黄色资源视频网站日韩| 亚洲第一黄色在线观看| 高清成人av一区三区| 夜夜骑夜夜操夜夜奸| 岛国av高清在线成人在线| 福利视频广场一区二区| 亚洲国际青青操综合网站| 亚洲精品乱码久久久本| 黄色男人的天堂视频| 涩爱综合久久五月蜜臀| 91天堂天天日天天操| 国产污污污污网站在线| 老司机免费视频网站在线看| 一区二区在线观看少妇| 极品性荡少妇一区二区色欲| 激情图片日韩欧美人妻| 在线观看国产网站资源| 女生自摸在线观看一区二区三区| 亚洲熟女久久久36d| av成人在线观看一区| av在线免费资源站| 中国熟女@视频91| 日韩亚洲高清在线观看| 精品美女久久久久久| 中文字幕 亚洲av| 国产卡一卡二卡三乱码手机| 中文字幕av熟女人妻| 在线观看一区二区三级| 成人av天堂丝袜在线观看| 美女视频福利免费看| 黄色视频成年人免费观看| 一区二区三区蜜臀在线| 日本高清成人一区二区三区| 韩国一级特黄大片做受| 动漫美女的小穴视频| 亚洲一级特黄特黄黄色录像片| 欧美日本国产自视大全| 亚洲美女高潮喷浆视频| 女警官打开双腿沦为性奴| 亚洲国产美女一区二区三区软件| 19一区二区三区在线播放| 日韩美在线观看视频黄| 精品亚洲国产中文自在线| 成人伊人精品色xxxx视频| 在线视频精品你懂的| 性欧美激情久久久久久久| 亚洲色偷偷综合亚洲AV伊人| 国产精品国产精品一区二区| 青青在线视频性感少妇和隔壁黑丝| 特大黑人巨大xxxx| 国产三级精品三级在线不卡| 在线观看成人国产电影| 免费观看污视频网站| 在线播放一区二区三区Av无码| 日本18禁久久久久久| 亚洲av一妻不如妾| 国产av国片精品一区二区| 99一区二区在线观看| 日韩中文字幕在线播放第二页| rct470中文字幕在线| 2021久久免费视频| 欧美一区二区三区四区性视频| 97国产福利小视频合集| 久久免看30视频口爆视频| 久久热这里这里只有精品| 久久永久免费精品人妻专区 | 新97超碰在线观看| 青青草原色片网站在线观看| 免费人成黄页网站在线观看国产| 欧美精品 日韩国产| 久久www免费人成一看片| 青青社区2国产视频| 日本免费一级黄色录像 | 首之国产AV医生和护士小芳| 国产使劲操在线播放| 熟女妇女老妇一二三区| 日韩三级黄色片网站| 成年人啪啪视频在线观看| 亚洲视频在线观看高清| 色天天天天射天天舔| 很黄很污很色的午夜网站在线观看| 久久久久久久久久性潮| 国产三级片久久久久久久| 红杏久久av人妻一区| 日韩精品啪啪视频一道免费| 免费av岛国天堂网站| gav成人免费播放| 在线免费观看亚洲精品电影| 人妻丝袜精品中文字幕| 亚洲第一黄色在线观看| 欧美视频综合第一页| 国产精品污污污久久| 日韩不卡中文在线视频网站| 成人伊人精品色xxxx视频| 日韩欧美亚洲熟女人妻| 大香蕉大香蕉在线看| 欧美性感尤物人妻在线免费看| 亚洲av日韩精品久久久| 啪啪啪啪啪啪啪啪av| 美女张开两腿让男人桶av| 大陆胖女人与丈夫操b国语高清 | 2021年国产精品自拍| 自拍偷区二区三区麻豆| 欧美黄片精彩在线免费观看| 亚洲人妻国产精品综合| av中文字幕国产在线观看| 欧美日韩中文字幕欧美| 人妻少妇精品久久久久久| 3D动漫精品啪啪一区二区下载| 亚洲天天干 夜夜操| 国产成人无码精品久久久电影| 99精品国自产在线人| 年轻的人妻被夫上司侵犯| 亚洲成人激情av在线| 亚洲区美熟妇久久久久| 亚洲av黄色在线网站| 成人性黑人一级av| 亚国产成人精品久久久| 国产成人午夜精品福利| 大白屁股精品视频国产| 伊拉克及约旦宣布关闭领空| 成人30分钟免费视频| 亚洲综合自拍视频一区| 日本高清成人一区二区三区| 在线免费观看亚洲精品电影| 亚洲偷自拍高清视频| 5528327男人天堂| 国产一级麻豆精品免费| jiujiure精品视频在线| 三级等保密码要求条款| 涩涩的视频在线观看视频| av天堂资源最新版在线看| 曰本无码人妻丰满熟妇啪啪| 噜噜色噜噜噜久色超碰| 精品高跟鞋丝袜一区二区| 亚洲一区二区三区精品乱码| 少妇被强干到高潮视频在线观看| 粗大的内捧猛烈进出爽大牛汉子| 视频在线免费观看你懂得| 青青青青操在线观看免费| 成人综合亚洲欧美一区| 久久精品美女免费视频| 久久美欧人妻少妇一区二区三区| 天堂av在线官网中文| 中文字幕欧美日韩射射一| 爆乳骚货内射骚货内射在线 | 午夜精品一区二区三区城中村| 不卡精品视频在线观看| 91高清成人在线视频| 成年人啪啪视频在线观看| 亚洲美女美妇久久字幕组| 天天日天天透天天操| 亚洲 欧美 自拍 偷拍 在线| 97国产福利小视频合集| 欧美亚洲牲夜夜综合久久| 夜色撩人久久7777| 日韩不卡中文在线视频网站| 91极品大一女神正在播放| 经典亚洲伊人第一页| 91九色porny国产在线| 亚洲1069综合男同| 福利国产视频在线观看| 女生被男生插的视频网站| 欧美天堂av无线av欧美| av中文字幕电影在线看| 国产精彩对白一区二区三区| 国际av大片在线免费观看| 3D动漫精品啪啪一区二区下载| 免费十精品十国产网站| 精品久久婷婷免费视频| 久久久精品999精品日本| 五月婷婷在线观看视频免费| 色综合天天综合网国产成人| 91p0rny九色露脸熟女| 亚洲国产最大av综合| 成人乱码一区二区三区av| 97年大学生大白天操逼| 成人性黑人一级av| 天天操天天干天天艹| 91超碰青青中文字幕| 在线播放国产黄色av| 久草视频首页在线观看| 国产又粗又黄又硬又爽| 亚洲国产在人线放午夜| 国产黄色片蝌蚪九色91| 91极品新人『兔兔』精品新作| 女生被男生插的视频网站| 在线视频免费观看网| 91在线免费观看成人| 啪啪啪18禁一区二区三区| av完全免费在线观看av| 成人sm视频在线观看| 亚洲综合在线观看免费| 888欧美视频在线| 日本人妻欲求不满中文字幕| 日韩无码国产精品强奸乱伦| 欧美天堂av无线av欧美| 免费高清自慰一区二区三区网站| 欧美成人综合色在线噜噜| 九色精品视频在线播放| 成年人黄色片免费网站| 色综合色综合色综合色| 成人午夜电影在线观看 久久| 欧美视频不卡一区四区| 久久精品36亚洲精品束缚| 很黄很污很色的午夜网站在线观看 | 日韩av中文在线免费观看| 青娱乐蜜桃臀av色| a v欧美一区=区三区| 一区二区三区四区中文| 亚洲成人精品女人久久久| 亚洲第一黄色在线观看| 国产精品福利小视频a| 国产普通话插插视频| 人妻另类专区欧美制服| 中文字幕人妻三级在线观看| 动漫av网站18禁| 亚洲一区二区三区精品视频在线 | 国产精品熟女久久久久浪潮| 亚洲卡1卡2卡三卡四老狼| 亚洲国际青青操综合网站| 人妻av无码专区久久绿巨人| ka0ri在线视频| 亚洲欧美综合另类13p| 337p日本大胆欧美人| 91麻豆精品传媒国产黄色片| av中文字幕网址在线| 男生用鸡操女生视频动漫| 天天干天天日天天干天天操| 中文字幕一区二区自拍| av乱码一区二区三区| 亚洲 国产 成人 在线| 国产普通话插插视频| 18禁无翼鸟成人在线| 亚洲av无女神免非久久| 国产91精品拍在线观看| 天天摸天天干天天操科普| 日本熟妇喷水xxx| 欧美viboss性丰满| 欧美亚洲免费视频观看| 青春草视频在线免费播放| 二区中出在线观看老师| 久久久久久99国产精品| 福利视频广场一区二区| av网站色偷偷婷婷网男人的天堂| 青青草在观免费国产精品| 欧美黑人性猛交xxxxⅹooo| 欧美亚洲偷拍自拍色图| 国产精品中文av在线播放| 岛国免费大片在线观看| 男人的天堂在线黄色| 最新91精品视频在线| 国产综合视频在线看片| 亚洲一区二区久久久人妻| 色综合久久无码中文字幕波多| 丝袜美腿欧美另类 中文字幕| 狠狠的往里顶撞h百合| 五十路熟女人妻一区二| 国内资源最丰富的网站|