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

Eclipse+Java+Swing實現圖書管理系統(tǒng)(詳細代碼)

 更新時間:2022年01月26日 16:36:08   作者:水堅石青?  
這篇文章主要介紹了Eclipse+Java+Swing實現圖書管理系統(tǒng)并附上詳細代碼,需要的小伙伴可以參考一下,希望對你有所幫助

一、系統(tǒng)介紹

該系統(tǒng)實現用戶注冊登錄功能。用戶端實現書籍查詢,借書,還書功能。用戶能夠查詢自己的借書記錄。管理員能夠上架圖書,下架圖書,添加圖書類別,修改圖書類別,刪除圖書類別,添加圖書信息,修改圖書信息,修改用戶信息,查詢圖書借閱歸還記錄。

二、系統(tǒng)展示

1.注冊

2.登錄

3.用戶端-圖書查詢及借閱

4.用戶端-借閱記錄及歸還

5.管理員端-添加圖書類別

6.管理員端-修改圖書類別

7.管理員端-添加圖書

8.管理員端-修改圖書

9.管理員端-管理用戶信息

10.管理員端-查詢借閱信息

三、部分代碼

基本類什么的就不列出來了,直接上頁面。

AdminMainFrm.java

package com.sjsq.view;

import java.awt.event.ActionEvent;

import javax.swing.GroupLayout;
import javax.swing.JDesktopPane;
import javax.swing.JFrame;
import javax.swing.JMenu;
import javax.swing.JMenuBar;
import javax.swing.JMenuItem;
import javax.swing.JOptionPane;
import javax.swing.WindowConstants;

public class AdminMainFrm extends JFrame {

?? ?private JDesktopPane jD_table;
?? ?private JMenu jMenu1;
?? ?private JMenu jMenu2;
?? ?private JMenu jMenu3;
?? ?private JMenu jMenu4;
?? ?private JMenuBar jMenuBar1;
?? ?private JMenuItem jMenuItem1;
?? ?private JMenuItem jMenuItem2;
?? ?private JMenuItem jMenuItem3;
?? ?private JMenuItem jMenuItem4;
?? ?private JMenuItem jMenuItem5;
?? ?private JMenuItem jMenuItem6;
?? ?private JMenuItem jMenuItem7;
?? ?
?? ?
?? ?public AdminMainFrm() {
?? ??? ?initComponents();
?? ??? ?// 設置位置
?? ??? ?setBounds(100, 200, 1050, 650);
?? ??? ?// 居中顯示
?? ??? ?this.setLocationRelativeTo(null);
?? ?}

?? ?private void initComponents() {

?? ??? ?jD_table = new JDesktopPane();
?? ??? ?jMenuBar1 = new JMenuBar();
?? ??? ?jMenu1 = new JMenu();
?? ??? ?jMenu2 = new JMenu();
?? ??? ?jMenuItem1 = new JMenuItem();
?? ??? ?jMenuItem2 = new JMenuItem();
?? ??? ?jMenu3 = new JMenu();
?? ??? ?jMenuItem4 = new JMenuItem();
?? ??? ?jMenuItem5 = new JMenuItem();
?? ??? ?jMenu4 = new JMenu();
?? ??? ?jMenuItem6 = new JMenuItem();
?? ??? ?jMenuItem7 = new JMenuItem();
?? ??? ?jMenuItem3 = new JMenuItem();

?? ??? ?setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
?? ??? ?setTitle("管理員主界面");

?? ??? ?jMenu1.setText("基本數據管理");

?? ??? ?jMenu2.setText("類別管理");
?? ??? ?jMenu2.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jMenu2ActionPerformed(evt);
?? ??? ??? ?}

?? ??? ??? ?private void jMenu2ActionPerformed(ActionEvent evt) {
?? ??? ??? ??? ?

?? ??? ??? ?}
?? ??? ?});

?? ??? ?jMenuItem1.setText("圖書類別添加");
?? ??? ?jMenuItem1.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jMenuItem1ActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});
?? ??? ?jMenu2.add(jMenuItem1);

?? ??? ?jMenuItem2.setText("圖書類別修改");
?? ??? ?jMenuItem2.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jMenuItem2ActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});
?? ??? ?jMenu2.add(jMenuItem2);

?? ??? ?jMenu1.add(jMenu2);

?? ??? ?jMenu3.setText("書籍管理");

?? ??? ?jMenuItem4.setText("書籍添加");
?? ??? ?jMenuItem4.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jMenuItem4ActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});
?? ??? ?jMenu3.add(jMenuItem4);

?? ??? ?jMenuItem5.setText("書籍修改");
?? ??? ?jMenuItem5.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jMenuItem5ActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});
?? ??? ?jMenu3.add(jMenuItem5);

?? ??? ?jMenu1.add(jMenu3);

?? ??? ?jMenu4.setText("用戶管理");

?? ??? ?jMenuItem6.setText("用戶信息");
?? ??? ?jMenuItem6.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jMenuItem6ActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});
?? ??? ?jMenu4.add(jMenuItem6);

?? ??? ?jMenuItem7.setText("借還信息");
?? ??? ?jMenuItem7.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jMenuItem7ActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});
?? ??? ?jMenu4.add(jMenuItem7);

?? ??? ?jMenu1.add(jMenu4);

?? ??? ?jMenuItem3.setText("退出系統(tǒng)");
?? ??? ?jMenuItem3.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jMenuItem3ActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});
?? ??? ?jMenu1.add(jMenuItem3);

?? ??? ?jMenuBar1.add(jMenu1);

?? ??? ?setJMenuBar(jMenuBar1);

?? ??? ?GroupLayout layout = new GroupLayout(getContentPane());
?? ??? ?getContentPane().setLayout(layout);
?? ??? ?layout.setHorizontalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ?.addComponent(jD_table, GroupLayout.DEFAULT_SIZE, 400, Short.MAX_VALUE));
?? ??? ?layout.setVerticalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ?.addComponent(jD_table, GroupLayout.DEFAULT_SIZE, 279, Short.MAX_VALUE));

?? ??? ?pack();
?? ?}
?? ??? ?

?? ?// 借還信息
?? ?private void jMenuItem7ActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?BorrowDetailFrm b = new BorrowDetailFrm();
?? ??? ?b.setVisible(true);
?? ??? ?this.jD_table.add(b);
?? ?}

?? ?// 用戶信息
?? ?private void jMenuItem6ActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?UserInfoFrm userInfoFrm = new UserInfoFrm();
?? ??? ?userInfoFrm.setVisible(true);
?? ??? ?this.jD_table.add(userInfoFrm);
?? ?}

?? ?private void jMenuItem1ActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?BookTypeAddFrm addFrm = new BookTypeAddFrm();
?? ??? ?addFrm.setVisible(true);
?? ??? ?this.jD_table.add(addFrm);
?? ?}

?? ?private void jMenuItem5ActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?BookManagerFrm bookManagerFrm = new BookManagerFrm();
?? ??? ?bookManagerFrm.setVisible(true);
?? ??? ?this.jD_table.add(bookManagerFrm);

?? ?}

?? ?private void jMenuItem4ActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?BookAddFrm bookAddFrm = new BookAddFrm();
?? ??? ?bookAddFrm.setVisible(true);
?? ??? ?this.jD_table.add(bookAddFrm);
?? ?}

?? ?private void jMenuItem2ActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?BookTypeManagerFrm bookTypeManagerFrm = new BookTypeManagerFrm();
?? ??? ?bookTypeManagerFrm.setVisible(true);
?? ??? ?this.jD_table.add(bookTypeManagerFrm);
?? ?}

?? ?private void jMenuItem3ActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?int i = JOptionPane.showConfirmDialog(null, "確認退出系統(tǒng)");
?? ??? ?if (i == 0) {
?? ??? ??? ?this.dispose();
?? ??? ?}
?? ?}

?? ?public static void main(String args[]) {
?? ??? ?java.awt.EventQueue.invokeLater(new Runnable() {
?? ??? ??? ?public void run() {
?? ??? ??? ??? ?new AdminMainFrm().setVisible(true);
?? ??? ??? ?}
?? ??? ?});
?? ?}
}

BookAddFrm.java

package com.sjsq.view;

import java.sql.Connection;
import java.sql.ResultSet;
import java.util.Vector;

import javax.swing.GroupLayout;
import javax.swing.JButton;
import javax.swing.JInternalFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.JTextField;
import javax.swing.LayoutStyle;
import javax.swing.table.DefaultTableModel;

import com.sjsq.dao.BookDao;
import com.sjsq.dao.BorrowDetailDao;
import com.sjsq.model.Book;
import com.sjsq.model.BorrowDetail;
import com.sjsq.util.DbUtil;
import com.sjsq.util.StringUtil;
import com.sjsq.util.TimeUtil;

public class BookInfoFrm extends JInternalFrame {
?? ?
?? ?private JTextField bookIdText;
?? ?private JTextField bookName;
?? ?private JTextField bookNameText;
?? ?private JTable bookTable;
?? ?private JButton jB_borrow;
?? ?private JButton jButton1;
?? ?private JLabel jLabel1;
?? ?private JLabel jLabel2;
?? ?private JLabel jLabel3;
?? ?private JPanel jPanel1;
?? ?private JScrollPane jScrollPane1;
?? ?
?? ?DbUtil dbUtil = new DbUtil();
?? ?BookDao bookDao = new BookDao();
?? ?BorrowDetailDao borrowDetailDao = new BorrowDetailDao();

?? ?
?? ?public BookInfoFrm() {
?? ??? ?initComponents();
?? ??? ?fillTable(new Book());
?? ??? ?setTitle("書籍信息");
?? ??? ?this.setLocation(200, 50);
?? ?}

?? ?private void fillTable(Book book) {
?? ??? ?DefaultTableModel model = (DefaultTableModel) bookTable.getModel();
?? ??? ?model.setRowCount(0);
?? ??? ?Connection con = null;
?? ??? ?try {
?? ??? ??? ?con = dbUtil.getCon();
?? ??? ??? ?book.setStatus(1);
?? ??? ??? ?ResultSet list = bookDao.list(con, book);
?? ??? ??? ?while (list.next()) {
?? ??? ??? ??? ?Vector rowData = new Vector();
?? ??? ??? ??? ?rowData.add(list.getInt("id"));
?? ??? ??? ??? ?rowData.add(list.getString("book_name"));
?? ??? ??? ??? ?rowData.add(list.getString("type_name"));
?? ??? ??? ??? ?rowData.add(list.getString("author"));
?? ??? ??? ??? ?rowData.add(list.getString("remark"));
?? ??? ??? ??? ?model.addRow(rowData);
?? ??? ??? ?}
?? ??? ?} catch (Exception e) {
?? ??? ??? ?
?? ??? ??? ?e.printStackTrace();
?? ??? ?} finally {
?? ??? ??? ?try {
?? ??? ??? ??? ?dbUtil.closeCon(con);
?? ??? ??? ?} catch (Exception e) {
?? ??? ??? ??? ?
?? ??? ??? ??? ?e.printStackTrace();
?? ??? ??? ?}
?? ??? ?}
?? ?}

?? ?
?? ?private void initComponents() {

?? ??? ?jScrollPane1 = new JScrollPane();
?? ??? ?bookTable = new JTable();
?? ??? ?jPanel1 = new JPanel();
?? ??? ?jLabel1 = new JLabel();
?? ??? ?bookNameText = new JTextField();
?? ??? ?jButton1 = new JButton();
?? ??? ?jB_borrow = new JButton();
?? ??? ?jLabel2 = new JLabel();
?? ??? ?bookIdText = new JTextField();
?? ??? ?jLabel3 = new JLabel();
?? ??? ?bookName = new JTextField();

?? ??? ?setClosable(true);

?? ??? ?bookTable.setModel(new DefaultTableModel(new Object[][] {

?? ??? ?}, new String[] { "編號", "書名", "類型", "作者", "描述" }) {
?? ??? ??? ?boolean[] canEdit = new boolean[] { false, false, false, false, false };

?? ??? ??? ?public boolean isCellEditable(int rowIndex, int columnIndex) {
?? ??? ??? ??? ?return canEdit[columnIndex];
?? ??? ??? ?}
?? ??? ?});
?? ??? ?bookTable.addMouseListener(new java.awt.event.MouseAdapter() {
?? ??? ??? ?public void mousePressed(java.awt.event.MouseEvent evt) {
?? ??? ??? ??? ?bookTableMousePressed(evt);
?? ??? ??? ?}
?? ??? ?});
?? ??? ?jScrollPane1.setViewportView(bookTable);

?? ??? ?jLabel1.setText("書籍名稱:");

?? ??? ?bookNameText.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?bookNameTextActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});

?? ??? ?jButton1.setText("查詢");
?? ??? ?jButton1.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jButton1ActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});

?? ??? ?GroupLayout jPanel1Layout = new GroupLayout(jPanel1);
?? ??? ?jPanel1.setLayout(jPanel1Layout);
?? ??? ?jPanel1Layout.setHorizontalGroup(jPanel1Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ?.addGroup(GroupLayout.Alignment.TRAILING, jPanel1Layout.createSequentialGroup()
?? ??? ??? ??? ??? ??? ?.addGap(42, 42, 42).addComponent(jLabel1).addGap(36, 36, 36)
?? ??? ??? ??? ??? ??? ?.addComponent(bookNameText, GroupLayout.PREFERRED_SIZE, 130,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ?.addPreferredGap(LayoutStyle.ComponentPlacement.RELATED, 149, Short.MAX_VALUE)
?? ??? ??? ??? ??? ??? ?.addComponent(jButton1).addGap(45, 45, 45)));
?? ??? ?jPanel1Layout.setVerticalGroup(jPanel1Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ?.addGroup(jPanel1Layout.createSequentialGroup().addGap(23, 23, 23)
?? ??? ??? ??? ??? ??? ?.addGroup(jPanel1Layout.createParallelGroup(GroupLayout.Alignment.BASELINE)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jButton1).addComponent(jLabel1).addComponent(bookNameText,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE))
?? ??? ??? ??? ??? ??? ?.addContainerGap(30, Short.MAX_VALUE)));

?? ??? ?jB_borrow.setText("借書");
?? ??? ?jB_borrow.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jB_borrowActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});

?? ??? ?jLabel2.setText("編號:");

?? ??? ?bookIdText.setEditable(false);

?? ??? ?jLabel3.setText("書名:");

?? ??? ?bookName.setEditable(false);

?? ??? ?GroupLayout layout = new GroupLayout(getContentPane());
?? ??? ?getContentPane().setLayout(layout);
?? ??? ?layout.setHorizontalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING).addGroup(layout
?? ??? ??? ??? ?.createSequentialGroup().addGap(22, 22, 22)
?? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING).addGroup(layout
?? ??? ??? ??? ??? ??? ?.createSequentialGroup().addComponent(jLabel2)
?? ??? ??? ??? ??? ??? ?.addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
?? ??? ??? ??? ??? ??? ?.addComponent(bookIdText, GroupLayout.PREFERRED_SIZE, 95,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ?.addPreferredGap(LayoutStyle.ComponentPlacement.RELATED).addComponent(jLabel3)
?? ??? ??? ??? ??? ??? ?.addGap(18, 18, 18)
?? ??? ??? ??? ??? ??? ?.addComponent(bookName, GroupLayout.PREFERRED_SIZE, 127,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ?.addPreferredGap(LayoutStyle.ComponentPlacement.RELATED, 102, Short.MAX_VALUE)
?? ??? ??? ??? ??? ??? ?.addComponent(jB_borrow).addGap(88, 88, 88))
?? ??? ??? ??? ??? ??? ?.addGroup(layout.createSequentialGroup()
?? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING, false)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jPanel1, GroupLayout.Alignment.TRAILING,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jScrollPane1, GroupLayout.Alignment.TRAILING,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, 507, Short.MAX_VALUE))
?? ??? ??? ??? ??? ??? ??? ??? ?.addContainerGap(38, Short.MAX_VALUE)))));
?? ??? ?layout.setVerticalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ?.addGroup(layout.createSequentialGroup()
?? ??? ??? ??? ??? ??? ?.addComponent(jPanel1, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ?.addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
?? ??? ??? ??? ??? ??? ?.addComponent(jScrollPane1, GroupLayout.PREFERRED_SIZE, 225,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ?.addPreferredGap(LayoutStyle.ComponentPlacement.RELATED, 35, Short.MAX_VALUE)
?? ??? ??? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.BASELINE)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jLabel2).addComponent(jLabel3)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(bookIdText, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(bookName, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jB_borrow))
?? ??? ??? ??? ??? ??? ?.addGap(27, 27, 27)));

?? ??? ?pack();
?? ?}
?? ??? ?

?? ?private void jB_borrowActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?String bookId = this.bookIdText.getText();
?? ??? ?String bookName = this.bookName.getText();
?? ??? ?if (StringUtil.isEmpty(bookId) || StringUtil.isEmpty(bookName)) {
?? ??? ??? ?JOptionPane.showMessageDialog(null, "請選擇相關書籍");
?? ??? ??? ?return;
?? ??? ?}
?? ??? ?BorrowDetail borrowDetail = new BorrowDetail();
?? ??? ?borrowDetail.setUserId(LoginFrm.currentUser.getUserId());
?? ??? ?borrowDetail.setBookId(Integer.parseInt(bookId));
?? ??? ?borrowDetail.setStatus(1);
?? ??? ?borrowDetail.setBorrowTime(TimeUtil.getTime());
?? ??? ?Connection con = null;
?? ??? ?try {
?? ??? ??? ?con = dbUtil.getCon();

?? ??? ??? ?// 先查詢是否有該書在借
?? ??? ??? ?ResultSet list = borrowDetailDao.list(con, borrowDetail);
?? ??? ??? ?while (list.next()) {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "該書已在借,請先還再借");
?? ??? ??? ??? ?return;
?? ??? ??? ?}
?? ??? ??? ?int i = borrowDetailDao.add(con, borrowDetail);
?? ??? ??? ?if (i == 1) {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "借書成功");
?? ??? ??? ?} else {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "借書失敗");
?? ??? ??? ?}
?? ??? ?} catch (Exception e) {
?? ??? ??? ?
?? ??? ??? ?e.printStackTrace();
?? ??? ??? ?JOptionPane.showMessageDialog(null, "借書異常");
?? ??? ?} finally {
?? ??? ??? ?try {
?? ??? ??? ??? ?dbUtil.closeCon(con);
?? ??? ??? ?} catch (Exception e) {
?? ??? ??? ??? ?
?? ??? ??? ??? ?e.printStackTrace();
?? ??? ??? ?}
?? ??? ?}

?? ?}

?? ?private void bookTableMousePressed(java.awt.event.MouseEvent evt) {
?? ??? ?int row = this.bookTable.getSelectedRow();
?? ??? ?Object bookId = this.bookTable.getValueAt(row, 0);
?? ??? ?Object bookName = this.bookTable.getValueAt(row, 1);
?? ??? ?this.bookIdText.setText(bookId.toString());
?? ??? ?this.bookName.setText(bookName.toString());
?? ?}

?? ?private void bookNameTextActionPerformed(java.awt.event.ActionEvent evt) {
?? ?}

?? ?private void jButton1ActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?String bookName = this.bookNameText.getText();
?? ??? ?Book book = new Book();
?? ??? ?book.setBookName(bookName);
?? ??? ?fillTable(book);
?? ?}

}

BookManagerFrm.java

package com.sjsq.view;

import java.math.BigDecimal;
import java.sql.Connection;
import java.sql.ResultSet;
import java.util.Vector;

import javax.swing.BorderFactory;
import javax.swing.GroupLayout;
import javax.swing.JButton;
import javax.swing.JComboBox;
import javax.swing.JInternalFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.JTextField;
import javax.swing.LayoutStyle;
import javax.swing.table.DefaultTableModel;

import com.sjsq.dao.BookDao;
import com.sjsq.dao.BookTypeDao;
import com.sjsq.model.Book;
import com.sjsq.model.BookType;
import com.sjsq.util.DbUtil;
import com.sjsq.util.StringUtil;

public class BookManagerFrm extends JInternalFrame {
?? ?
?? ?private JTextField authorText;
?? ?private JTextField bookId;
?? ?private JTextField bookName;
?? ?private JTextField bookNameText;
?? ?private JTable bookTable;
?? ?private JButton jButton1;
?? ?private JButton jButton2;
?? ?private JComboBox jCB_status;
?? ?private JComboBox jCB_type2;
?? ?private JLabel jLabel1;
?? ?private JLabel jLabel10;
?? ?private JLabel jLabel11;
?? ?private JLabel jLabel3;
?? ?private JLabel jLabel4;
?? ?private JLabel jLabel5;
?? ?private JLabel jLabel6;
?? ?private JLabel jLabel7;
?? ?private JLabel jLabel8;
?? ?private JLabel jLabel9;
?? ?private JPanel jPanel1;
?? ?private JPanel jPanel2;
?? ?private JScrollPane jScrollPane1;
?? ?private JTextField numberText;
?? ?private JTextField priceText;
?? ?private JTextField publishText;
?? ?private JTextField remarkText;
?? ?
?? ?
?? ?DbUtil dbUtil = new DbUtil();
?? ?BookTypeDao bookTypeDao = new BookTypeDao();
?? ?BookDao bookDao = new BookDao();

?? ?
?? ?public BookManagerFrm() {
?? ??? ?initComponents();
?? ??? ?this.jCB_status.addItem("上架");
?? ??? ?this.jCB_status.addItem("下架");
?? ??? ?fillBookTable(new Book());
?? ??? ?fillBookType();
?? ??? ?setTitle("書籍修改");
?? ??? ?this.setLocation(125, 10);
?? ?}

?? ?private void fillBookType() {
?? ??? ?Connection con = null;
?? ??? ?try {
?? ??? ??? ?con = dbUtil.getCon();
?? ??? ??? ?ResultSet list = bookTypeDao.list(con, new BookType());
?? ??? ??? ?while (list.next()) {
?? ??? ??? ??? ?BookType bookType = new BookType();
?? ??? ??? ??? ?bookType.setTypeId(list.getInt("id"));
?? ??? ??? ??? ?bookType.setTypeName(list.getString("type_name"));
?? ??? ??? ??? ?this.jCB_type2.addItem(bookType);
?? ??? ??? ?}
?? ??? ?} catch (Exception e) {
?? ??? ??? ?
?? ??? ??? ?e.printStackTrace();
?? ??? ?} finally {
?? ??? ??? ?try {
?? ??? ??? ??? ?dbUtil.closeCon(con);
?? ??? ??? ?} catch (Exception e) {
?? ??? ??? ??? ?
?? ??? ??? ??? ?e.printStackTrace();
?? ??? ??? ?}
?? ??? ?}
?? ?}

?? ?private void fillBookTable(Book book) {
?? ??? ?DefaultTableModel model = (DefaultTableModel) bookTable.getModel();
?? ??? ?model.setRowCount(0);
?? ??? ?Connection con = null;
?? ??? ?try {
?? ??? ??? ?con = dbUtil.getCon();
?? ??? ??? ?ResultSet resultSet = bookDao.list(con, book);
?? ??? ??? ?while (resultSet.next()) {
?? ??? ??? ??? ?Vector rowData = new Vector();
?? ??? ??? ??? ?rowData.add(resultSet.getInt("id"));
?? ??? ??? ??? ?rowData.add(resultSet.getString("book_name"));
?? ??? ??? ??? ?rowData.add(resultSet.getString("type_name"));
?? ??? ??? ??? ?rowData.add(resultSet.getString("author"));
?? ??? ??? ??? ?rowData.add(resultSet.getDouble("price"));
?? ??? ??? ??? ?rowData.add(resultSet.getInt("number"));
?? ??? ??? ??? ?if (resultSet.getInt("status") == 1) {
?? ??? ??? ??? ??? ?rowData.add("上架");
?? ??? ??? ??? ?} else {
?? ??? ??? ??? ??? ?rowData.add("下架");
?? ??? ??? ??? ?}
?? ??? ??? ??? ?model.addRow(rowData);
?? ??? ??? ?}
?? ??? ?} catch (Exception e) {
?? ??? ??? ?
?? ??? ??? ?e.printStackTrace();
?? ??? ?} finally {
?? ??? ??? ?try {
?? ??? ??? ??? ?dbUtil.closeCon(con);
?? ??? ??? ?} catch (Exception e) {
?? ??? ??? ??? ?
?? ??? ??? ??? ?e.printStackTrace();
?? ??? ??? ?}
?? ??? ?}
?? ?}

?? ?
?? ?
?? ?private void initComponents() {

?? ??? ?jPanel1 = new JPanel();
?? ??? ?jLabel1 = new JLabel();
?? ??? ?bookNameText = new JTextField();
?? ??? ?jButton1 = new JButton();
?? ??? ?jScrollPane1 = new JScrollPane();
?? ??? ?bookTable = new JTable();
?? ??? ?jPanel2 = new JPanel();
?? ??? ?jLabel3 = new JLabel();
?? ??? ?bookId = new JTextField();
?? ??? ?jLabel4 = new JLabel();
?? ??? ?bookName = new JTextField();
?? ??? ?jLabel5 = new JLabel();
?? ??? ?authorText = new JTextField();
?? ??? ?jLabel6 = new JLabel();
?? ??? ?publishText = new JTextField();
?? ??? ?jLabel7 = new JLabel();
?? ??? ?priceText = new JTextField();
?? ??? ?jLabel8 = new JLabel();
?? ??? ?numberText = new JTextField();
?? ??? ?jLabel9 = new JLabel();
?? ??? ?jLabel10 = new JLabel();
?? ??? ?jCB_type2 = new JComboBox();
?? ??? ?jLabel11 = new JLabel();
?? ??? ?remarkText = new JTextField();
?? ??? ?jButton2 = new JButton();
?? ??? ?jCB_status = new JComboBox();

?? ??? ?setClosable(true);

?? ??? ?jPanel1.setBorder(BorderFactory.createTitledBorder("查詢操作"));

?? ??? ?jLabel1.setText("書名:");

?? ??? ?jButton1.setText("查詢");
?? ??? ?jButton1.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jButton1ActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});

?? ??? ?GroupLayout jPanel1Layout = new GroupLayout(jPanel1);
?? ??? ?jPanel1.setLayout(jPanel1Layout);
?? ??? ?jPanel1Layout.setHorizontalGroup(jPanel1Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ?.addGroup(jPanel1Layout.createSequentialGroup().addGap(25, 25, 25).addComponent(jLabel1)
?? ??? ??? ??? ??? ??? ?.addGap(18, 18, 18)
?? ??? ??? ??? ??? ??? ?.addComponent(bookNameText, GroupLayout.PREFERRED_SIZE, 171,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ?.addGap(62, 62, 62).addComponent(jButton1).addContainerGap(299, Short.MAX_VALUE)));
?? ??? ?jPanel1Layout
?? ??? ??? ??? ?.setVerticalGroup(jPanel1Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ??? ??? ?.addGroup(jPanel1Layout.createSequentialGroup().addGroup(jPanel1Layout
?? ??? ??? ??? ??? ??? ??? ??? ?.createParallelGroup(GroupLayout.Alignment.BASELINE).addComponent(jLabel1)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(bookNameText, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jButton1)).addContainerGap(22, Short.MAX_VALUE)));

?? ??? ?bookTable.setModel(new DefaultTableModel(new Object[][] {

?? ??? ?}, new String[] { "編號", "書名", "類別", "作者", "價格", "庫存", "狀態(tài)" }) {
?? ??? ??? ?boolean[] canEdit = new boolean[] { false, false, false, false, false, false, false };

?? ??? ??? ?public boolean isCellEditable(int rowIndex, int columnIndex) {
?? ??? ??? ??? ?return canEdit[columnIndex];
?? ??? ??? ?}
?? ??? ?});
?? ??? ?bookTable.addMouseListener(new java.awt.event.MouseAdapter() {
?? ??? ??? ?public void mousePressed(java.awt.event.MouseEvent evt) {
?? ??? ??? ??? ?bookTableMousePressed(evt);
?? ??? ??? ?}
?? ??? ?});
?? ??? ?jScrollPane1.setViewportView(bookTable);

?? ??? ?jPanel2.setBorder(BorderFactory.createTitledBorder("書籍操作"));

?? ??? ?jLabel3.setText("編號:");

?? ??? ?bookId.setEditable(false);

?? ??? ?jLabel4.setText("書名:");

?? ??? ?jLabel5.setText("作者:");

?? ??? ?jLabel6.setText("出版:");

?? ??? ?jLabel7.setText("價格:");

?? ??? ?jLabel8.setText("庫存:");

?? ??? ?jLabel9.setText("狀態(tài):");

?? ??? ?jLabel10.setText("類別:");

?? ??? ?jLabel11.setText("描述:");

?? ??? ?jButton2.setText("修改");
?? ??? ?jButton2.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jButton2ActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});

?? ??? ?GroupLayout jPanel2Layout = new GroupLayout(jPanel2);
?? ??? ?jPanel2.setLayout(jPanel2Layout);
?? ??? ?jPanel2Layout.setHorizontalGroup(jPanel2Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ?.addGroup(jPanel2Layout.createSequentialGroup()
?? ??? ??? ??? ??? ??? ?.addGroup(jPanel2Layout.createParallelGroup(GroupLayout.Alignment.LEADING).addGroup(
?? ??? ??? ??? ??? ??? ??? ??? ?jPanel2Layout.createSequentialGroup().addGap(26, 26, 26).addGroup(jPanel2Layout
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.createParallelGroup(GroupLayout.Alignment.LEADING).addGroup(
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?jPanel2Layout.createSequentialGroup().addComponent(jLabel9)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addPreferredGap(
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?LayoutStyle.ComponentPlacement.RELATED)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jCB_status, 0, 117, Short.MAX_VALUE))
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(GroupLayout.Alignment.TRAILING,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?jPanel2Layout
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.createSequentialGroup().addGroup(jPanel2Layout
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.createParallelGroup(
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jLabel3).addComponent(jLabel6))
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addPreferredGap(
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?LayoutStyle.ComponentPlacement.RELATED,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(jPanel2Layout
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.createParallelGroup(
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.Alignment.TRAILING,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?false)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(publishText,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(bookId,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.Alignment.LEADING,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, 117,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?Short.MAX_VALUE))))
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addGap(39, 39, 39)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(jPanel2Layout.createParallelGroup(
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.Alignment.LEADING, false)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(jPanel2Layout.createSequentialGroup().addComponent(jLabel10)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addGap(27, 27,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?27)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jCB_type2, 0,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(GroupLayout.Alignment.TRAILING,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?jPanel2Layout.createSequentialGroup().addComponent(jLabel7)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addGap(27, 27, 27).addComponent(priceText))
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(jPanel2Layout.createSequentialGroup().addComponent(jLabel4)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addGap(27, 27, 27).addComponent(
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?bookName, GroupLayout.PREFERRED_SIZE, 108,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE)))
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addGap(18, 18, 18)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(jPanel2Layout
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(jPanel2Layout.createSequentialGroup().addComponent(jLabel11)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addGap(18, 18, 18).addComponent(remarkText,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE, 172,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE))
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(jPanel2Layout
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.createParallelGroup(GroupLayout.Alignment.TRAILING,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?false)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(GroupLayout.Alignment.LEADING,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?jPanel2Layout.createSequentialGroup()
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jLabel8).addGap(18, 18, 18)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(numberText))
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(GroupLayout.Alignment.LEADING,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?jPanel2Layout.createSequentialGroup()
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jLabel5).addGap(20, 20, 20)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(authorText,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?106,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE))))
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addGap(97, 97, 97))
?? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(jPanel2Layout.createSequentialGroup().addGap(108, 108, 108)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jButton2)))
?? ??? ??? ??? ??? ??? ?.addContainerGap()));
?? ??? ?jPanel2Layout.setVerticalGroup(jPanel2Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ?.addGroup(jPanel2Layout.createSequentialGroup().addGroup(jPanel2Layout
?? ??? ??? ??? ??? ??? ?.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ??? ??? ?.addGroup(jPanel2Layout.createSequentialGroup().addGroup(jPanel2Layout
?? ??? ??? ??? ??? ??? ??? ??? ?.createParallelGroup(GroupLayout.Alignment.BASELINE).addComponent(jLabel3)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(bookId, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE))
?? ??? ??? ??? ??? ??? ??? ??? ?.addGap(18, 18, 18)
?? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(jPanel2Layout.createParallelGroup(GroupLayout.Alignment.BASELINE)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jLabel6)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(publishText, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jLabel7)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(priceText, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jLabel8).addComponent(numberText,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE))
?? ??? ??? ??? ??? ??? ??? ??? ?.addGap(18, 18, 18)
?? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(jPanel2Layout.createParallelGroup(GroupLayout.Alignment.BASELINE)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jLabel9)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jCB_status, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jLabel10)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jCB_type2, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jLabel11).addComponent(remarkText,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE)))
?? ??? ??? ??? ??? ??? ?.addGroup(jPanel2Layout.createParallelGroup(GroupLayout.Alignment.BASELINE)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jLabel4)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(bookName, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(authorText, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jLabel5)))
?? ??? ??? ??? ??? ??? ?.addPreferredGap(LayoutStyle.ComponentPlacement.RELATED, 42, Short.MAX_VALUE)
?? ??? ??? ??? ??? ??? ?.addComponent(jButton2).addGap(28, 28, 28)));

?? ??? ?GroupLayout layout = new GroupLayout(getContentPane());
?? ??? ?getContentPane().setLayout(layout);
?? ??? ?layout.setHorizontalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING).addGroup(layout
?? ??? ??? ??? ?.createSequentialGroup().addGap(31, 31, 31)
?? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.TRAILING, false)
?? ??? ??? ??? ??? ??? ?.addComponent(jPanel1, GroupLayout.Alignment.LEADING,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.DEFAULT_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ?Short.MAX_VALUE)
?? ??? ??? ??? ??? ??? ?.addComponent(jScrollPane1, GroupLayout.Alignment.LEADING).addComponent(jPanel2,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.Alignment.LEADING, GroupLayout.DEFAULT_SIZE, 668,
?? ??? ??? ??? ??? ??? ??? ??? ?Short.MAX_VALUE))
?? ??? ??? ??? ?.addContainerGap(GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)));
?? ??? ?layout.setVerticalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ?.addGroup(layout.createSequentialGroup()
?? ??? ??? ??? ??? ??? ?.addComponent(jPanel1, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ?.addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
?? ??? ??? ??? ??? ??? ?.addComponent(jScrollPane1, GroupLayout.PREFERRED_SIZE, 186,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ?.addGap(18, 18, 18).addComponent(jPanel2, GroupLayout.DEFAULT_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
?? ??? ??? ??? ??? ??? ?.addContainerGap()));

?? ??? ?pack();
?? ?}

?? ?

?? ?private void jButton1ActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?String bookName = this.bookNameText.getText();
?? ??? ?Book book = new Book();
?? ??? ?book.setBookName(bookName);
?? ??? ?fillBookTable(book);
?? ?}

?? ?private void bookTableMousePressed(java.awt.event.MouseEvent evt) {
?? ??? ?int row = bookTable.getSelectedRow();
?? ??? ?Integer bookId = (Integer) bookTable.getValueAt(row, 0);
?? ??? ?Book book = new Book();
?? ??? ?book.setBookId(bookId);
?? ??? ?Connection con = null;
?? ??? ?try {
?? ??? ??? ?con = dbUtil.getCon();
?? ??? ??? ?ResultSet list = bookDao.list(con, book);
?? ??? ??? ?if (list.next()) {
?? ??? ??? ??? ?this.bookId.setText(list.getString("id"));
?? ??? ??? ??? ?this.bookName.setText(list.getString("book_name"));
?? ??? ??? ??? ?this.authorText.setText(list.getString("author"));
?? ??? ??? ??? ?this.publishText.setText(list.getString("publish"));
?? ??? ??? ??? ?this.priceText.setText(list.getString("price"));
?? ??? ??? ??? ?this.numberText.setText(list.getString("number"));
?? ??? ??? ??? ?this.remarkText.setText(list.getString("remark"));
?? ??? ??? ??? ?int status = list.getInt("status");
?? ??? ??? ??? ?if (status == 1) {
?? ??? ??? ??? ??? ?this.jCB_status.setSelectedIndex(0);
?? ??? ??? ??? ?} else {
?? ??? ??? ??? ??? ?this.jCB_status.setSelectedIndex(1);
?? ??? ??? ??? ?}
?? ??? ??? ??? ?int typeId = list.getInt("type_id");
?? ??? ??? ??? ?int count = this.jCB_type2.getItemCount();
?? ??? ??? ??? ?for (int i = 0; i < count; i++) {
?? ??? ??? ??? ??? ?BookType bookType = (BookType) this.jCB_type2.getItemAt(i);
?? ??? ??? ??? ??? ?if (bookType.getTypeId() == typeId) {
?? ??? ??? ??? ??? ??? ?this.jCB_type2.setSelectedIndex(i);
?? ??? ??? ??? ??? ?}
?? ??? ??? ??? ?}
?? ??? ??? ?}
?? ??? ?} catch (Exception e) {
?? ??? ??? ?
?? ??? ??? ?e.printStackTrace();
?? ??? ?} finally {
?? ??? ??? ?try {
?? ??? ??? ??? ?dbUtil.closeCon(con);
?? ??? ??? ?} catch (Exception e) {
?? ??? ??? ??? ?
?? ??? ??? ??? ?e.printStackTrace();
?? ??? ??? ?}
?? ??? ?}
?? ?}

?? ?private void jButton2ActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?String bookName = this.bookName.getText();
?? ??? ?String author = this.authorText.getText();
?? ??? ?String publish = this.publishText.getText();
?? ??? ?String priceStr = this.priceText.getText();
?? ??? ?String numberStr = this.numberText.getText();
?? ??? ?String remark = this.remarkText.getText();
?? ??? ?String bookId = this.bookId.getText();
?? ??? ?if (StringUtil.isEmpty(bookId) || StringUtil.isEmpty(bookName) || StringUtil.isEmpty(author)
?? ??? ??? ??? ?|| StringUtil.isEmpty(publish) || StringUtil.isEmpty(priceStr) || StringUtil.isEmpty(numberStr)
?? ??? ??? ??? ?|| StringUtil.isEmpty(remark)) {
?? ??? ??? ?JOptionPane.showMessageDialog(null, "請輸入相關內容");
?? ??? ??? ?return;
?? ??? ?}
?? ??? ?BookType selectedItem = (BookType) jCB_type2.getSelectedItem();
?? ??? ?Integer typeId = selectedItem.getTypeId();
?? ??? ?int index = jCB_status.getSelectedIndex();

?? ??? ?int number;
?? ??? ?double price;
?? ??? ?try {
?? ??? ??? ?number = Integer.parseInt(numberStr);
?? ??? ??? ?price = new BigDecimal(priceStr).setScale(2, BigDecimal.ROUND_DOWN).doubleValue();
?? ??? ?} catch (Exception e) {
?? ??? ??? ?JOptionPane.showMessageDialog(null, "參數錯誤");
?? ??? ??? ?return;
?? ??? ?}
?? ??? ?Book book = new Book();
?? ??? ?book.setBookId(Integer.parseInt(bookId));
?? ??? ?book.setBookName(bookName);
?? ??? ?book.setAuthor(author);
?? ??? ?book.setBookTypeId(typeId);
?? ??? ?book.setNumber(number);
?? ??? ?book.setPrice(price);
?? ??? ?book.setPublish(publish);
?? ??? ?book.setRemark(remark);
?? ??? ?book.setStatus(1);
?? ??? ?if (index == 0) {
?? ??? ??? ?book.setStatus(1);
?? ??? ?} else if (index == 1) {
?? ??? ??? ?book.setStatus(2);
?? ??? ?}
?? ??? ?Connection con = null;
?? ??? ?try {
?? ??? ??? ?con = dbUtil.getCon();
?? ??? ??? ?int i = bookDao.update(con, book);
?? ??? ??? ?if (i == 1) {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "修改成功");
?? ??? ??? ?} else {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "修改失敗");
?? ??? ??? ?}
?? ??? ?} catch (Exception e) {
?? ??? ??? ?
?? ??? ??? ?e.printStackTrace();
?? ??? ??? ?JOptionPane.showMessageDialog(null, "修改異常");
?? ??? ?} finally {
?? ??? ??? ?try {
?? ??? ??? ??? ?dbUtil.closeCon(con);
?? ??? ??? ?} catch (Exception e) {
?? ??? ??? ??? ?
?? ??? ??? ??? ?e.printStackTrace();
?? ??? ??? ?}
?? ??? ?}

?? ??? ?fillBookTable(new Book());
?? ?}

}

BookInfoFrm.java

package com.sjsq.view;

import java.sql.Connection;
import java.sql.ResultSet;
import java.util.Vector;

import javax.swing.GroupLayout;
import javax.swing.JButton;
import javax.swing.JInternalFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.JTextField;
import javax.swing.LayoutStyle;
import javax.swing.table.DefaultTableModel;

import com.sjsq.dao.BookDao;
import com.sjsq.dao.BorrowDetailDao;
import com.sjsq.model.Book;
import com.sjsq.model.BorrowDetail;
import com.sjsq.util.DbUtil;
import com.sjsq.util.StringUtil;
import com.sjsq.util.TimeUtil;

public class BookInfoFrm extends JInternalFrame {
?? ?
?? ?private JTextField bookIdText;
?? ?private JTextField bookName;
?? ?private JTextField bookNameText;
?? ?private JTable bookTable;
?? ?private JButton jB_borrow;
?? ?private JButton jButton1;
?? ?private JLabel jLabel1;
?? ?private JLabel jLabel2;
?? ?private JLabel jLabel3;
?? ?private JPanel jPanel1;
?? ?private JScrollPane jScrollPane1;
?? ?
?? ?DbUtil dbUtil = new DbUtil();
?? ?BookDao bookDao = new BookDao();
?? ?BorrowDetailDao borrowDetailDao = new BorrowDetailDao();

?? ?
?? ?public BookInfoFrm() {
?? ??? ?initComponents();
?? ??? ?fillTable(new Book());
?? ??? ?setTitle("書籍信息");
?? ??? ?this.setLocation(200, 50);
?? ?}

?? ?private void fillTable(Book book) {
?? ??? ?DefaultTableModel model = (DefaultTableModel) bookTable.getModel();
?? ??? ?model.setRowCount(0);
?? ??? ?Connection con = null;
?? ??? ?try {
?? ??? ??? ?con = dbUtil.getCon();
?? ??? ??? ?book.setStatus(1);
?? ??? ??? ?ResultSet list = bookDao.list(con, book);
?? ??? ??? ?while (list.next()) {
?? ??? ??? ??? ?Vector rowData = new Vector();
?? ??? ??? ??? ?rowData.add(list.getInt("id"));
?? ??? ??? ??? ?rowData.add(list.getString("book_name"));
?? ??? ??? ??? ?rowData.add(list.getString("type_name"));
?? ??? ??? ??? ?rowData.add(list.getString("author"));
?? ??? ??? ??? ?rowData.add(list.getString("remark"));
?? ??? ??? ??? ?model.addRow(rowData);
?? ??? ??? ?}
?? ??? ?} catch (Exception e) {
?? ??? ??? ?
?? ??? ??? ?e.printStackTrace();
?? ??? ?} finally {
?? ??? ??? ?try {
?? ??? ??? ??? ?dbUtil.closeCon(con);
?? ??? ??? ?} catch (Exception e) {
?? ??? ??? ??? ?
?? ??? ??? ??? ?e.printStackTrace();
?? ??? ??? ?}
?? ??? ?}
?? ?}

?? ?
?? ?private void initComponents() {

?? ??? ?jScrollPane1 = new JScrollPane();
?? ??? ?bookTable = new JTable();
?? ??? ?jPanel1 = new JPanel();
?? ??? ?jLabel1 = new JLabel();
?? ??? ?bookNameText = new JTextField();
?? ??? ?jButton1 = new JButton();
?? ??? ?jB_borrow = new JButton();
?? ??? ?jLabel2 = new JLabel();
?? ??? ?bookIdText = new JTextField();
?? ??? ?jLabel3 = new JLabel();
?? ??? ?bookName = new JTextField();

?? ??? ?setClosable(true);

?? ??? ?bookTable.setModel(new DefaultTableModel(new Object[][] {

?? ??? ?}, new String[] { "編號", "書名", "類型", "作者", "描述" }) {
?? ??? ??? ?boolean[] canEdit = new boolean[] { false, false, false, false, false };

?? ??? ??? ?public boolean isCellEditable(int rowIndex, int columnIndex) {
?? ??? ??? ??? ?return canEdit[columnIndex];
?? ??? ??? ?}
?? ??? ?});
?? ??? ?bookTable.addMouseListener(new java.awt.event.MouseAdapter() {
?? ??? ??? ?public void mousePressed(java.awt.event.MouseEvent evt) {
?? ??? ??? ??? ?bookTableMousePressed(evt);
?? ??? ??? ?}
?? ??? ?});
?? ??? ?jScrollPane1.setViewportView(bookTable);

?? ??? ?jLabel1.setText("書籍名稱:");

?? ??? ?bookNameText.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?bookNameTextActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});

?? ??? ?jButton1.setText("查詢");
?? ??? ?jButton1.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jButton1ActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});

?? ??? ?GroupLayout jPanel1Layout = new GroupLayout(jPanel1);
?? ??? ?jPanel1.setLayout(jPanel1Layout);
?? ??? ?jPanel1Layout.setHorizontalGroup(jPanel1Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ?.addGroup(GroupLayout.Alignment.TRAILING, jPanel1Layout.createSequentialGroup()
?? ??? ??? ??? ??? ??? ?.addGap(42, 42, 42).addComponent(jLabel1).addGap(36, 36, 36)
?? ??? ??? ??? ??? ??? ?.addComponent(bookNameText, GroupLayout.PREFERRED_SIZE, 130,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ?.addPreferredGap(LayoutStyle.ComponentPlacement.RELATED, 149, Short.MAX_VALUE)
?? ??? ??? ??? ??? ??? ?.addComponent(jButton1).addGap(45, 45, 45)));
?? ??? ?jPanel1Layout.setVerticalGroup(jPanel1Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ?.addGroup(jPanel1Layout.createSequentialGroup().addGap(23, 23, 23)
?? ??? ??? ??? ??? ??? ?.addGroup(jPanel1Layout.createParallelGroup(GroupLayout.Alignment.BASELINE)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jButton1).addComponent(jLabel1).addComponent(bookNameText,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE))
?? ??? ??? ??? ??? ??? ?.addContainerGap(30, Short.MAX_VALUE)));

?? ??? ?jB_borrow.setText("借書");
?? ??? ?jB_borrow.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jB_borrowActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});

?? ??? ?jLabel2.setText("編號:");

?? ??? ?bookIdText.setEditable(false);

?? ??? ?jLabel3.setText("書名:");

?? ??? ?bookName.setEditable(false);

?? ??? ?GroupLayout layout = new GroupLayout(getContentPane());
?? ??? ?getContentPane().setLayout(layout);
?? ??? ?layout.setHorizontalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING).addGroup(layout
?? ??? ??? ??? ?.createSequentialGroup().addGap(22, 22, 22)
?? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING).addGroup(layout
?? ??? ??? ??? ??? ??? ?.createSequentialGroup().addComponent(jLabel2)
?? ??? ??? ??? ??? ??? ?.addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
?? ??? ??? ??? ??? ??? ?.addComponent(bookIdText, GroupLayout.PREFERRED_SIZE, 95,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ?.addPreferredGap(LayoutStyle.ComponentPlacement.RELATED).addComponent(jLabel3)
?? ??? ??? ??? ??? ??? ?.addGap(18, 18, 18)
?? ??? ??? ??? ??? ??? ?.addComponent(bookName, GroupLayout.PREFERRED_SIZE, 127,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ?.addPreferredGap(LayoutStyle.ComponentPlacement.RELATED, 102, Short.MAX_VALUE)
?? ??? ??? ??? ??? ??? ?.addComponent(jB_borrow).addGap(88, 88, 88))
?? ??? ??? ??? ??? ??? ?.addGroup(layout.createSequentialGroup()
?? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING, false)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jPanel1, GroupLayout.Alignment.TRAILING,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jScrollPane1, GroupLayout.Alignment.TRAILING,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, 507, Short.MAX_VALUE))
?? ??? ??? ??? ??? ??? ??? ??? ?.addContainerGap(38, Short.MAX_VALUE)))));
?? ??? ?layout.setVerticalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ?.addGroup(layout.createSequentialGroup()
?? ??? ??? ??? ??? ??? ?.addComponent(jPanel1, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ?.addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
?? ??? ??? ??? ??? ??? ?.addComponent(jScrollPane1, GroupLayout.PREFERRED_SIZE, 225,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ?.addPreferredGap(LayoutStyle.ComponentPlacement.RELATED, 35, Short.MAX_VALUE)
?? ??? ??? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.BASELINE)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jLabel2).addComponent(jLabel3)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(bookIdText, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(bookName, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jB_borrow))
?? ??? ??? ??? ??? ??? ?.addGap(27, 27, 27)));

?? ??? ?pack();
?? ?}
?? ??? ?

?? ?private void jB_borrowActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?String bookId = this.bookIdText.getText();
?? ??? ?String bookName = this.bookName.getText();
?? ??? ?if (StringUtil.isEmpty(bookId) || StringUtil.isEmpty(bookName)) {
?? ??? ??? ?JOptionPane.showMessageDialog(null, "請選擇相關書籍");
?? ??? ??? ?return;
?? ??? ?}
?? ??? ?BorrowDetail borrowDetail = new BorrowDetail();
?? ??? ?borrowDetail.setUserId(LoginFrm.currentUser.getUserId());
?? ??? ?borrowDetail.setBookId(Integer.parseInt(bookId));
?? ??? ?borrowDetail.setStatus(1);
?? ??? ?borrowDetail.setBorrowTime(TimeUtil.getTime());
?? ??? ?Connection con = null;
?? ??? ?try {
?? ??? ??? ?con = dbUtil.getCon();

?? ??? ??? ?// 先查詢是否有該書在借
?? ??? ??? ?ResultSet list = borrowDetailDao.list(con, borrowDetail);
?? ??? ??? ?while (list.next()) {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "該書已在借,請先還再借");
?? ??? ??? ??? ?return;
?? ??? ??? ?}
?? ??? ??? ?int i = borrowDetailDao.add(con, borrowDetail);
?? ??? ??? ?if (i == 1) {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "借書成功");
?? ??? ??? ?} else {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "借書失敗");
?? ??? ??? ?}
?? ??? ?} catch (Exception e) {
?? ??? ??? ?
?? ??? ??? ?e.printStackTrace();
?? ??? ??? ?JOptionPane.showMessageDialog(null, "借書異常");
?? ??? ?} finally {
?? ??? ??? ?try {
?? ??? ??? ??? ?dbUtil.closeCon(con);
?? ??? ??? ?} catch (Exception e) {
?? ??? ??? ??? ?
?? ??? ??? ??? ?e.printStackTrace();
?? ??? ??? ?}
?? ??? ?}

?? ?}

?? ?private void bookTableMousePressed(java.awt.event.MouseEvent evt) {
?? ??? ?int row = this.bookTable.getSelectedRow();
?? ??? ?Object bookId = this.bookTable.getValueAt(row, 0);
?? ??? ?Object bookName = this.bookTable.getValueAt(row, 1);
?? ??? ?this.bookIdText.setText(bookId.toString());
?? ??? ?this.bookName.setText(bookName.toString());
?? ?}

?? ?private void bookNameTextActionPerformed(java.awt.event.ActionEvent evt) {
?? ?}

?? ?private void jButton1ActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?String bookName = this.bookNameText.getText();
?? ??? ?Book book = new Book();
?? ??? ?book.setBookName(bookName);
?? ??? ?fillTable(book);
?? ?}
}

BookTypeAddFrm.java

package com.sjsq.view;

import java.sql.Connection;

import javax.swing.GroupLayout;
import javax.swing.JButton;
import javax.swing.JInternalFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JScrollPane;
import javax.swing.JTextArea;
import javax.swing.JTextField;

import com.sjsq.dao.BookTypeDao;
import com.sjsq.model.BookType;
import com.sjsq.util.DbUtil;
import com.sjsq.util.StringUtil;

public class BookTypeAddFrm extends JInternalFrame {
?? ?
?? ?private JButton jButton1;
?? ?private JButton jButton2;
?? ?private JLabel jLabel1;
?? ?private JLabel jLabel2;
?? ?private JScrollPane jScrollPane1;
?? ?private JTextField typeNameText;
?? ?private JTextArea typeRemarkTtext;
?? ?
?? ?DbUtil dbUtil = new DbUtil();
?? ?BookTypeDao bookTypeDao = new BookTypeDao();

?? ?
?? ?public BookTypeAddFrm() {
?? ??? ?initComponents();
?? ??? ?setTitle("圖書類別添加");
?? ??? ?this.setLocation(200, 50);
?? ?}

?? ?
?? ?private void initComponents() {

?? ??? ?jLabel1 = new JLabel();
?? ??? ?jLabel2 = new JLabel();
?? ??? ?jButton1 = new JButton();
?? ??? ?typeNameText = new JTextField();
?? ??? ?jScrollPane1 = new JScrollPane();
?? ??? ?typeRemarkTtext = new JTextArea();
?? ??? ?jButton2 = new JButton();

?? ??? ?setClosable(true);

?? ??? ?jLabel1.setText("圖書類別名稱:");

?? ??? ?jLabel2.setText("類別說明:");

?? ??? ?jButton1.setText("添加");
?? ??? ?jButton1.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jButton1ActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});

?? ??? ?typeRemarkTtext.setColumns(20);
?? ??? ?typeRemarkTtext.setRows(5);
?? ??? ?jScrollPane1.setViewportView(typeRemarkTtext);

?? ??? ?jButton2.setText("重置");
?? ??? ?jButton2.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jButton2ActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});

?? ??? ?GroupLayout layout = new GroupLayout(getContentPane());
?? ??? ?getContentPane().setLayout(layout);
?? ??? ?layout.setHorizontalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ?.addGroup(layout.createSequentialGroup().addGap(49, 49, 49)
?? ??? ??? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING, false)
?? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(layout.createSequentialGroup().addComponent(jLabel2).addGap(18, 18, 18)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jScrollPane1))
?? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(layout.createSequentialGroup().addComponent(jLabel1).addGap(18, 18, 18)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(typeNameText, GroupLayout.PREFERRED_SIZE, 241,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE))
?? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(layout.createSequentialGroup().addComponent(jButton1).addGap(53, 53, 53)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jButton2)))
?? ??? ??? ??? ??? ??? ?.addGap(179, 179, 179)));
?? ??? ?layout.setVerticalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING).addGroup(layout
?? ??? ??? ??? ?.createSequentialGroup().addGap(35, 35, 35)
?? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.BASELINE).addComponent(jLabel1)
?? ??? ??? ??? ??? ??? ?.addComponent(typeNameText, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE))
?? ??? ??? ??? ?.addGap(43, 43, 43)
?? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING).addComponent(jLabel2)
?? ??? ??? ??? ??? ??? ?.addComponent(jScrollPane1, GroupLayout.PREFERRED_SIZE, 134,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE))
?? ??? ??? ??? ?.addGap(41, 41, 41).addGroup(layout.createParallelGroup(GroupLayout.Alignment.BASELINE)
?? ??? ??? ??? ??? ??? ?.addComponent(jButton1).addComponent(jButton2))
?? ??? ??? ??? ?.addContainerGap(62, Short.MAX_VALUE)));

?? ??? ?pack();
?? ?}
?? ??? ?

?? ?private void jButton1ActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?String typeName = this.typeNameText.getText();
?? ??? ?String typeRemark = this.typeRemarkTtext.getText();
?? ??? ?if (StringUtil.isEmpty(typeName) || StringUtil.isEmpty(typeRemark)) {
?? ??? ??? ?JOptionPane.showMessageDialog(null, "請輸入相關信息");
?? ??? ??? ?return;
?? ??? ?}
?? ??? ?BookType bookType = new BookType();
?? ??? ?bookType.setTypeName(typeName);
?? ??? ?bookType.setRemark(typeRemark);
?? ??? ?Connection con = null;
?? ??? ?try {
?? ??? ??? ?con = dbUtil.getCon();
?? ??? ??? ?int i = bookTypeDao.add(con, bookType);
?? ??? ??? ?if (i == 1) {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "添加成功");
?? ??? ??? ??? ?reset();
?? ??? ??? ?} else if (i == 2) {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "添加失敗,類別已存在");
?? ??? ??? ?} else {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "添加失敗");
?? ??? ??? ?}
?? ??? ?} catch (Exception e) {
?? ??? ??? ?
?? ??? ??? ?e.printStackTrace();
?? ??? ?} finally {
?? ??? ??? ?try {
?? ??? ??? ??? ?dbUtil.closeCon(con);
?? ??? ??? ?} catch (Exception e) {
?? ??? ??? ??? ?
?? ??? ??? ??? ?e.printStackTrace();
?? ??? ??? ?}
?? ??? ?}
?? ?}

?? ?private void reset() {
?? ??? ?this.typeNameText.setText("");
?? ??? ?this.typeRemarkTtext.setText("");
?? ?}

?? ?private void jButton2ActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?reset();
?? ?}

}

BookTypeManagerFrm.java

package com.sjsq.view;

import java.sql.Connection;
import java.sql.ResultSet;
import java.util.Vector;

import javax.swing.BorderFactory;
import javax.swing.GroupLayout;
import javax.swing.JButton;
import javax.swing.JInternalFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.JTextField;
import javax.swing.LayoutStyle;
import javax.swing.table.DefaultTableModel;

import com.sjsq.dao.BookTypeDao;
import com.sjsq.model.BookType;
import com.sjsq.util.DbUtil;
import com.sjsq.util.StringUtil;

public class BookTypeManagerFrm extends JInternalFrame {
?? ?
?? ?private JButton jButton1;
?? ?private JButton jButton2;
?? ?private JLabel jLabel1;
?? ?private JLabel jLabel2;
?? ?private JLabel jLabel3;
?? ?private JPanel jPanel1;
?? ?private JScrollPane jScrollPane1;
?? ?private JTextField typeIdText;
?? ?private JTextField typeNameText;
?? ?private JTextField typeRemarkText;
?? ?private JTable typeTable;
?? ?
?? ?
?? ?DbUtil dbUtil = new DbUtil();
?? ?BookTypeDao bookTypeDao = new BookTypeDao();

?? ?
?? ?public BookTypeManagerFrm() {
?? ??? ?initComponents();
?? ??? ?fillTable();
?? ??? ?setTitle("圖書類別修改");
?? ??? ?this.setLocation(200, 30);
?? ?}

?? ?private void fillTable() {
?? ??? ?DefaultTableModel model = (DefaultTableModel) typeTable.getModel();
?? ??? ?model.setRowCount(0);
?? ??? ?Connection con = null;
?? ??? ?try {
?? ??? ??? ?con = dbUtil.getCon();
?? ??? ??? ?ResultSet list = bookTypeDao.list(con, new BookType());
?? ??? ??? ?while (list.next()) {
?? ??? ??? ??? ?Vector rowData = new Vector();
?? ??? ??? ??? ?rowData.add(list.getInt("id"));
?? ??? ??? ??? ?rowData.add(list.getString("type_name"));
?? ??? ??? ??? ?rowData.add(list.getString("remark"));
?? ??? ??? ??? ?model.addRow(rowData);
?? ??? ??? ?}
?? ??? ?} catch (Exception e) {
?? ??? ??? ?
?? ??? ??? ?e.printStackTrace();
?? ??? ?} finally {
?? ??? ??? ?try {
?? ??? ??? ??? ?dbUtil.closeCon(con);
?? ??? ??? ?} catch (Exception e) {
?? ??? ??? ??? ?
?? ??? ??? ??? ?e.printStackTrace();
?? ??? ??? ?}
?? ??? ?}
?? ?}
?? ?
?? ?private void initComponents() {

?? ??? ?jScrollPane1 = new JScrollPane();
?? ??? ?typeTable = new JTable();
?? ??? ?jPanel1 = new JPanel();
?? ??? ?jLabel1 = new JLabel();
?? ??? ?jLabel2 = new JLabel();
?? ??? ?jLabel3 = new JLabel();
?? ??? ?typeIdText = new JTextField();
?? ??? ?typeNameText = new JTextField();
?? ??? ?typeRemarkText = new JTextField();
?? ??? ?jButton1 = new JButton();
?? ??? ?jButton2 = new JButton();

?? ??? ?setClosable(true);

?? ??? ?typeTable.setModel(new DefaultTableModel(new Object[][] {

?? ??? ?}, new String[] { "編號", "類別名稱", "類別描述" }) {
?? ??? ??? ?boolean[] canEdit = new boolean[] { false, false, false };

?? ??? ??? ?public boolean isCellEditable(int rowIndex, int columnIndex) {
?? ??? ??? ??? ?return canEdit[columnIndex];
?? ??? ??? ?}
?? ??? ?});
?? ??? ?typeTable.addMouseListener(new java.awt.event.MouseAdapter() {
?? ??? ??? ?public void mousePressed(java.awt.event.MouseEvent evt) {
?? ??? ??? ??? ?typeTableMousePressed(evt);
?? ??? ??? ?}
?? ??? ?});
?? ??? ?jScrollPane1.setViewportView(typeTable);

?? ??? ?jPanel1.setBorder(BorderFactory.createTitledBorder("表單操作"));
?? ??? ?jPanel1.setToolTipText("");

?? ??? ?jLabel1.setText("編號:");

?? ??? ?jLabel2.setText("類別名稱:");

?? ??? ?jLabel3.setText("描述:");

?? ??? ?typeIdText.setEditable(false);

?? ??? ?jButton1.setText("修改");
?? ??? ?jButton1.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jButton1ActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});

?? ??? ?jButton2.setText("刪除");
?? ??? ?jButton2.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jButton2ActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});

?? ??? ?GroupLayout jPanel1Layout = new GroupLayout(jPanel1);
?? ??? ?jPanel1.setLayout(jPanel1Layout);
?? ??? ?jPanel1Layout.setHorizontalGroup(jPanel1Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ?.addGroup(jPanel1Layout.createSequentialGroup().addGroup(jPanel1Layout
?? ??? ??? ??? ??? ??? ?.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ??? ??? ?.addGroup(jPanel1Layout.createSequentialGroup().addGap(22, 22, 22).addGroup(jPanel1Layout
?? ??? ??? ??? ??? ??? ??? ??? ?.createParallelGroup(GroupLayout.Alignment.LEADING, false)
?? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(jPanel1Layout.createSequentialGroup().addComponent(jLabel3).addGap(18, 18, 18)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(typeRemarkText))
?? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(jPanel1Layout.createSequentialGroup().addComponent(jLabel1).addGap(18, 18, 18)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(typeIdText, GroupLayout.PREFERRED_SIZE, 123,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addGap(18, 18, 18)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(jPanel1Layout
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jButton2)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(jPanel1Layout.createSequentialGroup().addComponent(jLabel2)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addGap(18, 18, 18).addComponent(typeNameText,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE, 133,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE))))))
?? ??? ??? ??? ??? ??? ?.addGroup(jPanel1Layout.createSequentialGroup().addGap(41, 41, 41).addComponent(jButton1)))
?? ??? ??? ??? ??? ??? ?.addContainerGap(43, Short.MAX_VALUE)));
?? ??? ?jPanel1Layout.setVerticalGroup(jPanel1Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ?.addGroup(jPanel1Layout.createSequentialGroup().addGroup(jPanel1Layout
?? ??? ??? ??? ??? ??? ?.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ??? ??? ?.addGroup(jPanel1Layout.createParallelGroup(GroupLayout.Alignment.BASELINE)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jLabel1).addComponent(jLabel2).addComponent(typeNameText,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE))
?? ??? ??? ??? ??? ??? ?.addComponent(typeIdText, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE))
?? ??? ??? ??? ??? ??? ?.addGap(27, 27, 27)
?? ??? ??? ??? ??? ??? ?.addGroup(jPanel1Layout.createParallelGroup(GroupLayout.Alignment.BASELINE)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jLabel3).addComponent(typeRemarkText,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE))
?? ??? ??? ??? ??? ??? ?.addPreferredGap(LayoutStyle.ComponentPlacement.RELATED, 41, Short.MAX_VALUE)
?? ??? ??? ??? ??? ??? ?.addGroup(jPanel1Layout.createParallelGroup(GroupLayout.Alignment.BASELINE)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jButton1).addComponent(jButton2))
?? ??? ??? ??? ??? ??? ?.addContainerGap()));

?? ??? ?GroupLayout layout = new GroupLayout(getContentPane());
?? ??? ?getContentPane().setLayout(layout);
?? ??? ?layout.setHorizontalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING).addGroup(layout
?? ??? ??? ??? ?.createSequentialGroup().addGap(42, 42, 42)
?? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.TRAILING)
?? ??? ??? ??? ??? ??? ?.addComponent(jPanel1, GroupLayout.Alignment.LEADING,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.DEFAULT_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ?Short.MAX_VALUE)
?? ??? ??? ??? ??? ??? ?.addComponent(jScrollPane1, GroupLayout.Alignment.LEADING,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE, 452, GroupLayout.PREFERRED_SIZE))
?? ??? ??? ??? ?.addContainerGap(49, Short.MAX_VALUE)));
?? ??? ?layout.setVerticalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ?.addGroup(layout.createSequentialGroup().addContainerGap()
?? ??? ??? ??? ??? ??? ?.addComponent(jScrollPane1, GroupLayout.PREFERRED_SIZE, 137,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ?.addGap(51, 51, 51)
?? ??? ??? ??? ??? ??? ?.addComponent(jPanel1, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ?.addContainerGap(30, Short.MAX_VALUE)));

?? ??? ?pack();
?? ?}
?? ??? ?

?? ?private void jButton2ActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?String typeId = this.typeIdText.getText();
?? ??? ?if (StringUtil.isEmpty(typeId)) {
?? ??? ??? ?JOptionPane.showMessageDialog(null, "請選擇相關信息");
?? ??? ??? ?return;
?? ??? ?}
?? ??? ?Connection con = null;
?? ??? ?try {
?? ??? ??? ?con = dbUtil.getCon();
?? ??? ??? ?int i = bookTypeDao.delete(con, typeId);
?? ??? ??? ?if (i == 1) {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "刪除成功");
?? ??? ??? ??? ?fillTable();
?? ??? ??? ?} else if (i == 2) {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "刪除失敗-類別最少保留一個");
?? ??? ??? ?} else if (i == 3) {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "刪除失敗-該類別下有書籍");
?? ??? ??? ?} else {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "刪除失敗");
?? ??? ??? ?}
?? ??? ?} catch (Exception e) {
?? ??? ??? ?
?? ??? ??? ?e.printStackTrace();
?? ??? ??? ?JOptionPane.showMessageDialog(null, "刪除異常");
?? ??? ?} finally {
?? ??? ??? ?try {
?? ??? ??? ??? ?dbUtil.closeCon(con);
?? ??? ??? ?} catch (Exception e) {
?? ??? ??? ??? ?
?? ??? ??? ??? ?e.printStackTrace();
?? ??? ??? ?}
?? ??? ?}
?? ?}

?? ?private void jButton1ActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?String typeId = this.typeIdText.getText();
?? ??? ?String typeName = this.typeNameText.getText();
?? ??? ?String typeRemark = this.typeRemarkText.getText();
?? ??? ?if (StringUtil.isEmpty(typeName) || StringUtil.isEmpty(typeRemark)) {
?? ??? ??? ?JOptionPane.showMessageDialog(null, "請輸入相關信息");
?? ??? ??? ?return;
?? ??? ?}
?? ??? ?BookType bookType = new BookType();
?? ??? ?bookType.setTypeId(Integer.parseInt(typeId));
?? ??? ?bookType.setTypeName(typeName);
?? ??? ?bookType.setRemark(typeRemark);
?? ??? ?Connection con = null;
?? ??? ?try {
?? ??? ??? ?con = dbUtil.getCon();
?? ??? ??? ?int i = bookTypeDao.update(con, bookType);
?? ??? ??? ?if (i == 1) {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "修改成功");
?? ??? ??? ??? ?fillTable();
?? ??? ??? ?} else {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "修改失敗");
?? ??? ??? ?}
?? ??? ?} catch (Exception e) {
?? ??? ??? ?
?? ??? ??? ?e.printStackTrace();
?? ??? ??? ?JOptionPane.showMessageDialog(null, "修改異常");
?? ??? ?} finally {
?? ??? ??? ?try {
?? ??? ??? ??? ?dbUtil.closeCon(con);
?? ??? ??? ?} catch (Exception e) {
?? ??? ??? ??? ?
?? ??? ??? ??? ?e.printStackTrace();
?? ??? ??? ?}
?? ??? ?}
?? ?}

?? ?private void typeTableMousePressed(java.awt.event.MouseEvent evt) {
?? ??? ?int row = this.typeTable.getSelectedRow();
?? ??? ?this.typeIdText.setText(typeTable.getValueAt(row, 0).toString());
?? ??? ?this.typeNameText.setText(typeTable.getValueAt(row, 1).toString());
?? ??? ?this.typeRemarkText.setText(typeTable.getValueAt(row, 2).toString());
?? ?}

}

BorrowDetailFrm.java

package com.sjsq.view;

import java.sql.Connection;
import java.sql.ResultSet;
import java.util.Vector;

import javax.swing.GroupLayout;
import javax.swing.JInternalFrame;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.table.DefaultTableModel;

import com.sjsq.dao.BorrowDetailDao;
import com.sjsq.model.BorrowDetail;
import com.sjsq.util.DbUtil;
import com.sjsq.util.TimeUtil;

public class BorrowDetailFrm extends JInternalFrame {
?? ?
?? ?private JTable detailTable;
?? ?private JScrollPane jScrollPane1;
?? ?
?? ?
?? ?DbUtil dbUtil = new DbUtil();
?? ?BorrowDetailDao borrowDetailDao = new BorrowDetailDao();

?? ?
?? ?public BorrowDetailFrm() {
?? ??? ?initComponents();
?? ??? ?fillTable(new BorrowDetail());
?? ??? ?setTitle("借還信息");
?? ??? ?this.setLocation(200, 50);
?? ?}

?? ?private void fillTable(BorrowDetail borrowDetail) {
?? ??? ?DefaultTableModel model = (DefaultTableModel) detailTable.getModel();
?? ??? ?model.setRowCount(0);
?? ??? ?Connection con = null;
?? ??? ?try {
?? ??? ??? ?con = dbUtil.getCon();
?? ??? ??? ?ResultSet list = borrowDetailDao.list(con, borrowDetail);
?? ??? ??? ?while (list.next()) {
?? ??? ??? ??? ?Vector rowData = new Vector();
?? ??? ??? ??? ?rowData.add(list.getString("username"));
?? ??? ??? ??? ?rowData.add(list.getString("book_name"));
?? ??? ??? ??? ?int status = list.getInt("status");
?? ??? ??? ??? ?if (status == 1) {
?? ??? ??? ??? ??? ?rowData.add("在借");
?? ??? ??? ??? ?} else {
?? ??? ??? ??? ??? ?rowData.add("已還");
?? ??? ??? ??? ?}
?? ??? ??? ??? ?rowData.add(TimeUtil.getDateByTime(list.getLong("borrow_time")));
?? ??? ??? ??? ?if (status == 2) {
?? ??? ??? ??? ??? ?rowData.add(TimeUtil.getDateByTime(list.getLong("return_time")));
?? ??? ??? ??? ?}
?? ??? ??? ??? ?model.addRow(rowData);
?? ??? ??? ?}
?? ??? ?} catch (Exception e) {
?? ??? ??? ?
?? ??? ??? ?e.printStackTrace();
?? ??? ?} finally {
?? ??? ??? ?try {
?? ??? ??? ??? ?dbUtil.closeCon(con);
?? ??? ??? ?} catch (Exception e) {
?? ??? ??? ??? ?
?? ??? ??? ??? ?e.printStackTrace();
?? ??? ??? ?}
?? ??? ?}
?? ?}

?? ?
?? ?private void initComponents() {

?? ??? ?jScrollPane1 = new JScrollPane();
?? ??? ?detailTable = new JTable();

?? ??? ?setClosable(true);

?? ??? ?detailTable.setModel(new DefaultTableModel(new Object[][] {

?? ??? ?}, new String[] { "借書人", "書名", "狀態(tài)", "借書時間", "還書時間" }) {
?? ??? ??? ?boolean[] canEdit = new boolean[] { false, false, false, false, false };

?? ??? ??? ?public boolean isCellEditable(int rowIndex, int columnIndex) {
?? ??? ??? ??? ?return canEdit[columnIndex];
?? ??? ??? ?}
?? ??? ?});
?? ??? ?jScrollPane1.setViewportView(detailTable);

?? ??? ?GroupLayout layout = new GroupLayout(getContentPane());
?? ??? ?getContentPane().setLayout(layout);
?? ??? ?layout.setHorizontalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ?.addGroup(layout.createSequentialGroup().addContainerGap()
?? ??? ??? ??? ??? ??? ?.addComponent(jScrollPane1, GroupLayout.DEFAULT_SIZE, 700, Short.MAX_VALUE)
?? ??? ??? ??? ??? ??? ?.addContainerGap()));
?? ??? ?layout.setVerticalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ?.addGroup(layout
?? ??? ??? ??? ??? ??? ?.createSequentialGroup().addContainerGap().addComponent(jScrollPane1,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE, 366, GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ?.addContainerGap(25, Short.MAX_VALUE)));

?? ??? ?pack();
?? ?}
?? ??? ?
}

LoginFrm.java

package com.sjsq.view;

import java.sql.Connection;

import javax.swing.GroupLayout;
import javax.swing.JButton;
import javax.swing.JComboBox;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JTextField;
import javax.swing.LayoutStyle;
import javax.swing.WindowConstants;

import com.sjsq.dao.UserDao;
import com.sjsq.model.User;
import com.sjsq.util.DbUtil;
import com.sjsq.util.StringUtil;

public class LoginFrm extends JFrame {
?? ?public static User currentUser;
?? ?private JButton jB_login;
?? ?private JButton jB_reset;
?? ?private JLabel jLabel1;
?? ?private JLabel jLabel2;
?? ?private JLabel jLabel3;
?? ?private JTextField passwordText;
?? ?private JComboBox role;
?? ?private JTextField userNameText;
?? ?
?? ?UserDao userDao = new UserDao();
?? ?DbUtil dbUtil = new DbUtil();

?? ?
?? ?public LoginFrm() {
?? ??? ?initComponents();
?? ??? ?this.role.addItem("學生");
?? ??? ?this.role.addItem("管理員");
?? ??? ?this.setLocationRelativeTo(null);
?? ?}

?? ?
?? ?private void initComponents() {

?? ??? ?jLabel1 = new JLabel();
?? ??? ?jLabel2 = new JLabel();
?? ??? ?jLabel3 = new JLabel();
?? ??? ?jB_login = new JButton();
?? ??? ?jB_reset = new JButton();
?? ??? ?userNameText = new JTextField();
?? ??? ?passwordText = new JTextField();
?? ??? ?role = new JComboBox();

?? ??? ?setTitle("用戶登錄");
?? ??? ?setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
?? ??? ?setResizable(false);

?? ??? ?jLabel1.setText("賬號:");

?? ??? ?jLabel2.setText("密碼:");

?? ??? ?jLabel3.setText("角色:");

?? ??? ?jB_login.setText("登錄");
?? ??? ?jB_login.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jB_loginActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});

?? ??? ?jB_reset.setText("重置");
?? ??? ?jB_reset.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jB_resetActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});

?? ??? ?GroupLayout layout = new GroupLayout(getContentPane());
?? ??? ?getContentPane().setLayout(layout);
?? ??? ?layout.setHorizontalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING).addGroup(layout
?? ??? ??? ??? ?.createSequentialGroup().addGap(59, 59, 59)
?? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ??? ??? ?.addGroup(layout.createSequentialGroup().addComponent(jB_login).addGap(87, 87, 87)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jB_reset))
?? ??? ??? ??? ??? ??? ?.addGroup(layout.createSequentialGroup()
?? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.TRAILING)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jLabel3).addComponent(jLabel2).addComponent(jLabel1))
?? ??? ??? ??? ??? ??? ??? ??? ?.addGap(18, 18, 18)
?? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING, false)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(userNameText, GroupLayout.DEFAULT_SIZE, 150,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?Short.MAX_VALUE)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(passwordText)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(role, 0, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))))
?? ??? ??? ??? ?.addContainerGap(137, Short.MAX_VALUE)));
?? ??? ?layout.setVerticalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING).addGroup(layout
?? ??? ??? ??? ?.createSequentialGroup().addGap(49, 49, 49)
?? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.BASELINE).addComponent(jLabel1)
?? ??? ??? ??? ??? ??? ?.addComponent(userNameText, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE))
?? ??? ??? ??? ?.addGap(45, 45, 45)
?? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING).addComponent(jLabel2)
?? ??? ??? ??? ??? ??? ?.addComponent(passwordText, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE))
?? ??? ??? ??? ?.addGap(33, 33, 33)
?? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.BASELINE).addComponent(jLabel3)
?? ??? ??? ??? ??? ??? ?.addComponent(role, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE))
?? ??? ??? ??? ?.addPreferredGap(LayoutStyle.ComponentPlacement.RELATED, 42, Short.MAX_VALUE)
?? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.BASELINE).addComponent(jB_login)
?? ??? ??? ??? ??? ??? ?.addComponent(jB_reset))
?? ??? ??? ??? ?.addGap(37, 37, 37)));

?? ??? ?pack();
?? ?}

?? ?

?? ?private void jB_loginActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?String userName = this.userNameText.getText();
?? ??? ?String password = this.passwordText.getText();
?? ??? ?int index = this.role.getSelectedIndex();
?? ??? ?if (StringUtil.isEmpty(userName) || StringUtil.isEmpty(password)) {
?? ??? ??? ?JOptionPane.showMessageDialog(null, "請輸入相關信息");
?? ??? ??? ?return;
?? ??? ?}
?? ??? ?User user = new User();
?? ??? ?user.setUserName(userName);
?? ??? ?user.setPassword(password);
?? ??? ?if (index == 0) {
?? ??? ??? ?user.setRole(1);
?? ??? ?} else {
?? ??? ??? ?user.setRole(2);
?? ??? ?}
?? ??? ?Connection con = null;
?? ??? ?try {
?? ??? ??? ?con = dbUtil.getCon();
?? ??? ??? ?User login = userDao.login(con, user);
?? ??? ??? ?currentUser = login;
?? ??? ??? ?if (login == null) {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "登錄失敗");
?? ??? ??? ?} else {
?? ??? ??? ??? ?// 角色 1普通 2管理員
?? ??? ??? ??? ?if (index == 0) {
?? ??? ??? ??? ??? ?// 學生
?? ??? ??? ??? ??? ?this.dispose();
?? ??? ??? ??? ??? ?new UserMainFrm().setVisible(true);
?? ??? ??? ??? ?} else {
?? ??? ??? ??? ??? ?// 管理員
?? ??? ??? ??? ??? ?
?? ??? ??? ??? ??? ?this.dispose();
?? ??? ??? ??? ??? ?new AdminMainFrm().setVisible(true);
?? ??? ??? ??? ?}
?? ??? ??? ?}
?? ??? ?} catch (Exception e) {
?? ??? ??? ?
?? ??? ??? ?e.printStackTrace();
?? ??? ??? ?JOptionPane.showMessageDialog(null, "登錄異常");
?? ??? ?} finally {
?? ??? ??? ?try {
?? ??? ??? ??? ?dbUtil.closeCon(con);
?? ??? ??? ?} catch (Exception e) {
?? ??? ??? ??? ?
?? ??? ??? ??? ?e.printStackTrace();
?? ??? ??? ?}
?? ??? ?}

?? ?}

?? ?private void reset() {
?? ??? ?this.userNameText.setText("");
?? ??? ?this.passwordText.setText("");
?? ?}

?? ?private void jB_resetActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?reset();
?? ?}

?? ?public static void main(String args[]) {
?? ??? ?java.awt.EventQueue.invokeLater(new Runnable() {
?? ??? ??? ?public void run() {
?? ??? ??? ??? ?new LoginFrm().setVisible(true);
?? ??? ??? ?}
?? ??? ?});
?? ?}

}

RegisterFrm.java

package com.sjsq.view;

import java.sql.Connection;

import javax.swing.GroupLayout;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JTextField;
import javax.swing.LayoutStyle;
import javax.swing.WindowConstants;

import com.sjsq.dao.UserDao;
import com.sjsq.model.User;
import com.sjsq.util.DbUtil;
import com.sjsq.util.StringUtil;

public class RegisterFrm extends JFrame {
?? ?
?? ?private JButton jButton1;
?? ?private JButton jButton2;
?? ?private JLabel jLabel1;
?? ?private JLabel jLabel2;
?? ?private JTextField passwordText;
?? ?private JTextField userNameText;
?? ?
?? ?
?? ?DbUtil dbUtil = new DbUtil();
?? ?UserDao userDao = new UserDao();

?? ?
?? ?public RegisterFrm() {
?? ??? ?initComponents();
?? ??? ?this.setLocationRelativeTo(null);
?? ?}

?? ?
?? ?private void initComponents() {

?? ??? ?jLabel1 = new JLabel();
?? ??? ?jLabel2 = new JLabel();
?? ??? ?jButton1 = new JButton();
?? ??? ?jButton2 = new JButton();
?? ??? ?userNameText = new JTextField();
?? ??? ?passwordText = new JTextField();

?? ??? ?setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
?? ??? ?setTitle("用戶注冊");
?? ??? ?setResizable(false);

?? ??? ?jLabel1.setText("賬號:");

?? ??? ?jLabel2.setText("密碼:");

?? ??? ?jButton1.setText("注冊");
?? ??? ?jButton1.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jButton1ActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});

?? ??? ?jButton2.setText("重置");
?? ??? ?jButton2.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jButton2ActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});

?? ??? ?GroupLayout layout = new GroupLayout(getContentPane());
?? ??? ?getContentPane().setLayout(layout);
?? ??? ?layout.setHorizontalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING).addGroup(layout
?? ??? ??? ??? ?.createSequentialGroup().addGap(60, 60, 60)
?? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ??? ??? ?.addGroup(layout.createSequentialGroup().addComponent(jButton1).addGap(77, 77, 77)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jButton2))
?? ??? ??? ??? ??? ??? ?.addGroup(layout.createSequentialGroup()
?? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jLabel1).addComponent(jLabel2))
?? ??? ??? ??? ??? ??? ??? ??? ?.addGap(37, 37, 37)
?? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING, false)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(passwordText).addComponent(userNameText,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, 144, Short.MAX_VALUE))))
?? ??? ??? ??? ?.addContainerGap(123, Short.MAX_VALUE)));
?? ??? ?layout.setVerticalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING).addGroup(layout
?? ??? ??? ??? ?.createSequentialGroup().addGap(49, 49, 49)
?? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.BASELINE).addComponent(jLabel1)
?? ??? ??? ??? ??? ??? ?.addComponent(userNameText, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE))
?? ??? ??? ??? ?.addGap(48, 48, 48)
?? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.BASELINE).addComponent(jLabel2)
?? ??? ??? ??? ??? ??? ?.addComponent(passwordText, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE))
?? ??? ??? ??? ?.addPreferredGap(LayoutStyle.ComponentPlacement.RELATED, 68, Short.MAX_VALUE)
?? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.BASELINE).addComponent(jButton1)
?? ??? ??? ??? ??? ??? ?.addComponent(jButton2))
?? ??? ??? ??? ?.addGap(64, 64, 64)));

?? ??? ?pack();
?? ?}
?? ??? ?

?? ?private void jButton1ActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?String userName = this.userNameText.getText();
?? ??? ?String password = this.passwordText.getText();
?? ??? ?if (StringUtil.isEmpty(userName) || StringUtil.isEmpty(password)) {
?? ??? ??? ?JOptionPane.showMessageDialog(null, "請輸入相關信息");
?? ??? ??? ?return;
?? ??? ?}
?? ??? ?User user = new User();
?? ??? ?user.setUserName(userName);
?? ??? ?user.setPassword(password);
?? ??? ?user.setRole(1);
?? ??? ?Connection con = null;
?? ??? ?try {
?? ??? ??? ?con = dbUtil.getCon();
?? ??? ??? ?int i = userDao.addUser(con, user);
?? ??? ??? ?if (i == 2) {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "該用戶名已存在,請重新注冊");
?? ??? ??? ?} else if (i == 0) {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "注冊失敗");
?? ??? ??? ?} else {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "注冊成功");
?? ??? ??? ??? ?this.dispose();
?? ??? ??? ??? ?new LoginFrm().setVisible(true);
?? ??? ??? ?}
?? ??? ?} catch (Exception e) {
?? ??? ??? ?
?? ??? ??? ?e.printStackTrace();
?? ??? ?} finally {
?? ??? ??? ?try {
?? ??? ??? ??? ?dbUtil.closeCon(con);
?? ??? ??? ?} catch (Exception e) {
?? ??? ??? ??? ?
?? ??? ??? ??? ?e.printStackTrace();
?? ??? ??? ?}
?? ??? ?}
?? ?}

?? ?private void reset() {
?? ??? ?this.userNameText.setText("");
?? ??? ?this.passwordText.setText("");
?? ?}

?? ?private void jButton2ActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?reset();
?? ?}

?? ?public static void main(String args[]) {
?? ??? ?java.awt.EventQueue.invokeLater(new Runnable() {
?? ??? ??? ?public void run() {
?? ??? ??? ??? ?new RegisterFrm().setVisible(true);
?? ??? ??? ?}
?? ??? ?});
?? ?}

}

UserBorrowDetail.java

package com.sjsq.view;

import java.sql.Connection;
import java.sql.ResultSet;
import java.util.Vector;

import javax.swing.GroupLayout;
import javax.swing.JButton;
import javax.swing.JInternalFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.JTextField;
import javax.swing.LayoutStyle;
import javax.swing.table.DefaultTableModel;

import com.sjsq.dao.BorrowDetailDao;
import com.sjsq.model.BorrowDetail;
import com.sjsq.util.DbUtil;
import com.sjsq.util.StringUtil;
import com.sjsq.util.TimeUtil;

public class UserBorrowDetail extends JInternalFrame {
?? ?
?? ?private JTextField borrowIdText;
?? ?private JTable borrowTbale;
?? ?private JButton jB_return;
?? ?private JLabel jLabel1;
?? ?private JScrollPane jScrollPane1;
?? ?
?? ?
?? ?DbUtil dbUtil = new DbUtil();
?? ?BorrowDetailDao borrowDetailDao = new BorrowDetailDao();

?? ?
?? ?public UserBorrowDetail() {
?? ??? ?initComponents();
?? ??? ?fillTable(new BorrowDetail());
?? ??? ?this.jB_return.setVisible(false);
?? ??? ?setTitle("借還信息");
?? ??? ?this.setLocation(200, 50);
?? ?}

?? ?private void fillTable(BorrowDetail borrowDetail) {
?? ??? ?DefaultTableModel model = (DefaultTableModel) borrowTbale.getModel();
?? ??? ?model.setRowCount(0);
?? ??? ?Integer userId = LoginFrm.currentUser.getUserId();
?? ??? ?Connection con = null;
?? ??? ?try {
?? ??? ??? ?con = dbUtil.getCon();
?? ??? ??? ?borrowDetail.setUserId(userId);
?? ??? ??? ?ResultSet list = borrowDetailDao.list(con, borrowDetail);
?? ??? ??? ?while (list.next()) {
?? ??? ??? ??? ?Vector rowData = new Vector();
?? ??? ??? ??? ?rowData.add(list.getInt("id"));
?? ??? ??? ??? ?rowData.add(list.getString("book_name"));
?? ??? ??? ??? ?int status = list.getInt("status");
?? ??? ??? ??? ?if (status == 1) {
?? ??? ??? ??? ??? ?rowData.add("在借");
?? ??? ??? ??? ?}
?? ??? ??? ??? ?if (status == 2) {
?? ??? ??? ??? ??? ?rowData.add("已還");
?? ??? ??? ??? ?}
?? ??? ??? ??? ?rowData.add(TimeUtil.getDateByTime(list.getLong("borrow_time")));
?? ??? ??? ??? ?if (status == 2) {
?? ??? ??? ??? ??? ?rowData.add(TimeUtil.getDateByTime(list.getLong("return_time")));
?? ??? ??? ??? ?}
?? ??? ??? ??? ?model.addRow(rowData);
?? ??? ??? ?}
?? ??? ?} catch (Exception e) {
?? ??? ??? ?
?? ??? ??? ?e.printStackTrace();
?? ??? ?} finally {
?? ??? ??? ?try {
?? ??? ??? ??? ?dbUtil.closeCon(con);
?? ??? ??? ?} catch (Exception e) {
?? ??? ??? ??? ?
?? ??? ??? ??? ?e.printStackTrace();
?? ??? ??? ?}
?? ??? ?}
?? ?}
?? ?
?? ?private void initComponents() {

?? ??? ?jScrollPane1 = new JScrollPane();
?? ??? ?borrowTbale = new JTable();
?? ??? ?jLabel1 = new JLabel();
?? ??? ?borrowIdText = new JTextField();
?? ??? ?jB_return = new JButton();

?? ??? ?setClosable(true);

?? ??? ?borrowTbale.setModel(new DefaultTableModel(new Object[][] {

?? ??? ?}, new String[] { "編號", "書名", "狀態(tài)", "借書時間", "還書時間" }) {
?? ??? ??? ?boolean[] canEdit = new boolean[] { false, false, false, false, false };

?? ??? ??? ?public boolean isCellEditable(int rowIndex, int columnIndex) {
?? ??? ??? ??? ?return canEdit[columnIndex];
?? ??? ??? ?}
?? ??? ?});
?? ??? ?borrowTbale.addMouseListener(new java.awt.event.MouseAdapter() {
?? ??? ??? ?public void mousePressed(java.awt.event.MouseEvent evt) {
?? ??? ??? ??? ?borrowTbaleMousePressed(evt);
?? ??? ??? ?}
?? ??? ?});
?? ??? ?jScrollPane1.setViewportView(borrowTbale);

?? ??? ?jLabel1.setText("編號:");

?? ??? ?borrowIdText.setEditable(false);

?? ??? ?jB_return.setText("還書");
?? ??? ?jB_return.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jB_returnActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});

?? ??? ?GroupLayout layout = new GroupLayout(getContentPane());
?? ??? ?getContentPane().setLayout(layout);
?? ??? ?layout.setHorizontalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ?.addGroup(layout.createSequentialGroup().addGap(35, 35, 35).addComponent(jLabel1).addGap(38, 38, 38)
?? ??? ??? ??? ??? ??? ?.addComponent(borrowIdText, GroupLayout.PREFERRED_SIZE, 114,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ?.addPreferredGap(LayoutStyle.ComponentPlacement.RELATED, 282, Short.MAX_VALUE)
?? ??? ??? ??? ??? ??? ?.addComponent(jB_return).addGap(44, 44, 44))
?? ??? ??? ??? ?.addGroup(layout.createSequentialGroup().addContainerGap()
?? ??? ??? ??? ??? ??? ?.addComponent(jScrollPane1, GroupLayout.DEFAULT_SIZE, 700, Short.MAX_VALUE)
?? ??? ??? ??? ??? ??? ?.addContainerGap()));
?? ??? ?layout.setVerticalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING).addGroup(layout
?? ??? ??? ??? ?.createSequentialGroup()
?? ??? ??? ??? ?.addComponent(jScrollPane1, GroupLayout.PREFERRED_SIZE, 239,
?? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ?.addGap(18, 18, 18)
?? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.BASELINE).addComponent(jLabel1)
?? ??? ??? ??? ??? ??? ?.addComponent(borrowIdText, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ?.addComponent(jB_return))
?? ??? ??? ??? ?.addContainerGap(26, Short.MAX_VALUE)));

?? ??? ?pack();
?? ?}
?? ??? ?

?? ?private void jB_returnActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?String BorrowStr = this.borrowIdText.getText();
?? ??? ?if (StringUtil.isEmpty(BorrowStr)) {
?? ??? ??? ?JOptionPane.showMessageDialog(null, "請選擇未還的書籍");
?? ??? ??? ?return;
?? ??? ?}
?? ??? ?BorrowDetail detail = new BorrowDetail();
?? ??? ?detail.setBorrowId(Integer.parseInt(BorrowStr));
?? ??? ?detail.setStatus(2);
?? ??? ?detail.setReturnTime(TimeUtil.getTime());
?? ??? ?Connection con = null;
?? ??? ?try {
?? ??? ??? ?con = dbUtil.getCon();
?? ??? ??? ?int i = borrowDetailDao.returnBook(con, detail);
?? ??? ??? ?if (i == 1) {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "還書成功");
?? ??? ??? ?} else {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "還書失敗");
?? ??? ??? ?}
?? ??? ?} catch (Exception e) {
?? ??? ??? ?
?? ??? ??? ?e.printStackTrace();
?? ??? ??? ?JOptionPane.showMessageDialog(null, "還書異常");
?? ??? ?} finally {
?? ??? ??? ?try {
?? ??? ??? ??? ?dbUtil.closeCon(con);
?? ??? ??? ?} catch (Exception e) {
?? ??? ??? ??? ?
?? ??? ??? ??? ?e.printStackTrace();
?? ??? ??? ?}
?? ??? ?}
?? ??? ?fillTable(new BorrowDetail());
?? ?}

?? ?private void borrowTbaleMousePressed(java.awt.event.MouseEvent evt) {
?? ??? ?int row = borrowTbale.getSelectedRow();
?? ??? ?Integer borrowId = (Integer) borrowTbale.getValueAt(row, 0);
?? ??? ?String status = (String) borrowTbale.getValueAt(row, 2);
?? ??? ?this.borrowIdText.setText(borrowId.toString());
?? ??? ?if (status.equals("在借")) {
?? ??? ??? ?this.jB_return.setVisible(true);
?? ??? ?} else {
?? ??? ??? ?this.jB_return.setVisible(false);
?? ??? ?}
?? ?}
}

UserInfoFrm.java

package com.sjsq.view;

import java.sql.Connection;
import java.sql.ResultSet;
import java.util.Vector;

import javax.swing.BorderFactory;
import javax.swing.GroupLayout;
import javax.swing.JButton;
import javax.swing.JInternalFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.JTextField;
import javax.swing.LayoutStyle;
import javax.swing.table.DefaultTableModel;

import com.sjsq.dao.UserDao;
import com.sjsq.model.User;
import com.sjsq.util.DbUtil;
import com.sjsq.util.StringUtil;

public class UserInfoFrm extends JInternalFrame {
?? ?
?? ?private JButton jButton1;
?? ?private JButton jButton2;
?? ?private JLabel jLabel1;
?? ?private JLabel jLabel2;
?? ?private JLabel jLabel3;
?? ?private JLabel jLabel4;
?? ?private JLabel jLabel5;
?? ?private JPanel jPanel1;
?? ?private JPanel jPanel2;
?? ?private JScrollPane jScrollPane1;
?? ?private JTextField passwordText;
?? ?private JTextField userIdText;
?? ?private JTextField userNameText;
?? ?private JTextField userNaneSelectText;
?? ?private JTable userTable;
?? ?
?? ?
?? ?DbUtil dbUtil = new DbUtil();
?? ?UserDao userDao = new UserDao();

?? ?
?? ?public UserInfoFrm() {
?? ??? ?initComponents();
?? ??? ?fillTable(new User());
?? ??? ?setTitle("用戶信息");
?? ??? ?this.setLocation(200, 50);
?? ?}

?? ?private void fillTable(User user) {
?? ??? ?DefaultTableModel model = (DefaultTableModel) userTable.getModel();
?? ??? ?model.setRowCount(0);

?? ??? ?Connection con = null;
?? ??? ?try {
?? ??? ??? ?con = dbUtil.getCon();
?? ??? ??? ?ResultSet list = userDao.list(con, user);
?? ??? ??? ?while (list.next()) {
?? ??? ??? ??? ?Vector rowData = new Vector();
?? ??? ??? ??? ?rowData.add(list.getInt("id"));
?? ??? ??? ??? ?rowData.add(list.getString("username"));
?? ??? ??? ??? ?rowData.add(list.getString("password"));
?? ??? ??? ??? ?model.addRow(rowData);
?? ??? ??? ?}
?? ??? ?} catch (Exception e) {
?? ??? ??? ?
?? ??? ??? ?e.printStackTrace();
?? ??? ?} finally {
?? ??? ??? ?try {
?? ??? ??? ??? ?dbUtil.closeCon(con);
?? ??? ??? ?} catch (Exception e) {
?? ??? ??? ??? ?
?? ??? ??? ??? ?e.printStackTrace();
?? ??? ??? ?}
?? ??? ?}
?? ?}

?? ?
?? ?private void initComponents() {

?? ??? ?jLabel2 = new JLabel();
?? ??? ?jScrollPane1 = new JScrollPane();
?? ??? ?userTable = new JTable();
?? ??? ?jPanel1 = new JPanel();
?? ??? ?jLabel1 = new JLabel();
?? ??? ?jButton1 = new JButton();
?? ??? ?userNaneSelectText = new JTextField();
?? ??? ?jPanel2 = new JPanel();
?? ??? ?jLabel3 = new JLabel();
?? ??? ?userIdText = new JTextField();
?? ??? ?jLabel4 = new JLabel();
?? ??? ?userNameText = new JTextField();
?? ??? ?jLabel5 = new JLabel();
?? ??? ?passwordText = new JTextField();
?? ??? ?jButton2 = new JButton();

?? ??? ?jLabel2.setText("jLabel2");

?? ??? ?setClosable(true);

?? ??? ?userTable.setModel(new DefaultTableModel(new Object[][] {

?? ??? ?}, new String[] { "編號", "賬號", "密碼" }) {
?? ??? ??? ?boolean[] canEdit = new boolean[] { false, false, false };

?? ??? ??? ?public boolean isCellEditable(int rowIndex, int columnIndex) {
?? ??? ??? ??? ?return canEdit[columnIndex];
?? ??? ??? ?}
?? ??? ?});
?? ??? ?userTable.addMouseListener(new java.awt.event.MouseAdapter() {
?? ??? ??? ?public void mousePressed(java.awt.event.MouseEvent evt) {
?? ??? ??? ??? ?userTableMousePressed(evt);
?? ??? ??? ?}
?? ??? ?});
?? ??? ?jScrollPane1.setViewportView(userTable);

?? ??? ?jPanel1.setBorder(BorderFactory.createTitledBorder("表單操作"));

?? ??? ?jLabel1.setText("賬號:");

?? ??? ?jButton1.setText("查詢");
?? ??? ?jButton1.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jButton1ActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});

?? ??? ?GroupLayout jPanel1Layout = new GroupLayout(jPanel1);
?? ??? ?jPanel1.setLayout(jPanel1Layout);
?? ??? ?jPanel1Layout.setHorizontalGroup(jPanel1Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ?.addGroup(jPanel1Layout.createSequentialGroup().addContainerGap().addComponent(jLabel1)
?? ??? ??? ??? ??? ??? ?.addGap(18, 18, 18)
?? ??? ??? ??? ??? ??? ?.addComponent(userNaneSelectText, GroupLayout.DEFAULT_SIZE, 184, Short.MAX_VALUE)
?? ??? ??? ??? ??? ??? ?.addGap(18, 18, 18).addComponent(jButton1).addContainerGap()));
?? ??? ?jPanel1Layout.setVerticalGroup(jPanel1Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ?.addGroup(jPanel1Layout.createSequentialGroup().addGroup(jPanel1Layout
?? ??? ??? ??? ??? ??? ?.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ??? ??? ?.addGroup(jPanel1Layout.createParallelGroup(GroupLayout.Alignment.BASELINE)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jLabel1).addComponent(userNaneSelectText,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE))
?? ??? ??? ??? ??? ??? ?.addComponent(jButton1))
?? ??? ??? ??? ??? ??? ?.addContainerGap(GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)));

?? ??? ?jPanel2.setBorder(BorderFactory.createTitledBorder("用戶操作"));

?? ??? ?jLabel3.setText("編號:");

?? ??? ?userIdText.setEditable(false);

?? ??? ?jLabel4.setText("賬號:");

?? ??? ?jLabel5.setText("密碼:");

?? ??? ?jButton2.setText("修改");
?? ??? ?jButton2.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jButton2ActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});

?? ??? ?GroupLayout jPanel2Layout = new GroupLayout(jPanel2);
?? ??? ?jPanel2.setLayout(jPanel2Layout);
?? ??? ?jPanel2Layout.setHorizontalGroup(jPanel2Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ?.addGroup(jPanel2Layout.createSequentialGroup().addContainerGap()
?? ??? ??? ??? ??? ??? ?.addGroup(jPanel2Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(jPanel2Layout.createSequentialGroup().addComponent(jLabel3)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(userIdText, GroupLayout.PREFERRED_SIZE, 85,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addGap(18, 18, 18).addComponent(jLabel4))
?? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(jPanel2Layout.createSequentialGroup().addComponent(jLabel5)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(passwordText, GroupLayout.PREFERRED_SIZE, 88,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE)))
?? ??? ??? ??? ??? ??? ?.addGroup(jPanel2Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(jPanel2Layout.createSequentialGroup().addGap(37, 37, 37).addComponent(
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?userNameText, GroupLayout.PREFERRED_SIZE, 94,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE))
?? ??? ??? ??? ??? ??? ??? ??? ?.addGroup(jPanel2Layout.createSequentialGroup().addGap(8, 8, 8).addComponent(jButton2)))
?? ??? ??? ??? ??? ??? ?.addContainerGap(26, Short.MAX_VALUE)));
?? ??? ?jPanel2Layout.setVerticalGroup(jPanel2Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ?.addGroup(jPanel2Layout.createSequentialGroup()
?? ??? ??? ??? ??? ??? ?.addGroup(jPanel2Layout.createParallelGroup(GroupLayout.Alignment.BASELINE)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jLabel3).addComponent(jLabel4)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(userIdText, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(userNameText, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE))
?? ??? ??? ??? ??? ??? ?.addGap(29, 29, 29)
?? ??? ??? ??? ??? ??? ?.addGroup(jPanel2Layout.createParallelGroup(GroupLayout.Alignment.BASELINE)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jLabel5)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(passwordText, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ??? ??? ?.addComponent(jButton2))
?? ??? ??? ??? ??? ??? ?.addContainerGap(37, Short.MAX_VALUE)));

?? ??? ?GroupLayout layout = new GroupLayout(getContentPane());
?? ??? ?getContentPane().setLayout(layout);
?? ??? ?layout.setHorizontalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING).addGroup(layout
?? ??? ??? ??? ?.createSequentialGroup().addGap(24, 24, 24)
?? ??? ??? ??? ?.addGroup(layout.createParallelGroup(GroupLayout.Alignment.TRAILING)
?? ??? ??? ??? ??? ??? ?.addComponent(jPanel2, GroupLayout.Alignment.LEADING,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.DEFAULT_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ?Short.MAX_VALUE)
?? ??? ??? ??? ??? ??? ?.addComponent(jScrollPane1, GroupLayout.Alignment.LEADING, 0, 0, Short.MAX_VALUE)
?? ??? ??? ??? ??? ??? ?.addComponent(jPanel1, GroupLayout.Alignment.LEADING,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.DEFAULT_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ?Short.MAX_VALUE))
?? ??? ??? ??? ?.addGap(226, 226, 226)));
?? ??? ?layout.setVerticalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING)
?? ??? ??? ??? ?.addGroup(layout.createSequentialGroup()
?? ??? ??? ??? ??? ??? ?.addComponent(jPanel1, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ?.addGap(28, 28, 28)
?? ??? ??? ??? ??? ??? ?.addComponent(jScrollPane1, GroupLayout.PREFERRED_SIZE, 136,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ?.addPreferredGap(LayoutStyle.ComponentPlacement.UNRELATED)
?? ??? ??? ??? ??? ??? ?.addComponent(jPanel2, GroupLayout.PREFERRED_SIZE,
?? ??? ??? ??? ??? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
?? ??? ??? ??? ??? ??? ?.addContainerGap(16, Short.MAX_VALUE)));

?? ??? ?pack();
?? ?}
?? ??? ?

?? ?private void userTableMousePressed(java.awt.event.MouseEvent evt) {
?? ??? ?int row = this.userTable.getSelectedRow();
?? ??? ?this.userIdText.setText(userTable.getValueAt(row, 0).toString());
?? ??? ?this.userNameText.setText(userTable.getValueAt(row, 1).toString());
?? ??? ?this.passwordText.setText(userTable.getValueAt(row, 2).toString());
?? ?}

?? ?private void jButton2ActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?String userId = this.userIdText.getText();
?? ??? ?String userName = this.userNameText.getText();
?? ??? ?String password = this.passwordText.getText();
?? ??? ?if (StringUtil.isEmpty(userName) || StringUtil.isEmpty(password)) {
?? ??? ??? ?JOptionPane.showMessageDialog(null, "請輸入相關信息");
?? ??? ??? ?return;
?? ??? ?}
?? ??? ?User user = new User();
?? ??? ?user.setUserId(Integer.parseInt(userId));
?? ??? ?user.setUserName(userName);
?? ??? ?user.setPassword(password);
?? ??? ?Connection con = null;
?? ??? ?try {
?? ??? ??? ?con = dbUtil.getCon();
?? ??? ??? ?int i = userDao.update(con, user);
?? ??? ??? ?if (i == 1) {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "修改成功");
?? ??? ??? ??? ?fillTable(new User());
?? ??? ??? ?} else {
?? ??? ??? ??? ?JOptionPane.showMessageDialog(null, "修改失敗");
?? ??? ??? ?}
?? ??? ?} catch (Exception e) {
?? ??? ??? ?
?? ??? ??? ?e.printStackTrace();
?? ??? ??? ?JOptionPane.showMessageDialog(null, "修改異常");
?? ??? ?} finally {
?? ??? ??? ?try {
?? ??? ??? ??? ?dbUtil.closeCon(con);
?? ??? ??? ?} catch (Exception e) {
?? ??? ??? ??? ?
?? ??? ??? ??? ?e.printStackTrace();
?? ??? ??? ?}
?? ??? ?}
?? ?}

?? ?private void jButton1ActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?String userName = this.userNaneSelectText.getText();
?? ??? ?User user = new User();
?? ??? ?user.setUserName(userName);
?? ??? ?fillTable(user);
?? ?}
}

UserMainFrm.java

package com.sjsq.view;

import javax.swing.GroupLayout;
import javax.swing.JDesktopPane;
import javax.swing.JFrame;
import javax.swing.JMenu;
import javax.swing.JMenuBar;
import javax.swing.JMenuItem;
import javax.swing.JOptionPane;
import javax.swing.WindowConstants;

public class UserMainFrm extends JFrame {

?? ?private JMenu jMenu1;
?? ?private JMenuBar jMenuBar1;
?? ?private JMenuItem jMenuItem1;
?? ?private JMenuItem jMenuItem2;
?? ?private JMenuItem jMenuItem3;
?? ?private JDesktopPane userMainjdp;

?? ?public UserMainFrm() {
?? ??? ?initComponents();
?? ??? ?// 設置位置
?? ??? ?setBounds(100, 200, 1050, 650);
?? ??? ?// 居中顯示
?? ??? ?this.setLocationRelativeTo(null);
?? ?}

?? ?private void initComponents() {

?? ??? ?userMainjdp = new JDesktopPane();
?? ??? ?jMenuBar1 = new JMenuBar();
?? ??? ?jMenu1 = new JMenu();
?? ??? ?jMenuItem1 = new JMenuItem();
?? ??? ?jMenuItem2 = new JMenuItem();
?? ??? ?jMenuItem3 = new JMenuItem();

?? ??? ?setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
?? ??? ?setTitle("圖書者主界面");
?? ??? ?
?? ??? ?jMenu1.setText("基本信息");

?? ??? ?jMenuItem1.setText("書籍信息");
?? ??? ?jMenuItem1.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jMenuItem1ActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});
?? ??? ?jMenu1.add(jMenuItem1);

?? ??? ?jMenuItem2.setText("借書記錄");
?? ??? ?jMenuItem2.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jMenuItem2ActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});
?? ??? ?jMenu1.add(jMenuItem2);

?? ??? ?jMenuItem3.setText("退出系統(tǒng)");
?? ??? ?jMenuItem3.addActionListener(new java.awt.event.ActionListener() {
?? ??? ??? ?public void actionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ??? ??? ?jMenuItem3ActionPerformed(evt);
?? ??? ??? ?}
?? ??? ?});
?? ??? ?jMenu1.add(jMenuItem3);

?? ??? ?jMenuBar1.add(jMenu1);

?? ??? ?setJMenuBar(jMenuBar1);

?? ??? ?GroupLayout layout = new GroupLayout(getContentPane());
?? ??? ?getContentPane().setLayout(layout);
?? ??? ?layout.setHorizontalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING).addComponent(userMainjdp,
?? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, 400, Short.MAX_VALUE));
?? ??? ?layout.setVerticalGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING).addComponent(userMainjdp,
?? ??? ??? ??? ?GroupLayout.DEFAULT_SIZE, 279, Short.MAX_VALUE));

?? ??? ?pack();
?? ?}

?? ?private void jMenuItem3ActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?int i = JOptionPane.showConfirmDialog(null, "確認退出系統(tǒng)");
?? ??? ?if (i == 0) {
?? ??? ??? ?this.dispose();
?? ??? ?}
?? ?}

?? ?private void jMenuItem2ActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?UserBorrowDetail userBorrowDetail = new UserBorrowDetail();
?? ??? ?userBorrowDetail.setVisible(true);
?? ??? ?this.userMainjdp.add(userBorrowDetail);
?? ?}

?? ?private void jMenuItem1ActionPerformed(java.awt.event.ActionEvent evt) {
?? ??? ?BookInfoFrm infoFrm = new BookInfoFrm();
?? ??? ?infoFrm.setVisible(true);
?? ??? ?this.userMainjdp.add(infoFrm);
?? ?}

?? ?public static void main(String args[]) {
?? ??? ?java.awt.EventQueue.invokeLater(new Runnable() {
?? ??? ??? ?public void run() {
?? ??? ??? ??? ?new UserMainFrm().setVisible(true);
?? ??? ??? ?}
?? ??? ?});
?? ?}

}

UserManagerFrm.java

package com.sjsq.view;

import javax.swing.GroupLayout;
import javax.swing.JInternalFrame;

public class UserManagerFrm extends JInternalFrame {

?? ?public UserManagerFrm() {
?? ??? ?initComponents();
?? ?}

?? ?private void initComponents() {

?? ??? ?setClosable(true);

?? ??? ?GroupLayout layout = new GroupLayout(getContentPane());
?? ??? ?getContentPane().setLayout(layout);
?? ??? ?layout.setHorizontalGroup(
?? ??? ??? ??? ?layout.createParallelGroup(GroupLayout.Alignment.LEADING).addGap(0, 394, Short.MAX_VALUE));
?? ??? ?layout.setVerticalGroup(
?? ??? ??? ??? ?layout.createParallelGroup(GroupLayout.Alignment.LEADING).addGap(0, 278, Short.MAX_VALUE));

?? ??? ?pack();
?? ?}

}

 

相關文章

  • MyBatisPlus超詳細分析條件查詢

    MyBatisPlus超詳細分析條件查詢

    這篇文章主要介紹了MyBatisPlus條件查詢的使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-08-08
  • 使用注解@Validated和BindingResult對入參進行非空校驗方式

    使用注解@Validated和BindingResult對入參進行非空校驗方式

    這篇文章主要介紹了使用注解@Validated和BindingResult對入參進行非空校驗方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • Java中ArrayList初始化的四種方法詳解

    Java中ArrayList初始化的四種方法詳解

    這篇文章主要介紹了Java中ArrayList初始化的四種方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-04-04
  • java實現excel導出合并單元格的步驟詳解

    java實現excel導出合并單元格的步驟詳解

    這篇文章主要介紹了java實現excel導出合并單元格,通過使用Apache POI庫,我們可以方便地創(chuàng)建Excel文件、填充數據、合并單元格和導出Excel文件,需要的朋友可以參考下
    2023-04-04
  • 新手了解java基礎知識(一)

    新手了解java基礎知識(一)

    這篇文章主要介紹了Java基礎知識,本文介紹了Java語言相關的基礎知識、歷史介紹、主要應用方向等內容,需要的朋友可以參考下,希望對你有所幫助
    2021-07-07
  • 使用AOP+反射實現自定義Mybatis多表關聯(lián)查詢

    使用AOP+反射實現自定義Mybatis多表關聯(lián)查詢

    這篇文章主要介紹了使用AOP+反射實現自定義Mybatis多表關聯(lián),目前的需求是增強現有的查詢,使用簡單的注解即可實現多表關聯(lián),本文通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2022-05-05
  • IDEA maven依賴錯誤中包下面紅色波浪線

    IDEA maven依賴錯誤中包下面紅色波浪線

    這篇文章主要介紹了IDEA maven依賴錯誤中包下面紅色波浪線,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-08-08
  • RepeatSubmit若依框架如何防止表單重復提交注解

    RepeatSubmit若依框架如何防止表單重復提交注解

    若依框架中的@RepeatSubmit注解用于防止表單重復提交,通過在控制器方法上添加該注解,并在前端頁面和JavaScript代碼中實現雙重校驗,可以確保同一用戶在短時間內不會重復提交相同的表單
    2024-11-11
  • JDBC用法小結

    JDBC用法小結

    這篇文章主要介紹了JDBC用法,較為詳細的分析了基于JDBC進行數據庫操作的技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2014-12-12
  • 詳解Spring-Boot中如何使用多線程處理任務

    詳解Spring-Boot中如何使用多線程處理任務

    本篇文章主要介紹了詳解Spring-Boot中如何使用多線程處理任務,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2017-03-03

最新評論

亚洲午夜伦理视频在线| 天天干天天插天天谢| 青青青艹视频在线观看| 国产高清在线观看1区2区| 日本真人性生活视频免费看| av天堂中文字幕最新| 插逼视频双插洞国产操逼插洞| 精品国产污污免费网站入口自| 欧亚乱色一区二区三区| 无码中文字幕波多野不卡 | 91精品国产麻豆国产| 成人国产激情自拍三区| okirakuhuhu在线观看| 久久精品视频一区二区三区四区| 中国黄片视频一区91| 1000部国产精品成人观看视频| 丝袜长腿第一页在线| 日本啪啪啪啪啪啪啪| 在线观看操大逼视频| 国产女人露脸高潮对白视频| av中文字幕在线观看第三页| 成年人黄视频在线观看| 丰满的继坶3中文在线观看| 少妇高潮一区二区三区| 美女大bxxxx内射| 亚洲公开视频在线观看| 亚洲av日韩高清hd| 2017亚洲男人天堂| av在线shipin| 91国语爽死我了不卡| 福利一二三在线视频观看| 亚洲av午夜免费观看| 青青草在观免费国产精品| 欧美日本在线视频一区| 人人妻人人澡欧美91精品| 97超碰最新免费在线观看| 521精品视频在线观看| 99精品免费观看视频| 成年人啪啪视频在线观看| 亚洲成人av一区久久| 熟女少妇激情五十路| 亚洲午夜伦理视频在线| 337p日本大胆欧美人| 伊拉克及约旦宣布关闭领空| 日韩欧美中文国产在线| 午夜精品亚洲精品五月色| 欧美日本国产自视大全| 亚洲精品 欧美日韩| 免费岛国喷水视频在线观看 | av老司机精品在线观看| 亚洲成人情色电影在线观看| 精品一区二区三区在线观看| 亚洲精品午夜aaa久久| 丰满的子国产在线观看| 国产九色91在线视频| 日本一道二三区视频久久| av黄色成人在线观看| 日韩在线视频观看有码在线| 中文字幕一区二区自拍| 色97视频在线播放| 亚洲日本一区二区三区 | 六月婷婷激情一区二区三区| 午夜精彩视频免费一区| av中文字幕国产在线观看| 亚洲欧洲一区二区在线观看| 日本啪啪啪啪啪啪啪| 亚洲成人情色电影在线观看| 欧美亚洲国产成人免费在线 | 亚洲区欧美区另类最新章节| 快插进小逼里大鸡吧视频| 超pen在线观看视频公开97 | 久久美欧人妻少妇一区二区三区| 极品粉嫩小泬白浆20p主播 | 国产麻豆剧传媒精品国产av蜜桃| 日本一道二三区视频久久| 日本成人不卡一区二区| 人妻丝袜精品中文字幕| 国产极品精品免费视频| 欧美视频综合第一页| 换爱交换乱高清大片| eeuss鲁片一区二区三区| 国产女孩喷水在线观看| 一区二区视频视频视频| 日本韩国免费福利精品| 亚洲图片偷拍自拍区| 欧美在线偷拍视频免费看| 97精品综合久久在线| 青青操免费日综合视频观看| 一区二区三区四区中文| 久久久久久久精品老熟妇| 青青草人人妻人人妻| 国产午夜亚洲精品麻豆| 不卡一区一区三区在线| 最新国产精品拍在线观看| 亚洲国产在线精品国偷产拍| 日本一本午夜在线播放| 性色av一区二区三区久久久| 午夜激情精品福利视频| 91麻豆精品久久久久| 欧美日本aⅴ免费视频| 只有精品亚洲视频在线观看| 日本一区精品视频在线观看| 91国内精品自线在拍白富美| 中文乱理伦片在线观看| 亚洲综合在线观看免费| 真实国模和老外性视频| 东京热男人的av天堂| 福利视频一区二区三区筱慧| 一级A一级a爰片免费免会员| 国产成人一区二区三区电影网站| 五月天久久激情视频| 亚洲国产精品中文字幕网站| 97色视频在线观看| 日本韩国在线观看一区二区| 久久久久久久精品老熟妇| 99精品久久久久久久91蜜桃| 瑟瑟视频在线观看免费视频| 人人妻人人爽人人添夜| 国产精品久久久久网| 边摸边做超爽毛片18禁色戒 | 在线观看的黄色免费网站| 成年人的在线免费视频| 中文字幕网站你懂的| 玩弄人妻熟妇性色av少妇| 天天干夜夜操天天舔| 伊人成人在线综合网| 久久久精品999精品日本| av俺也去在线播放| 国产精品国色综合久久| 免费在线看的黄片视频| 99re久久这里都是精品视频| 日本成人一区二区不卡免费在线| 11久久久久久久久久久| 伊拉克及约旦宣布关闭领空| 同居了嫂子在线播高清中文| 一区二区三区四区中文| av中文在线天堂精品| av线天堂在线观看| 亚洲中文字幕校园春色| 久久久91蜜桃精品ad| 2022精品久久久久久中文字幕| 高清成人av一区三区| 欧美国产亚洲中英文字幕| 午夜91一区二区三区| 欧美亚洲一二三区蜜臀| 2021久久免费视频| 成人在线欧美日韩国产| av手机免费在线观看高潮| 水蜜桃国产一区二区三区| 特黄老太婆aa毛毛片| 天天干天天啪天天舔| 青青青青青操视频在线观看| 在线免费观看欧美小视频| 亚洲天堂成人在线观看视频网站| 午夜毛片不卡免费观看视频| 国产精品国产三级麻豆| 亚洲国产最大av综合| 人人妻人人爽人人澡人人精品| 欲乱人妻少妇在线视频裸| 日本性感美女写真视频| 密臀av一区在线观看| 日韩欧美一级aa大片| 午夜国产福利在线观看| 日韩亚国产欧美三级涩爱| 欧美综合婷婷欧美综合| www日韩a级s片av| 亚洲av色图18p| 97超碰免费在线视频| 久久亚洲天堂中文对白| av在线播放国产不卡| 免费在线看的黄片视频| 揄拍成人国产精品免费看视频| 水蜜桃国产一区二区三区| 4个黑人操素人视频网站精品91| 国产精品亚洲在线观看| 日韩中文字幕在线播放第二页| aaa久久久久久久久| 亚洲精品无码久久久久不卡 | 亚洲成人国产综合一区| 偷拍自拍亚洲美腿丝袜| 66久久久久久久久久久| 99av国产精品欲麻豆| 国产精品国产精品一区二区| 在线免费观看亚洲精品电影| 一区二区三区四区视频| 性感美女福利视频网站| 成人国产小视频在线观看| 欧美综合婷婷欧美综合| 日韩视频一区二区免费观看| 国产综合高清在线观看| 亚洲日产av一区二区在线| 天天干天天插天天谢| 99国内精品永久免费视频| 亚洲中文精品人人免费| av完全免费在线观看av| 任你操视频免费在线观看| 91精品视频在线观看免费| 亚洲av日韩精品久久久| 天天干天天操天天爽天天摸| 欧美一区二区三区久久久aaa| 天天干狠狠干天天操| 操日韩美女视频在线免费看| 青青草原网站在线观看 | 国产精品自拍在线视频| 在线观看免费视频色97| 午夜婷婷在线观看视频| 国产男女视频在线播放| 欧美亚洲国产成人免费在线| 久草视频在线免播放| 日本人妻少妇18—xx| 国产日韩精品一二三区久久久| 成人久久精品一区二区三区| 97人妻无码AV碰碰视频| 丝袜美腿视频诱惑亚洲无| 日本一本午夜在线播放| 99热99这里精品6国产| 亚洲成人国产av在线| 91大神福利视频网| 在线观看的a站 最新| 五十路熟女人妻一区二区9933| 精品国产乱码一区二区三区乱| 成年人午夜黄片视频资源| 综合国产成人在线观看| 天天日天天操天天摸天天舔 | 91香蕉成人app下载| 91在线免费观看成人| 青青草亚洲国产精品视频| 成年人午夜黄片视频资源| 日韩人妻在线视频免费| 任你操视频免费在线观看| 青草久久视频在线观看| 国产成人综合一区2区| 国产成人综合一区2区| 亚洲精品国产久久久久久| 久久久久只精品国产三级| 成人精品视频99第一页| av大全在线播放免费| 91大屁股国产一区二区| 中文字幕无码日韩专区免费| 激情啪啪啪啪一区二区三区 | 青青草原色片网站在线观看| 少妇ww搡性bbb91| 国产精品人妻66p| 免费手机黄页网址大全| 国产自拍在线观看成人| 2020av天堂网在线观看| 啪啪啪操人视频在线播放| 国产va精品免费观看| 日本精品视频不卡一二三| 自拍偷拍亚洲欧美在线视频| 成年午夜影片国产片| 日本性感美女三级视频| 中文字幕高清在线免费播放| 精品一线二线三线日本| 日韩美女综合中文字幕pp| 在线免费观看亚洲精品电影| 一区国内二区日韩三区欧美| 福利午夜视频在线合集| 亚洲熟色妇av日韩熟色妇在线| 一区二区三区四区视频| 动漫精品视频在线观看| 午夜免费体验区在线观看 | 自拍偷拍日韩欧美亚洲| 夜女神免费福利视频| 亚洲人成精品久久久久久久| 在线免费视频 自拍| 亚洲国产第一页在线观看| 91精品激情五月婷婷在线| 夜色17s精品人妻熟女| 精品一区二区三区午夜| 青青在线视频性感少妇和隔壁黑丝| 2020久久躁狠狠躁夜夜躁| 亚洲av成人免费网站| 日本少妇的秘密免费视频| 成熟熟女国产精品一区| 97人人模人人爽人人喊| 国产又粗又硬又大视频| 亚洲 人妻 激情 中文| 亚洲va国产va欧美va在线| 欧美黑人性猛交xxxxⅹooo| 少妇系列一区二区三区视频| 水蜜桃国产一区二区三区| 亚洲最大黄了色网站| 女生自摸在线观看一区二区三区| 国产精品手机在线看片| 精品亚洲国产中文自在线| 日本人竟这样玩学生妹| 天天夜天天日天天日| 18禁美女黄网站色大片下载| 色av色婷婷人妻久久久精品高清 | 韩国三级aaaaa高清视频| 大白屁股精品视频国产| 久久久久五月天丁香社区 | 激情啪啪啪啪一区二区三区| 日本xx片在线观看| 香蕉aⅴ一区二区三区| 亚洲精品午夜aaa久久| 2021天天色天天干| 美女大bxxxx内射| 最近中文2019年在线看| 亚洲美女自偷自拍11页| av日韩在线免费播放| 欧美亚洲免费视频观看| 国产精品福利小视频a| 在线观看黄色成年人网站| 插逼视频双插洞国产操逼插洞| AV无码一区二区三区不卡| 日辽宁老肥女在线观看视频| 日本a级视频老女人| av成人在线观看一区| 91在线免费观看成人| 国产极品精品免费视频| 天天草天天色天天干| 男人天堂最新地址av| 亚洲成人av一区在线| free性日本少妇| 国产亚洲欧美45p| 91精品国产黑色丝袜| 天天干夜夜操啊啊啊| 亚洲成人av在线一区二区| 黄色片一级美女黄色片| 国产高清精品一区二区三区| 欧美香蕉人妻精品一区二区| 欧美精品免费aaaaaa| 57pao国产一区二区| 人妻无码色噜噜狠狠狠狠色| av乱码一区二区三区| 亚洲欧美久久久久久久久| 只有精品亚洲视频在线观看| 男人和女人激情视频| 老有所依在线观看完整版| 插小穴高清无码中文字幕| 亚洲第一黄色在线观看| 日韩美女综合中文字幕pp| 日韩少妇人妻精品无码专区| 色综合久久五月色婷婷综合| 熟女视频一区,二区,三区| 国产又粗又硬又大视频| 午夜精品久久久久久99热| 国产精品视频男人的天堂| av一本二本在线观看| 97香蕉碰碰人妻国产樱花| 中文字幕一区二 区二三区四区| 不卡一区一区三区在线| 日日操综合成人av| 红杏久久av人妻一区| 91she九色精品国产| 99精品国产免费久久| 在线不卡成人黄色精品| 成人蜜桃美臀九一一区二区三区| 中文字幕无码日韩专区免费| 欧美激情电影免费在线| 欧美一区二区中文字幕电影| 国产精品精品精品999| av中文字幕国产在线观看| 亚洲粉嫩av一区二区三区| 成人资源在线观看免费官网| 美味人妻2在线播放| 亚洲成人免费看电影| 在线 中文字幕 一区| 极品丝袜一区二区三区| 亚洲国际青青操综合网站| 骚货自慰被发现爆操| 在线视频这里只有精品自拍| 黑人借宿ntr人妻的沦陷2| 欧美一级片免费在线成人观看| 888亚洲欧美国产va在线播放| 久草视频 久草视频2| 韩国爱爱视频中文字幕| 制服丝袜在线人妻中文字幕| 天天日天天鲁天天操| 久草视频福利在线首页| 2021最新热播中文字幕| 天天操,天天干,天天射| 欧美激情电影免费在线| 天天躁日日躁狠狠躁躁欧美av | 欧美日韩亚洲国产无线码| 秋霞午夜av福利经典影视| 国产一级麻豆精品免费| av在线资源中文字幕| 1区2区3区不卡视频| 国产精品免费不卡av| 自拍偷拍亚洲欧美在线视频| 美女大bxxxx内射| 午夜激情久久不卡一区二区 | 开心 色 六月 婷婷| 亚洲一级美女啪啪啪| 在线观看国产网站资源| 日韩成人性色生活片| 又色又爽又黄的美女裸体| ka0ri在线视频| 亚洲国产精品久久久久蜜桃| 欧美一级片免费在线成人观看| 宅男噜噜噜666免费观看| 最新国产精品拍在线观看| 亚洲成人国产av在线| 一区二区三区激情在线| 国产妇女自拍区在线观看| 国产黑丝高跟鞋视频在线播放| 亚洲精品国品乱码久久久久| 免费在线福利小视频| 免费高清自慰一区二区三区网站 | 青青青艹视频在线观看| 亚洲av极品精品在线观看| 欧美第一页在线免费观看视频 | 亚洲图库另类图片区| 日韩精品二区一区久久| av天堂中文免费在线| 天天射,天天操,天天说| 天天操天天操天天碰| 1000部国产精品成人观看视频| 天天日天天敢天天干| 91桃色成人网络在线观看| av老司机精品在线观看| 亚洲av日韩高清hd| 极品粉嫩小泬白浆20p主播| 99热国产精品666| 夜夜嗨av蜜臀av| 中文字幕高清免费在线人妻| 中文字幕高清资源站| 日韩在线中文字幕色| 人妻另类专区欧美制服| 好吊操视频这里只有精品| 亚洲高清国产一区二区三区| 亚洲精品国偷自产在线观看蜜桃 | 国产精品视频欧美一区二区| 亚洲成人精品女人久久久| 亚洲人一区二区中文字幕| 91大屁股国产一区二区| 自拍偷拍vs一区二区三区| 精品一区二区三区午夜| 日本特级片中文字幕| av天堂中文字幕最新| 香蕉av影视在线观看| 天天夜天天日天天日| 国产精品伦理片一区二区| 国产真实灌醉下药美女av福利| 欧美精品一区二区三区xxxx| 国产麻豆剧传媒精品国产av蜜桃| 人妻素人精油按摩中出| 精品国产亚洲av一淫| 中文字日产幕乱六区蜜桃| 日本韩国亚洲综合日韩欧美国产| 91色网站免费在线观看| 日本真人性生活视频免费看| 天堂中文字幕翔田av| 午夜av一区二区三区| 国产精品手机在线看片| 青青青艹视频在线观看| 日美女屁股黄邑视频| 三级黄色亚洲成人av| 日韩加勒比东京热二区| 中文字幕一区二区三区人妻大片| 夜夜操,天天操,狠狠操| 激情啪啪啪啪一区二区三区| 91精品视频在线观看免费| 亚洲福利精品福利精品福利| 91麻豆精品91久久久久同性| 亚洲精品乱码久久久本| 欧亚乱色一区二区三区| 人妻av无码专区久久绿巨人| 91www一区二区三区| 日韩欧美一级黄片亚洲| 欧美亚洲自偷自拍 在线| 亚洲一区二区三区在线高清 | 色综合久久无码中文字幕波多| 18禁污污污app下载| 日韩黄色片在线观看网站| 精品suv一区二区69| 日本熟女精品一区二区三区| 任你操任你干精品在线视频 | 黄页网视频在线免费观看| 亚洲中文字幕综合小综合| 黄色资源视频网站日韩| 日韩人妻xxxxx| 狠狠操操操操操操操操操| 91精品国产91久久自产久强| 久久精品国产23696| 中文字幕高清资源站| 熟女国产一区亚洲中文字幕| 国产麻豆乱子伦午夜视频观看| 人妻素人精油按摩中出| 美女骚逼日出水来了| 护士特殊服务久久久久久久| 在线观看av2025| 亚洲av男人的天堂你懂的| 日韩美女精品视频在线观看网站| 宅男噜噜噜666国产| 97国产在线av精品| 日本美女性生活一级片| 黑人解禁人妻叶爱071| 偷拍自拍亚洲美腿丝袜| 一区二区视频在线观看免费观看| 久久农村老妇乱69系列| 欧洲黄页网免费观看| 扒开让我视频在线观看| 中文字母永久播放1区2区3区 | 国产成人精品福利短视频| 男人和女人激情视频| 久久久久久久精品成人热| 玩弄人妻熟妇性色av少妇| 大鸡巴操娇小玲珑的女孩逼| 久久久极品久久蜜桃| 亚洲成人熟妇一区二区三区 | 欧美乱妇无乱码一区二区| 亚洲高清国产一区二区三区| 绝色少妇高潮3在线观看| 亚洲天堂精品福利成人av| 国产黄色a级三级三级三级 | 欧美成一区二区三区四区| 欧美老妇精品另类不卡片| 日本午夜久久女同精女女| 日韩黄色片在线观看网站| 国产在线一区二区三区麻酥酥| 中国熟女一区二区性xx| 久久精品久久精品亚洲人| 亚洲女人的天堂av| 唐人色亚洲av嫩草| 日美女屁股黄邑视频| 亚洲精品中文字幕下载| 午夜频道成人在线91| 中文字幕人妻一区二区视频| 久久丁香婷婷六月天| 专门看国产熟妇的网站| 亚洲天堂有码中文字幕视频| 国产精品久久久久网| 亚洲高清免费在线观看视频| 亚洲天堂精品久久久| 欧美伊人久久大香线蕉综合| 在线可以看的视频你懂的| 密臀av一区在线观看| av在线资源中文字幕| 国产精品国色综合久久| 99一区二区在线观看| 男生舔女生逼逼视频| 亚洲国产成人无码麻豆艾秋| 日本韩国在线观看一区二区| 免费福利av在线一区二区三区| 国产午夜激情福利小视频在线| av无限看熟女人妻另类av| 国产日本欧美亚洲精品视| 欧美爆乳肉感大码在线观看| 欧美精品激情在线最新观看视频| 黄色片一级美女黄色片| 天天干天天日天天干天天操| 青青操免费日综合视频观看| 婷婷色国产黑丝少妇勾搭AV| 中文字幕 人妻精品| 亚洲Av无码国产综合色区| 色天天天天射天天舔| 91自产国产精品视频| 搡老熟女一区二区在线观看 | 久久精品亚洲成在人线a| 国产精品黄大片在线播放| 熟女人妻一区二区精品视频| 韩国女主播精品视频网站| 大陆精品一区二区三区久久| 中国老熟女偷拍第一页| 久久久久久性虐视频| 大骚逼91抽插出水视频| 日本黄色特一级视频| 亚洲欧美激情国产综合久久久| 欧美日韩中文字幕欧美| 日日夜夜大香蕉伊人| 夜女神免费福利视频| 国产亚洲成人免费在线观看| 18禁无翼鸟成人在线| 国产精品午夜国产小视频| 国产日本精品久久久久久久| 五十路丰满人妻熟妇| 美女被肏内射视频网站| 天天日夜夜操天天摸| 日本在线不卡免费视频| 99热这里只有精品中文| 国产一区成人在线观看视频 | 国产免费高清视频视频| 大鸡巴插入美女黑黑的阴毛| 天天干天天爱天天色| 人妻素人精油按摩中出| 日韩欧美制服诱惑一区在线| 亚洲激情av一区二区| 视频啪啪啪免费观看| 午夜dv内射一区区| 3344免费偷拍视频| 青青操免费日综合视频观看| 夜色撩人久久7777| sejizz在线视频| 丰满少妇人妻xxxxx| 小泽玛利亚视频在线观看| 亚洲av可乐操首页| 国产精品成人xxxx| 中文字幕1卡1区2区3区| 91精品国产高清自在线看香蕉网| 国产亚洲视频在线二区| 中文字幕之无码色多多| 亚洲中文精品人人免费| 视频一区 二区 三区 综合| 动漫黑丝美女的鸡巴| 日本黄色三级高清视频| 18禁网站一区二区三区四区| 人妻无码中文字幕专区| 成人性黑人一级av| 亚洲av天堂在线播放| 91精品啪在线免费| 美女福利视频导航网站| 亚国产成人精品久久久| 无码精品一区二区三区人| 欧美乱妇无乱码一区二区| 午夜激情久久不卡一区二区| 一区二区三区毛片国产一区| 哥哥姐姐综合激情小说| 亚洲欧洲av天堂综合| 国产伦精品一区二区三区竹菊| 亚洲午夜电影之麻豆| 亚洲变态另类色图天堂网| 亚洲另类图片蜜臀av| 在线免费视频 自拍| 第一福利视频在线观看| 欧美亚洲少妇福利视频| 亚洲成a人片777777| 日本av高清免费网站| 国产污污污污网站在线| 午夜美女少妇福利视频| 国产伊人免费在线播放| 中国产一级黄片免费视频播放| 亚洲欧美自拍另类图片| 精品一线二线三线日本| 加勒比视频在线免费观看| 亚洲av色香蕉一区二区三区| 欧美在线精品一区二区三区视频 | 日本韩国免费一区二区三区视频| 在线观看av亚洲情色| 91九色国产porny蝌蚪| 大黑人性xxxxbbbb| 精品视频中文字幕在线播放| 人妻少妇中文有码精品| 97色视频在线观看| 亚洲av成人免费网站| 美女张开两腿让男人桶av| 白白操白白色在线免费视频 | 六月婷婷激情一区二区三区| gav成人免费播放| 青青草人人妻人人妻| 亚洲第一伊人天堂网| weyvv5国产成人精品的视频| 伊人综合aⅴ在线网| 国产av自拍偷拍盛宴| 99久久中文字幕一本人| 人人妻人人人操人人人爽| 婷婷色国产黑丝少妇勾搭AV| 久久精品视频一区二区三区四区| 亚洲精品国产在线电影| 班长撕开乳罩揉我胸好爽| 99热久久极品热亚洲| 含骚鸡巴玩逼逼视频| 91免费观看国产免费| av手机免费在线观看高潮| 三级等保密码要求条款| www久久久久久久久久久| 动漫黑丝美女的鸡巴| 青青尤物在线观看视频网站| 亚洲精品国产久久久久久| www日韩a级s片av| 久久热这里这里只有精品| 国产在线免费观看成人| 91天堂精品一区二区| 精品一线二线三线日本| 人人超碰国字幕观看97| 日本少妇的秘密免费视频| 亚洲国产欧美一区二区三区…| 亚洲的电影一区二区三区| 黑人巨大精品欧美视频| 天堂av在线播放免费| 天天操天天干天天日狠狠插 | 日韩在线视频观看有码在线| 熟女人妻一区二区精品视频| 国产午夜亚洲精品麻豆| 91色九色porny| 亚洲欧美另类自拍偷拍色图| 亚洲一区二区三区uij| 亚洲精品乱码久久久久久密桃明 | 九九热99视频在线观看97| 2025年人妻中文字幕乱码在线 | 国产品国产三级国产普通话三级| 超黄超污网站在线观看| 瑟瑟视频在线观看免费视频| 超黄超污网站在线观看| 精品人人人妻人人玩日产欧| 啪啪啪啪啪啪啪啪啪啪黄色| 自拍偷拍日韩欧美亚洲| 337p日本大胆欧美人| 欧美色呦呦最新网址| 伊人情人综合成人久久网小说 | 日本av高清免费网站| 国产高清97在线观看视频| 男人的天堂av日韩亚洲| 玩弄人妻熟妇性色av少妇| 18禁网站一区二区三区四区| 亚洲免费av在线视频| 成人区人妻精品一区二视频| 国产欧美精品不卡在线| 在线免费观看亚洲精品电影| 91麻豆精品久久久久| 99热99这里精品6国产| 91人妻精品久久久久久久网站| 亚洲国产欧美一区二区丝袜黑人 | 国产大鸡巴大鸡巴操小骚逼小骚逼 | 黄工厂精品视频在线观看| 亚洲国产成人无码麻豆艾秋| 在线观看av观看av| 亚洲高清自偷揄拍自拍| 中文字幕第1页av一天堂网| 国产av欧美精品高潮网站| 夜色撩人久久7777| 亚洲男人在线天堂网| 一区二区三区av高清免费| 国产激情av网站在线观看| 端庄人妻堕落挣扎沉沦| 色综合天天综合网国产成人| 精品91高清在线观看 | 欧美一级片免费在线成人观看| xxx日本hd高清| 国产一区二区三免费视频| 天天干狠狠干天天操| 国产剧情演绎系列丝袜高跟| 国产av国片精品一区二区| 免费观看国产综合视频| 在线播放 日韩 av| 制丝袜业一区二区三区| 爆乳骚货内射骚货内射在线| 人人妻人人爱人人草| 蜜桃专区一区二区在线观看| 天天夜天天日天天日| 亚洲国产精品黑丝美女| 亚洲熟色妇av日韩熟色妇在线| 99精品免费久久久久久久久a| 久久免费看少妇高潮完整版| 只有精品亚洲视频在线观看| 天天操夜夜操天天操天天操| 午夜在线精品偷拍一区二| 特级欧美插插插插插bbbbb| 激情伦理欧美日韩中文字幕| 亚洲欧美久久久久久久久| 天天干狠狠干天天操| 97欧洲一区二区精品免费 | 国产性色生活片毛片春晓精品| 午夜福利人人妻人人澡人人爽| 日韩人妻在线视频免费| 美女福利视频导航网站| 亚洲欧美综合另类13p| 狠狠躁狠狠爱网站视频| 日韩成人综艺在线播放| av完全免费在线观看av| 日本美女成人在线视频| 欧美亚洲国产成人免费在线| 亚洲国产中文字幕啊啊啊不行了| 亚洲精品国产久久久久久| 午夜影院在线观看视频羞羞羞| 国产熟妇一区二区三区av| 日韩视频一区二区免费观看| 十八禁在线观看地址免费| 久久国产精品精品美女| 一区二区三区四区五区性感视频| 美女操逼免费短视频下载链接| 天天日天天干天天插舔舔| 天天色天天操天天舔| 中文字幕免费福利视频6| 天天做天天干天天舔| 久久香蕉国产免费天天| 青青青青青手机视频| 在线免费视频 自拍| 区一区二区三国产中文字幕| 91社福利《在线观看| 密臀av一区在线观看| 成人18禁网站在线播放| 精品美女久久久久久| 操日韩美女视频在线免费看| 动漫黑丝美女的鸡巴| 中文字幕人妻av在线观看| 一区二区三区欧美日韩高清播放| 婷婷久久久综合中文字幕| 中文字幕第一页国产在线| 国产亚洲四十路五十路| 人妻自拍视频中国大陆| 男女啪啪视频免费在线观看| 亚洲综合在线视频可播放| 18禁美女羞羞免费网站| 一区二区三区蜜臀在线| 天天干天天操天天爽天天摸| 插逼视频双插洞国产操逼插洞| 最新激情中文字幕视频| 9色在线视频免费观看| heyzo蜜桃熟女人妻| 亚欧在线视频你懂的| 国产日韩一区二区在线看| 美女小视频网站在线| 欧美成人综合色在线噜噜| 好太好爽好想要免费| 亚洲av一妻不如妾| 夜色17s精品人妻熟女| 韩国黄色一级二级三级| 97色视频在线观看| 97少妇精品在线观看| 国产又粗又猛又爽又黄的视频在线| 99久久中文字幕一本人| 日本男女操逼视频免费看| 色呦呦视频在线观看视频| 天天色天天爱天天爽| 黄工厂精品视频在线观看| 日韩a级黄色小视频| 免费看国产又粗又猛又爽又黄视频| 骚货自慰被发现爆操| 亚洲va欧美va人人爽3p| 精品91高清在线观看| 国产成人精品av网站| 4个黑人操素人视频网站精品91| 中文字幕+中文字幕| 久草福利电影在线观看| 精品国产在线手机在线| 一个色综合男人天堂| 97国产精品97久久| 男人操女人逼逼视频网站| 首之国产AV医生和护士小芳| 视频 国产 精品 熟女 | 最新日韩av传媒在线| 青草久久视频在线观看| 国产精品精品精品999| 亚洲免费福利一区二区三区| 在线播放一区二区三区Av无码| 特黄老太婆aa毛毛片| 91精品国产观看免费| 国产精彩福利精品视频| 毛茸茸的大外阴中国视频| 丝袜美腿视频诱惑亚洲无| 婷婷久久久综合中文字幕| 午夜蜜桃一区二区三区| 18禁精品网站久久| 国产妇女自拍区在线观看| 亚洲图库另类图片区| 黄页网视频在线免费观看 | 日韩精品啪啪视频一道免费| 五十路老熟女码av| 青青青青青青青青青青草青青| 青青青青青青草国产| 和邻居少妇愉情中文字幕| 久久国产精品精品美女| 在线观看免费视频色97| 久久久超爽一二三av| 青青在线视频性感少妇和隔壁黑丝| 强行扒开双腿猛烈进入免费版| 少妇人妻100系列| 视频 国产 精品 熟女 | 在线视频这里只有精品自拍| 国产黄色a级三级三级三级| 亚洲天堂第一页中文字幕| 日韩美女搞黄视频免费| 性欧美激情久久久久久久| 在线观看欧美黄片一区二区三区| jiujiure精品视频在线| 久青青草视频手机在线免费观看| av中文字幕电影在线看| 天天色天天操天天透| 孕妇奶水仑乱A级毛片免费看| 在线免费视频 自拍| 亚洲国产成人无码麻豆艾秋| 日韩在线视频观看有码在线| 亚洲视频在线视频看视频在线| 东京热男人的av天堂| 夜夜嗨av蜜臀av| 91大神福利视频网| 久久久久久cao我的性感人妻 | 亚洲成人熟妇一区二区三区| 青青草人人妻人人妻| 在线观看免费岛国av| 国产在线91观看免费观看| 久久久精品欧洲亚洲av| 欧美性受xx黑人性猛交| 国产性色生活片毛片春晓精品 | 蜜桃视频入口久久久| 亚洲欧美综合在线探花| 亚洲av在线观看尤物| 成人精品视频99第一页| 亚洲av日韩av网站| 97国产在线av精品| 77久久久久国产精产品| 男女之间激情网午夜在线| 日本午夜久久女同精女女| 性感美女高潮视频久久久| 黄色视频在线观看高清无码| 中文字幕综合一区二区| 亚洲va天堂va国产va久| 人人人妻人人澡人人| 最新国产精品网址在线观看| 中文字幕+中文字幕| 亚洲 清纯 国产com| 老司机在线精品福利视频| 日本女大学生的黄色小视频| 粉嫩av蜜乳av蜜臀| 午夜毛片不卡在线看| 性感美女诱惑福利视频| 国产综合精品久久久久蜜臀| av手机在线免费观看日韩av| 欧美成人一二三在线网| 青青色国产视频在线| 精品国产在线手机在线| 98视频精品在线观看| 日韩欧美一级aa大片| 欧美80老妇人性视频| 国产老熟女伦老熟妇ⅹ| 黄色资源视频网站日韩| 欧亚日韩一区二区三区观看视频| 成人免费做爰高潮视频| 亚洲黄色av网站免费播放| 天天摸天天日天天操| 成人国产激情自拍三区| 亚洲精品麻豆免费在线观看| 国产在线一区二区三区麻酥酥| 欧美精品资源在线观看| 东游记中文字幕版哪里可以看到| 人妻少妇一区二区三区蜜桃| 国产91嫩草久久成人在线视频| 亚洲国产香蕉视频在线播放| 97精品视频在线观看| 国产乱弄免费视频观看| 成人精品在线观看视频| eeuss鲁片一区二区三区| 国产精品久久久久网| 日韩成人免费电影二区| 国产黑丝高跟鞋视频在线播放| 啪啪啪操人视频在线播放| 午夜大尺度无码福利视频| 中文字幕免费福利视频6| 亚洲国产精品久久久久久6| 人妻av无码专区久久绿巨人| 日韩美女综合中文字幕pp| 色97视频在线播放| 日韩人妻在线视频免费| 在线不卡成人黄色精品| 韩国三级aaaaa高清视频| 大香蕉伊人国产在线| 不戴胸罩引我诱的隔壁的人妻| 久久丁香花五月天色婷婷| 精品久久久久久久久久久久人妻| 日韩视频一区二区免费观看| 自拍偷拍日韩欧美亚洲| 骚逼被大屌狂草视频免费看| 亚洲免费福利一区二区三区| 一区二区在线观看少妇| 骚货自慰被发现爆操| 国产视频一区在线观看| 久久久久久久一区二区三| 同居了嫂子在线播高清中文| 欧美香蕉人妻精品一区二区| 80电影天堂网官网| 福利国产视频在线观看| 亚洲激情偷拍一区二区| 巨乳人妻日下部加奈被邻居中出| 精品一区二区三区午夜| 人妻少妇精品久久久久久| 人人爽亚洲av人人爽av| 日本裸体熟妇区二区欧美| 岛国免费大片在线观看| 999九九久久久精品| 国产成人无码精品久久久电影| 亚洲va国产va欧美va在线| 黄色大片免费观看网站| 人妻久久久精品69系列| 91免费福利网91麻豆国产精品| 国产之丝袜脚在线一区二区三区| 国产精品黄片免费在线观看| 久久久精品欧洲亚洲av| 日本三极片中文字幕| 大香蕉玖玖一区2区| 午夜dv内射一区区| 亚洲av第国产精品| 黄色片黄色片wyaa| 狠狠躁夜夜躁人人爽天天久天啪| 91亚洲精品干熟女蜜桃频道| 337p日本大胆欧美人| 经典国语激情内射视频| 欧美亚洲少妇福利视频| 天堂av狠狠操蜜桃| 欧美黑人巨大性xxxxx猛交| 日本韩国免费一区二区三区视频 | 成年人啪啪视频在线观看| 一区二区三区视频,福利一区二区| av在线免费观看亚洲天堂| 久久精品36亚洲精品束缚| 和邻居少妇愉情中文字幕| 综合激情网激情五月五月婷婷| 国产夫妻视频在线观看免费| 日本熟女50视频免费| 91国内视频在线观看| aiss午夜免费视频| 欧美在线精品一区二区三区视频 | 亚洲精品欧美日韩在线播放 | 色综合色综合色综合色| 不戴胸罩引我诱的隔壁的人妻| 欧美第一页在线免费观看视频| 亚洲在线免费h观看网站| 天天干天天啪天天舔| 欧美久久久久久三级网| 欧美偷拍亚洲一区二区| 在线网站你懂得老司机| av手机在线观播放网站| 美女被肏内射视频网站| 成人福利视频免费在线| 99久久久无码国产精品性出奶水 | 国产亚洲欧美45p| 色综合久久无码中文字幕波多| 97国产在线观看高清| 久久久久只精品国产三级| 91九色国产porny蝌蚪| 午夜影院在线观看视频羞羞羞| 欧美精产国品一二三产品价格| 国产三级精品三级在线不卡| av新中文天堂在线网址| 最新国产精品拍在线观看| 国产精品视频欧美一区二区| 亚洲一级av无码一级久久精品| 国产美女午夜福利久久| 亚洲国产精品中文字幕网站| 久久久久久cao我的性感人妻| 欧美va不卡视频在线观看| 亚洲午夜高清在线观看| 中国熟女@视频91| 欧美伊人久久大香线蕉综合| 中文字幕乱码av资源| 国产精品sm调教视频| 中文字幕综合一区二区| 青青在线视频性感少妇和隔壁黑丝 | 一区二区三区 自拍偷拍| 2020久久躁狠狠躁夜夜躁| 成人av亚洲一区二区| 亚洲熟妇x久久av久久| 午夜久久久久久久99| 97少妇精品在线观看| 在线观看一区二区三级| 又粗又长 明星操逼小视频| 激情综合治理六月婷婷| 99热99这里精品6国产| av俺也去在线播放| 真实国产乱子伦一区二区| 日本啪啪啪啪啪啪啪| av成人在线观看一区| 啪啪啪18禁一区二区三区| 熟妇一区二区三区高清版| 熟女人妻一区二区精品视频| heyzo蜜桃熟女人妻| 亚洲在线一区二区欧美| 99re国产在线精品| 98视频精品在线观看| 91chinese在线视频| av天堂资源最新版在线看| 日本福利午夜电影在线观看| 男生舔女生逼逼的视频| 中国黄色av一级片| 91免费黄片可看视频| 大鸡吧插入女阴道黄色片| 亚洲无码一区在线影院| 最新91九色国产在线观看| 黑人借宿ntr人妻的沦陷2| 欧美日韩一区二区电影在线观看| 青青操免费日综合视频观看| www日韩毛片av| 可以免费看的www视频你懂的| 午夜毛片不卡免费观看视频| 中文字幕综合一区二区| 任你操视频免费在线观看| 亚洲伊人久久精品影院一美女洗澡 | 亚洲护士一区二区三区| 亚洲天堂成人在线观看视频网站| 99视频精品全部15| 国语对白xxxx乱大交| 亚洲av自拍偷拍综合| 国产一级麻豆精品免费| 日本a级视频老女人| 国产又粗又猛又爽又黄的视频在线 | 久久美欧人妻少妇一区二区三区| 欧美一区二区三区高清不卡tv| 大肉大捧一进一出好爽在线视频| 国产a级毛久久久久精品| 韩国亚洲欧美超一级在线播放视频| 天堂中文字幕翔田av| 热久久只有这里有精品| 美女张开两腿让男人桶av| 2018最新中文字幕在线观看| 在线观看视频 你懂的| 久久久精品999精品日本| 日韩美女精品视频在线观看网站 | 精品乱子伦一区二区三区免费播| 欧美一区二区三区在线资源| 青青社区2国产视频| 1000部国产精品成人观看视频| 国产精品人久久久久久| 美女骚逼日出水来了| 日韩北条麻妃一区在线| 三上悠亚和黑人665番号| 免费无码人妻日韩精品一区二区 | 亚洲一区制服丝袜美腿| 看一级特黄a大片日本片黑人| 天堂av狠狠操蜜桃| 天天射夜夜操综合网| jul—619中文字幕在线| 青青青青青青草国产| 成人亚洲精品国产精品| 淫秽激情视频免费观看| 中文字幕第一页国产在线| 1769国产精品视频免费观看| 国产视频一区在线观看| 日韩美女福利视频网| 欧美aa一级一区三区四区| 欧美视频一区免费在线| 日本性感美女视频网站| 激情国产小视频在线| 精品高跟鞋丝袜一区二区| 日韩成人综艺在线播放| 好男人视频在线免费观看网站| 国产精品国色综合久久| 日本精品视频不卡一二三| 国产精品国色综合久久| 亚洲 图片 欧美 图片| 黄色片年轻人在线观看| 成人av在线资源网站| 福利午夜视频在线合集| 日韩三级电影华丽的外出| 亚洲激情,偷拍视频| 亚洲美女高潮喷浆视频| 亚洲人人妻一区二区三区| 欧美专区日韩专区国产专区| 18禁美女羞羞免费网站| 美女福利视频网址导航| 午夜毛片不卡在线看| 51国产偷自视频在线播放| 最新日韩av传媒在线| 绯色av蜜臀vs少妇| 又粗又硬又猛又爽又黄的| 青青青视频手机在线观看| 色吉吉影音天天干天天操| 不卡一区一区三区在线| 大鸡吧插入女阴道黄色片| 亚洲激情偷拍一区二区| 18禁美女无遮挡免费| 国产视频一区在线观看| 日日夜夜精品一二三| 淫秽激情视频免费观看| 视频久久久久久久人妻| 亚洲精品乱码久久久本| 在线观看成人国产电影| 亚洲第一伊人天堂网| 中文字幕在线免费第一页| 人人爱人人妻人人澡39| av手机免费在线观看高潮| 亚洲码av无色中文| 大胆亚洲av日韩av| 日本特级片中文字幕| 中文字幕一区二 区二三区四区| sspd152中文字幕在线| 日本在线一区二区不卡视频| 韩国一级特黄大片做受| 小穴多水久久精品免费看| 青青色国产视频在线| av线天堂在线观看| rct470中文字幕在线| 亚洲超碰97人人做人人爱| 天堂va蜜桃一区入口| 天天日天天摸天天爱| 白嫩白嫩美女极品国产在线观看| 天天日天天日天天射天天干| 97人妻夜夜爽二区欧美极品| 中文字幕 亚洲av| 国产亚洲精品视频合集| 婷婷久久一区二区字幕网址你懂得 | 亚洲人妻视频在线网| 啊啊啊视频试看人妻| 国产成人午夜精品福利| 日本人妻少妇18—xx| 天天日天天摸天天爱| 精品高跟鞋丝袜一区二区| 亚洲国产成人在线一区| 99精品视频在线观看免费播放| 熟女少妇激情五十路| 国产妇女自拍区在线观看| 91九色porny国产蝌蚪视频| 日本少妇精品免费视频| 亚洲一区二区激情在线| 亚洲综合一区二区精品久久| av乱码一区二区三区| 欧美女同性恋免费a| 欧美地区一二三专区| 1000部国产精品成人观看视频| 成人区人妻精品一区二视频| 性感美女高潮视频久久久| 青青青青操在线观看免费| 在线观看视频 你懂的| 国产女孩喷水在线观看| 亚洲成人线上免费视频观看| 在线网站你懂得老司机| 91试看福利一分钟| 欧美一区二区三区乱码在线播放| 制丝袜业一区二区三区| 日本一道二三区视频久久| 美女在线观看日本亚洲一区| 色av色婷婷人妻久久久精品高清| 任你操视频免费在线观看| 9色在线视频免费观看| 亚洲日产av一区二区在线| 中国黄片视频一区91| 日本午夜久久女同精女女| 天天日天天干天天舔天天射| 欧美日韩v中文在线| 天美传媒mv视频在线观看| 老师啊太大了啊啊啊尻视频| 久久精品美女免费视频| 一区二区免费高清黄色视频| 久精品人妻一区二区三区 | 久久久超爽一二三av| 色婷婷精品大在线观看| 姐姐的朋友2在线观看中文字幕| 中文字幕在线观看国产片| 91 亚洲视频在线观看| 久久精品36亚洲精品束缚| 黑人3p华裔熟女普通话| 一区二区三区日韩久久| 天天日天天干天天爱| 欧美亚洲一二三区蜜臀| 精品国产在线手机在线| 精品美女福利在线观看| av线天堂在线观看| 欧美亚洲中文字幕一区二区三区| 国产性感美女福利视频| 国产精品久久久久久久精品视频| 欧美美女人体视频一区| 日本韩国免费一区二区三区视频 | xxx日本hd高清| 国产亚洲精品视频合集| 青娱乐蜜桃臀av色| 污污小视频91在线观看| 综合页自拍视频在线播放| 久久农村老妇乱69系列| 午夜大尺度无码福利视频| 亚洲欧美日韩视频免费观看| 在线观看日韩激情视频| 亚洲免费福利一区二区三区| 在线观看黄色成年人网站| 久草视频在线免播放| 最近中文2019年在线看| 青青青青视频在线播放| 日本av在线一区二区三区| av中文字幕在线导航| 天天日天天干天天爱| 日韩欧美一级精品在线观看| 欧美韩国日本国产亚洲| 亚洲伊人久久精品影院一美女洗澡| 欧美香蕉人妻精品一区二区| 免费一级特黄特色大片在线观看| 韩国黄色一级二级三级| 91精品国产91青青碰| 999热精品视频在线| 在线新三级黄伊人网| 精品一区二区三区在线观看| 久久久久久久久久久久久97| 精品av久久久久久久| 又色又爽又黄又刺激av网站| 成年人该看的视频黄免费| 午夜dv内射一区区| 日本熟妇色熟妇在线观看| 可以免费看的www视频你懂的| 啪啪啪18禁一区二区三区| 黑人3p华裔熟女普通话| 中文字幕人妻三级在线观看| 亚洲综合图片20p| 亚洲激情偷拍一区二区| 亚洲激情,偷拍视频| 91精品高清一区二区三区| 1000小视频在线| 少妇与子乱在线观看| 国产综合高清在线观看| 在线免费观看国产精品黄色| 色秀欧美视频第一页| 中文字幕av熟女人妻| 久久丁香花五月天色婷婷| 国产不卡av在线免费| 少妇被强干到高潮视频在线观看| 一级黄片久久久久久久久| 毛茸茸的大外阴中国视频| 国产白袜脚足J棉袜在线观看| 中出中文字幕在线观看| 韩国亚洲欧美超一级在线播放视频| 天天想要天天操天天干| 大鸡吧插入女阴道黄色片| 久久永久免费精品人妻专区 | 天天日天天操天天摸天天舔| 人妻av无码专区久久绿巨人| 爆乳骚货内射骚货内射在线| 大香蕉伊人国产在线| 88成人免费av网站| 国产精品人妻熟女毛片av久| 日韩欧美国产一区ab| 婷婷色国产黑丝少妇勾搭AV| 国产精品久久9999| 一区二区三区另类在线| 丰满少妇人妻xxxxx| 中文字幕第1页av一天堂网 | 91国产资源在线视频| 在线观看成人国产电影| 操操网操操伊剧情片中文字幕网| 中文字幕无码日韩专区免费| 色狠狠av线不卡香蕉一区二区| 偷拍自拍福利视频在线观看| 亚洲精品国偷自产在线观看蜜桃| 中文字幕一区二区亚洲一区| 2021国产一区二区| 亚洲 自拍 色综合图| 4个黑人操素人视频网站精品91| 人妻无码中文字幕专区| 99久久中文字幕一本人| 欧美亚洲一二三区蜜臀| 男大肉棒猛烈插女免费视频| 青青色国产视频在线| 国产va在线观看精品| 91在线免费观看成人| 亚洲色偷偷综合亚洲AV伊人| 日韩无码国产精品强奸乱伦| 国产高清精品极品美女| 天天做天天干天天舔| 又粗又硬又猛又爽又黄的| 欧美视频不卡一区四区| 亚洲精品一线二线在线观看| 黑人3p华裔熟女普通话| 欧美亚洲自偷自拍 在线| 中文字幕日韩无敌亚洲精品| 白白操白白色在线免费视频| 中文字幕一区二区三区蜜月| 亚洲另类综合一区小说| 午夜的视频在线观看| 日本精品美女在线观看| 亚洲熟妇久久无码精品| 亚洲一区二区三区在线高清| 操操网操操伊剧情片中文字幕网| 亚洲另类图片蜜臀av| 亚洲国产在线精品国偷产拍| 国产成人精品一区在线观看 | 中国熟女@视频91| 人人爱人人妻人人澡39| av乱码一区二区三区| av破解版在线观看| 国产福利小视频免费观看| 黑人变态深video特大巨大| 国产免费高清视频视频| 日本女大学生的黄色小视频| 成人18禁网站在线播放| lutube在线成人免费看| 888欧美视频在线| 国产在线91观看免费观看| 激情伦理欧美日韩中文字幕| 97人妻色免费视频| 九九视频在线精品播放| 亚洲国产美女一区二区三区软件| 免费在线观看视频啪啪| 国产大学生援交正在播放| 在线不卡日韩视频播放| 75国产综合在线视频| 人妻久久久精品69系列| 国产亚洲精品欧洲在线观看| 中英文字幕av一区| 91人妻精品一区二区在线看| av视屏免费在线播放| 好太好爽好想要免费| 97瑟瑟超碰在线香蕉| 偷拍美女一区二区三区| 一区二区三区蜜臀在线| 97超碰最新免费在线观看| 日本三极片视频网站观看| 国产一级麻豆精品免费| 国产一区二区在线欧美| 成年人的在线免费视频| 大陆胖女人与丈夫操b国语高清| 91精品资源免费观看| 99热99这里精品6国产| 亚洲乱码中文字幕在线| 伊人开心婷婷国产av| 一区二区三区四区视频在线播放 | 国产亚州色婷婷久久99精品| 精品视频一区二区三区四区五区| 自拍偷拍一区二区三区图片| 成人国产影院在线观看| 中文字幕一区二 区二三区四区| 男人的天堂一区二区在线观看| 高潮视频在线快速观看国家快速| 1024久久国产精品| 午夜精品久久久久久99热| 99亚洲美女一区二区三区| 成人免费毛片aaaa| 免费看国产又粗又猛又爽又黄视频| 一区二区免费高清黄色视频| 天天射夜夜操狠狠干| 日美女屁股黄邑视频| 成年人午夜黄片视频资源| 啊用力插好舒服视频| 又粗又硬又猛又爽又黄的| 3337p日本欧洲大胆色噜噜| 黑人大几巴狂插日本少妇| 91麻豆精品91久久久久同性| av手机在线免费观看日韩av| 精品成人午夜免费看| 亚洲一区二区三区偷拍女厕91| 精品91自产拍在线观看一区| 国产又粗又硬又大视频| 久久麻豆亚洲精品av| 涩爱综合久久五月蜜臀| 亚洲成人激情av在线| 天天干天天啪天天舔| 国产精品久久9999| 在线国产中文字幕视频| 91精品国产综合久久久蜜| 黄色视频成年人免费观看| 免费在线播放a级片| 日韩中文字幕福利av| 一区二区三区激情在线| 日本三极片视频网站观看| 五十路熟女av天堂| 女生被男生插的视频网站| 国产黑丝高跟鞋视频在线播放 | 欧美特色aaa大片| 免费在线看的黄片视频| 福利片区一区二体验区| 日本性感美女三级视频| japanese五十路熟女熟妇| 操操网操操伊剧情片中文字幕网| 激情伦理欧美日韩中文字幕| 老熟妇凹凸淫老妇女av在线观看| 丝袜肉丝一区二区三区四区在线| gogo国模私拍视频| 黄色片年轻人在线观看| 搡老熟女一区二区在线观看| 日本美女性生活一级片| 国产美女精品福利在线| 啪啪啪操人视频在线播放| 91极品大一女神正在播放| 99精品一区二区三区的区| 欧美乱妇无乱码一区二区| 人妻少妇一区二区三区蜜桃| 亚洲区美熟妇久久久久| 在线免费视频 自拍| 热99re69精品8在线播放| 成年美女黄网站18禁久久| 嫩草aⅴ一区二区三区| 性感美女福利视频网站| 在线观看视频网站麻豆| 伊人成人在线综合网| 中文字幕在线视频一区二区三区| 亚洲国产精品久久久久蜜桃| 亚洲国产在线精品国偷产拍| 欧美日韩高清午夜蜜桃大香蕉| 2018最新中文字幕在线观看| 国产无遮挡裸体免费直播视频| 国产一区二区火爆视频| 国产午夜无码福利在线看| 国产精品久久久黄网站| 韩国女主播精品视频网站| 亚洲一区av中文字幕在线观看| 57pao国产一区二区| 青青青青青操视频在线观看| 亚洲av无硬久久精品蜜桃| 亚洲精品在线资源站| 中文字幕人妻一区二区视频| 亚洲一区二区三区久久受| 最新97国产在线视频| 高潮喷水在线视频观看| 亚洲av黄色在线网站| 亚洲天堂成人在线观看视频网站| 岛国黄色大片在线观看 | 99精品国产自在现线观看| 天天日天天日天天擦| 亚洲推理片免费看网站| 欧美综合婷婷欧美综合| 亚洲精品欧美日韩在线播放 | 在线可以看的视频你懂的| 欧美日本aⅴ免费视频| 亚洲av日韩av网站| 欧美黑人巨大性xxxxx猛交| 亚洲中文字字幕乱码| 黄色三级网站免费下载| 521精品视频在线观看| 日韩写真福利视频在线观看| 中字幕人妻熟女人妻a62v网| 日韩人妻xxxxx| 亚洲熟妇无码一区二区三区| 欧美一级色视频美日韩| 天天日天天摸天天爱| 中文字幕人妻被公上司喝醉在线| 天堂v男人视频在线观看| 欧美韩国日本国产亚洲| 国产精品污污污久久| 91小伙伴中女熟女高潮| 又黄又刺激的午夜小视频| 欧美乱妇无乱码一区二区| 精品suv一区二区69| 一区二区三区四区中文| 色偷偷伊人大杳蕉综合网| 好了av中文字幕在线| 成人性爱在线看四区| 97香蕉碰碰人妻国产樱花| 亚国产成人精品久久久| 2020久久躁狠狠躁夜夜躁| yy6080国产在线视频| 中文字幕日本人妻中出| 亚洲精品三级av在线免费观看| 欧美男同性恋69视频| 岛国av高清在线成人在线| 亚洲一区二区三区uij| 亚洲精品久久综合久| 夜夜操,天天操,狠狠操| 午夜精品福利一区二区三区p | 欧美男人大鸡吧插女人视频| 国产精品视频男人的天堂| 色吉吉影音天天干天天操| 亚洲人妻30pwc| 青娱乐在线免费视频盛宴| 综合国产成人在线观看| 国产 在线 免费 精品| 国产精品久久久久久久女人18| 91精品视频在线观看免费| 国产卡一卡二卡三乱码手机| 日本韩国免费福利精品| 国产精品久久久久网| 亚洲 图片 欧美 图片| 婷婷综合亚洲爱久久| 亚洲精品ww久久久久久| 又色又爽又黄的美女裸体| 日本女大学生的黄色小视频| 亚洲Av无码国产综合色区| 午夜婷婷在线观看视频| 亚洲av自拍天堂网| av中文字幕在线观看第三页| 福利一二三在线视频观看| 国产白袜脚足J棉袜在线观看| 日本人妻欲求不满中文字幕| 亚洲高清国产拍青青草原| 亚洲欧美清纯唯美另类 | 硬鸡巴动态操女人逼视频| 欧美在线偷拍视频免费看| 天天日天天日天天擦| 在线免费观看日本伦理| 家庭女教师中文字幕在线播放| 亚洲熟妇久久无码精品| heyzo蜜桃熟女人妻| 午夜91一区二区三区| 孕妇奶水仑乱A级毛片免费看| 在线观看的a站 最新| 视频一区二区在线免费播放| 在线成人日韩av电影| 国产精品久久久久网| 在线免费观看黄页视频| 岛国一区二区三区视频在线| 亚洲伊人色一综合网| 天码人妻一区二区三区在线看| 天天射,天天操,天天说| 国产视频网站一区二区三区| 社区自拍揄拍尻屁你懂的| 久久精品国产999| 一二三中文乱码亚洲乱码one| 国产三级影院在线观看| 国产女人被做到高潮免费视频| 国产精品久久久久久久精品视频| 99re6热在线精品| 黄色在线观看免费观看在线| 2020av天堂网在线观看| 国产日韩欧美视频在线导航| 91久久精品色伊人6882| 91精品激情五月婷婷在线| 2020久久躁狠狠躁夜夜躁| 亚洲av可乐操首页| 噜噜色噜噜噜久色超碰| 亚洲 欧美 自拍 偷拍 在线| 国产成人自拍视频播放| 黑人大几巴狂插日本少妇| 在线制服丝袜中文字幕| 欧美性受xx黑人性猛交| 黑人巨大的吊bdsm| 男人操女人的逼免费视频| 黄工厂精品视频在线观看| 一区二区三区另类在线| 国产一区二区欧美三区| 视频一区二区三区高清在线| 久久精品国产23696| 精品久久久久久久久久久久人妻| 天堂av在线官网中文| okirakuhuhu在线观看| 19一区二区三区在线播放| 天堂av狠狠操蜜桃| 亚洲无码一区在线影院| 日噜噜噜夜夜噜噜噜天天噜噜噜| 欧美成人猛片aaaaaaa| 日韩一个色综合导航| 久久久久久久久久性潮| 顶级尤物粉嫩小尤物网站| 黄色视频在线观看高清无码| 黄片三级三级三级在线观看| 97国产在线观看高清| 久久三久久三久久三久久| 1000部国产精品成人观看视频| 精品美女福利在线观看| 青青色国产视频在线| 欧美精品激情在线最新观看视频| 亚洲成人线上免费视频观看| 神马午夜在线观看视频| 国产成人无码精品久久久电影| 国产va在线观看精品| 91福利在线视频免费观看| 日本一区美女福利视频| 国产熟妇人妻ⅹxxxx麻豆| 亚洲综合图片20p| 青青草国内在线视频精选| 日本xx片在线观看| 欧美黑人与人妻精品| 国产一区二区视频观看| 适合午夜一个人看的视频| 都市激情校园春色狠狠| 天天干天天日天天干天天操| 久久综合老鸭窝色综合久久 | 在线观看国产网站资源| 精品久久久久久久久久久99| 九色porny九色9l自拍视频| 青青伊人一精品视频| 亚洲青青操骚货在线视频| 日韩影片一区二区三区不卡免费| 在线视频这里只有精品自拍| 欧美另类一区二区视频| 日本女大学生的黄色小视频| 日辽宁老肥女在线观看视频| 激情啪啪啪啪一区二区三区| 91啪国自产中文字幕在线| 大香蕉大香蕉在线看| 亚洲国产欧美一区二区三区久久| avjpm亚洲伊人久久| 一区二区在线观看少妇| 成人亚洲精品国产精品| 国产福利小视频免费观看| 亚洲欧美人精品高清| 精品亚洲国产中文自在线| 久久精品在线观看一区二区| 好吊操视频这里只有精品| 青青草国内在线视频精选| 亚洲最大黄了色网站| 国产午夜亚洲精品麻豆| 中文字幕在线免费第一页| 日本性感美女写真视频| 日本av高清免费网站| 水蜜桃一区二区三区在线观看视频| 亚洲成人午夜电影在线观看| 狠狠躁夜夜躁人人爽天天天天97| 国产亚洲四十路五十路| 成人精品视频99第一页| 天天操天天干天天插| 操人妻嗷嗷叫视频一区二区| 免费观看丰满少妇做受| mm131美女午夜爽爽爽| 亚洲最大黄了色网站| av手机在线免费观看日韩av| www日韩毛片av| 天堂v男人视频在线观看| 天天草天天色天天干| 亚洲av香蕉一区区二区三区犇| 成人H精品动漫在线无码播放| 日韩精品中文字幕在线| 99精品久久久久久久91蜜桃| 视频一区二区综合精品| heyzo蜜桃熟女人妻| 天堂女人av一区二区| 亚洲2021av天堂| 亚洲欧美综合另类13p| 夜夜操,天天操,狠狠操| 91在线免费观看成人| 中国把吊插入阴蒂的视频| 日韩av熟妇在线观看| 狠狠鲁狠狠操天天晚上干干| 淫秽激情视频免费观看| 国产视频在线视频播放| 人人人妻人人澡人人| 婷婷综合蜜桃av在线| 一区国内二区日韩三区欧美| v888av在线观看视频| 9l人妻人人爽人人爽| 天天日天天日天天射天天干| av手机在线观播放网站| 在线视频这里只有精品自拍| 沙月文乃人妻侵犯中文字幕在线| av欧美网站在线观看| 揄拍成人国产精品免费看视频| 大陆胖女人与丈夫操b国语高清| 国产亚洲欧美另类在线观看| 国产品国产三级国产普通话三级| 青青草国内在线视频精选| 日韩欧美亚洲熟女人妻| 欧美偷拍亚洲一区二区| 中文字幕人妻一区二区视频| 亚洲欧美激情国产综合久久久| 2020久久躁狠狠躁夜夜躁| 成人福利视频免费在线| 91中文字幕最新合集| 亚洲av色香蕉一区二区三区| 不卡日韩av在线观看| 午夜精品九一唐人麻豆嫩草成人| 国产麻豆国语对白露脸剧情| 日本免费午夜视频网站| 哥哥姐姐综合激情小说| 五十路丰满人妻熟妇| 久久机热/这里只有| 亚洲 欧美 精品 激情 偷拍| 久久亚洲天堂中文对白| 国产精品久久久久久久精品视频| 老司机午夜精品视频资源| 天天色天天舔天天射天天爽| 顶级尤物粉嫩小尤物网站| 91精品国产黑色丝袜| 天码人妻一区二区三区在线看| 久久久制服丝袜中文字幕| 人妻另类专区欧美制服| 78色精品一区二区三区| 亚洲一区二区激情在线| 五月天久久激情视频| 日韩av免费观看一区| 亚洲av一妻不如妾| 日本av在线一区二区三区| 日本丰满熟妇大屁股久久| 国产日韩欧美视频在线导航| 日本少妇人妻xxxxx18| 天天做天天爽夜夜做少妇| 精品一线二线三线日本| 免费高清自慰一区二区三区网站 | 国产又粗又猛又爽又黄的视频美国| 欧美精品国产综合久久| 日本熟女50视频免费| weyvv5国产成人精品的视频| 中文字日产幕乱六区蜜桃| 人妻丰满熟妇综合网| 久草视频在线免播放| 欧美另类z0z变态| 亚洲最大黄了色网站| 99热99re在线播放| av破解版在线观看| 中文字幕成人日韩欧美| 日本熟妇丰满厨房55| 高清成人av一区三区| 最新国产精品网址在线观看| 免费在线观看视频啪啪| 中文字幕一区二区三区蜜月 | 丰满的子国产在线观看| 97人妻无码AV碰碰视频| 偷拍自拍视频图片免费| 欧美另类z0z变态| 2022国产精品视频| 伊人日日日草夜夜草| 91亚洲手机在线视频播放| 国产卡一卡二卡三乱码手机| 特黄老太婆aa毛毛片| 成年午夜影片国产片| 欧美性受xx黑人性猛交| 精品视频中文字幕在线播放 | 国产美女一区在线观看| 日本高清成人一区二区三区| 久草视频在线一区二区三区资源站 | 天天做天天干天天操天天射| 久久精品久久精品亚洲人| 天堂va蜜桃一区入口| 成人动漫大肉棒插进去视频| 成年午夜影片国产片| 天天做天天爽夜夜做少妇| 偷偷玩弄新婚人妻h视频| 亚洲av日韩av网站| 91精品啪在线免费| nagger可以指黑人吗| 久久久精品999精品日本| 欧美一区二区中文字幕电影| 伊人情人综合成人久久网小说| 最近中文字幕国产在线| 国产一级精品综合av| 日韩一个色综合导航| 一区二区视频视频视频| 在线 中文字幕 一区| 91老熟女连续高潮对白| 欧美亚洲免费视频观看| 99国内小视频在现欢看| 女警官打开双腿沦为性奴| 伊人开心婷婷国产av| 亚洲高清国产一区二区三区| 日韩欧美一级精品在线观看| 成人高潮aa毛片免费| 国产精品国色综合久久| 亚洲 中文 自拍 无码| 中文字幕成人日韩欧美| 这里有精品成人国产99| 午夜精品一区二区三区城中村| 亚洲精品国品乱码久久久久| 欧美亚洲一二三区蜜臀| 一区二区三区麻豆福利视频| av亚洲中文天堂字幕网| 欧美精品中文字幕久久二区| 欧美男人大鸡吧插女人视频| 国产性生活中老年人视频网站| 日本少妇精品免费视频| 又粗又硬又猛又爽又黄的| 日韩熟女系列一区二区三区| 天天操天天污天天射| 在线免费观看99视频| 绝顶痉挛大潮喷高潮无码| 大学生A级毛片免费视频| 成年女人免费播放视频| 欧美黑人性猛交xxxxⅹooo| 欧美精品伦理三区四区| 国产97视频在线精品| 欧美日韩一区二区电影在线观看| 国产成人精品福利短视频| 综合一区二区三区蜜臀| 久草视频首页在线观看| 888亚洲欧美国产va在线播放| 国产卡一卡二卡三乱码手机| 日本啪啪啪啪啪啪啪| 操日韩美女视频在线免费看| 亚洲欧美国产综合777| 国产V亚洲V天堂无码欠欠| 免费岛国喷水视频在线观看| 青青在线视频性感少妇和隔壁黑丝| 日韩午夜福利精品试看| 欧美偷拍亚洲一区二区| 97年大学生大白天操逼| 自拍偷拍,中文字幕| 欧美一区二区三区啪啪同性| 欧美性受xx黑人性猛交| 亚洲国产欧美国产综合在线| 欧美韩国日本国产亚洲| 蜜桃视频在线欧美一区| 亚洲人妻30pwc| 人妻久久久精品69系列| 可以免费看的www视频你懂的| 国产黄网站在线观看播放| 天天干天天操天天插天天日| 日本一二三中文字幕| av手机在线免费观看日韩av| 偷拍自拍亚洲视频在线观看| 青青青国产片免费观看视频| 日本午夜爽爽爽爽爽视频在线观看| 亚洲欧美精品综合图片小说| 久久精品视频一区二区三区四区| 天天综合天天综合天天网| 不戴胸罩引我诱的隔壁的人妻| 性感美女高潮视频久久久| 欧美精产国品一二三区| 水蜜桃国产一区二区三区| 青青在线视频性感少妇和隔壁黑丝 | 日本人妻精品久久久久久| 欧美精产国品一二三产品价格| 操人妻嗷嗷叫视频一区二区| 日本又色又爽又黄又粗| 青青在线视频性感少妇和隔壁黑丝 | 亚洲一区二区激情在线| 狍和女人的王色毛片| 中国无遮挡白丝袜二区精品| 丁香花免费在线观看中文字幕| 大鸡巴操b视频在线| 91麻豆精品久久久久| 自拍偷拍亚洲精品第2页| 久久丁香婷婷六月天| 懂色av之国产精品| 午夜精品一区二区三区更新| 夜夜嗨av一区二区三区中文字幕| 亚洲天堂精品福利成人av| 人妻3p真实偷拍一二区| 色哟哟在线网站入口| 国产a级毛久久久久精品| 国产普通话插插视频| 日本少妇的秘密免费视频| av黄色成人在线观看| 中英文字幕av一区| AV天堂一区二区免费试看| 日本韩国免费福利精品| 在线视频精品你懂的| av高潮迭起在线观看| 在线国产精品一区二区三区| 精品久久久久久高潮| 国产乱子伦一二三区| 沈阳熟妇28厘米大战黑人| 18禁免费av网站| 99热久久极品热亚洲| 中国黄色av一级片| 国产精品入口麻豆啊啊啊| 全国亚洲男人的天堂| 国产污污污污网站在线| 久久综合老鸭窝色综合久久| 丝袜亚洲另类欧美变态| 国产精品久久9999| 亚洲成人国产综合一区| 首之国产AV医生和护士小芳| 天天射夜夜操综合网| 国内自拍第一页在线观看| 热99re69精品8在线播放| 91麻豆精品久久久久| 国产美女精品福利在线| 一区二区三区视频,福利一区二区| 任你操任你干精品在线视频| 97欧洲一区二区精品免费| 爱爱免费在线观看视频| 绝顶痉挛大潮喷高潮无码 | 日韩成人免费电影二区| 粉嫩欧美美人妻小视频| 色呦呦视频在线观看视频| 亚洲av色图18p| 日韩av中文在线免费观看| 黑人3p华裔熟女普通话| 97人妻无码AV碰碰视频| av日韩在线观看大全| 精品一线二线三线日本| 人妻另类专区欧美制服| 真实国产乱子伦一区二区| 色婷婷久久久久swag精品| 亚洲国产最大av综合| 性感美女高潮视频久久久| 57pao国产一区二区| 国产日韩av一区二区在线| 成人高清在线观看视频| 亚洲天堂精品福利成人av| 亚洲中文精品人人免费| 男人天堂最新地址av| 日韩中文字幕精品淫| 欧美成人猛片aaaaaaa| 亚洲变态另类色图天堂网| 日韩美女搞黄视频免费| 夜色17s精品人妻熟女| 日韩av中文在线免费观看| 日本一区美女福利视频| 日日夜夜狠狠干视频| 99热99这里精品6国产| av手机在线观播放网站| 99一区二区在线观看| 亚洲精品中文字幕下载| 精品久久久久久久久久久a√国产| 涩爱综合久久五月蜜臀| 中文字幕免费福利视频6| 97人妻总资源视频| 国产亚洲成人免费在线观看| 中文字幕日本人妻中出| 中文乱理伦片在线观看| 人人人妻人人澡人人| 国产精品探花熟女在线观看| 社区自拍揄拍尻屁你懂的| 国产夫妻视频在线观看免费| 亚洲中文字幕国产日韩| 大胆亚洲av日韩av| 男女啪啪啪啪啪的网站| 在线免费观看靠比视频的网站| 色吉吉影音天天干天天操| 中文字幕一区二区自拍| 国产成人精品久久二区91| 天天射夜夜操狠狠干| 色爱av一区二区三区| 亚洲精品国品乱码久久久久| 免费在线福利小视频| 日本真人性生活视频免费看| 东京热男人的av天堂| 成人精品视频99第一页| 日韩三级电影华丽的外出| 成年人该看的视频黄免费| 自拍 日韩 欧美激情| 不卡日韩av在线观看| 亚洲一区二区人妻av| 中文乱理伦片在线观看| 久久久超爽一二三av| 啊啊好慢点插舔我逼啊啊啊视频| 亚洲的电影一区二区三区| 91精品国产高清自在线看香蕉网| 大屁股肉感人妻中文字幕在线| 欧美日韩一级黄片免费观看| 99热久久这里只有精品| 视频 一区二区在线观看| 黑人巨大的吊bdsm| 99久久99久国产黄毛片| 四川五十路熟女av| 国产亚洲四十路五十路| 韩国AV无码不卡在线播放| 亚洲一区二区三区av网站| 亚洲人妻视频在线网| 久草电影免费在线观看| 亚洲熟女久久久36d| 国产精彩福利精品视频| 国产黄色大片在线免费播放| 综合页自拍视频在线播放| 75国产综合在线视频| 天天日天天玩天天摸| 久久久人妻一区二区| 丰满的子国产在线观看| 东京热男人的av天堂| 国语对白xxxx乱大交| 亚洲天堂有码中文字幕视频| 亚洲中文精品字幕在线观看| 亚洲综合在线视频可播放| 狠狠鲁狠狠操天天晚上干干| 亚洲精品一线二线在线观看| 亚洲国际青青操综合网站| 偷拍自拍亚洲视频在线观看| 91久久国产成人免费网站| 国产亚洲欧美视频网站| 337p日本大胆欧美人| 丝袜国产专区在线观看| 1000小视频在线| 韩国男女黄色在线观看| 99久久中文字幕一本人| 国产亚洲视频在线二区| 亚洲高清国产自产av| av天堂中文字幕最新| 在线观看911精品国产| 亚洲丝袜老师诱惑在线观看| 国产成人精品一区在线观看| 99人妻视频免费在线| 粉嫩欧美美人妻小视频| 国产精品国产三级国产午| 中英文字幕av一区| 日韩av有码一区二区三区4| 日本午夜爽爽爽爽爽视频在线观看| 青娱乐蜜桃臀av色| 亚洲精品av在线观看| 亚洲欧美激情中文字幕| 人人妻人人人操人人人爽| 综合激情网激情五月五月婷婷| 天天夜天天日天天日| 日韩美女精品视频在线观看网站 | 视频一区二区在线免费播放| 亚洲av日韩高清hd| 少妇一区二区三区久久久| 中文字幕第三十八页久久| 亚洲精品欧美日韩在线播放| 亚洲成人av在线一区二区| 男人在床上插女人视频| 五十路熟女av天堂| 不戴胸罩引我诱的隔壁的人妻| 国产成人午夜精品福利| 国产精品3p和黑人大战| 99久久久无码国产精品性出奶水| 中文字幕第1页av一天堂网| 黑人解禁人妻叶爱071| 沙月文乃人妻侵犯中文字幕在线| 91www一区二区三区| 91久久人澡人人添人人爽乱| 日本一二三中文字幕| 欧美精产国品一二三产品价格| 91一区精品在线观看| 爆乳骚货内射骚货内射在线| 日韩加勒比东京热二区| 成人影片高清在线观看| 亚洲av色香蕉一区二区三区 | 青青青青青青青青青国产精品视频| 欧美aa一级一区三区四区| 日韩精品啪啪视频一道免费| 国产在线观看黄色视频| 在线新三级黄伊人网| av中文字幕国产在线观看| 黄色在线观看免费观看在线| 北条麻妃av在线免费观看| 狠狠鲁狠狠操天天晚上干干| 扒开让我视频在线观看| 亚洲一区久久免费视频| 日本福利午夜电影在线观看| 亚洲 中文字幕在线 日韩| 91人妻人人做人人爽在线| 91精品资源免费观看| 阴茎插到阴道里面的视频| 亚洲乱码中文字幕在线| 大屁股熟女一区二区三区| 噜噜色噜噜噜久色超碰| 97色视频在线观看| 在线观看操大逼视频| 亚洲av日韩精品久久久久久hd| 日韩av大胆在线观看| 欧美香蕉人妻精品一区二区| 天天艹天天干天天操| 任你操视频免费在线观看| 欧美视频中文一区二区三区| 91极品新人『兔兔』精品新作| 精品人妻伦一二三区久 | 男人的天堂一区二区在线观看| 一区二区三区日韩久久| 亚洲精品 日韩电影| 超碰97人人澡人人| 自拍偷区二区三区麻豆| 天天干天天插天天谢| 97精品综合久久在线| 欧美一区二区三区乱码在线播放| 亚洲综合一区成人在线| 北条麻妃高跟丝袜啪啪| 青青青青操在线观看免费| 97人人模人人爽人人喊| 亚洲护士一区二区三区| 2012中文字幕在线高清| 国产精品手机在线看片| 93人妻人人揉人人澡人人| 亚洲视频在线视频看视频在线| 国产女孩喷水在线观看| 久草视频 久草视频2| 自拍偷拍日韩欧美亚洲| 五月精品丁香久久久久福利社| 青娱乐在线免费视频盛宴| 自拍偷拍亚洲另类色图| 天天夜天天日天天日| av资源中文字幕在线观看| 激情啪啪啪啪一区二区三区 | japanese五十路熟女熟妇| 日韩特级黄片高清在线看| 亚洲国产成人av在线一区| 亚洲欧美色一区二区| 可以免费看的www视频你懂的| 边摸边做超爽毛片18禁色戒| 久久久久久九九99精品| 直接观看免费黄网站| 2025年人妻中文字幕乱码在线| 国产麻豆剧传媒精品国产av蜜桃| 大陆精品一区二区三区久久| 国产va在线观看精品| 日本熟女50视频免费| 成年人中文字幕在线观看| 国产精品sm调教视频| 国产精品久久综合久久| 最新国产精品拍在线观看| 国产福利小视频二区| 久久精品国产23696| 日韩av熟妇在线观看| 国产一区二区在线欧美| 黑人解禁人妻叶爱071| 97超碰免费在线视频| 一区二区三区国产精选在线播放| 久草视频中文字幕在线观看| jiuse91九色视频| 1769国产精品视频免费观看| 国产黄色a级三级三级三级| 天天日天天爽天天爽| 色秀欧美视频第一页| 久久丁香婷婷六月天| 欧美精品欧美极品欧美视频| 青青青青青青青青青青草青青| 青青草亚洲国产精品视频| 18禁美女羞羞免费网站| av老司机亚洲一区二区| 国产视频网站一区二区三区| 欧美成人一二三在线网| 成年人黄色片免费网站| 日曰摸日日碰夜夜爽歪歪| 欧美一级片免费在线成人观看 | 福利视频广场一区二区| 欧美日韩高清午夜蜜桃大香蕉| 欧美色婷婷综合在线| 少妇一区二区三区久久久| 日韩人妻在线视频免费| 青青社区2国产视频| 亚洲精品一区二区三区老狼| 青青社区2国产视频| 可以在线观看的av中文字幕| 婷婷综合亚洲爱久久| 久草视频中文字幕在线观看| 无忧传媒在线观看视频| 日韩欧美中文国产在线| 国产不卡av在线免费| 五十路丰满人妻熟妇| 在线亚洲天堂色播av电影| 免费观看国产综合视频| 18禁无翼鸟成人在线| 日韩人妻丝袜中文字幕| 欧美色呦呦最新网址| 99人妻视频免费在线| 在线播放 日韩 av| 爆乳骚货内射骚货内射在线| 日韩黄色片在线观看网站| 国产aⅴ一线在线观看| 黄色大片免费观看网站| 美女福利视频网址导航| 91中文字幕免费在线观看| 在线 中文字幕 一区| 国产无遮挡裸体免费直播视频| av乱码一区二区三区| 搞黄色在线免费观看| 亚洲1卡2卡三卡4卡在线观看| 成年美女黄网站18禁久久| 日韩不卡中文在线视频网站| 老司机免费视频网站在线看| 2018最新中文字幕在线观看| 97资源人妻免费在线视频| 久久丁香花五月天色婷婷| 在线视频免费观看网| 国产精品国色综合久久| 亚洲免费在线视频网站| 91精品国产高清自在线看香蕉网| 中文字幕一区二区亚洲一区| 午夜激情高清在线观看| 欧美3p在线观看一区二区三区| 巨乳人妻日下部加奈被邻居中出 | 久久免看30视频口爆视频| 国产黄色大片在线免费播放| 国产精品视频欧美一区二区| 日韩av有码中文字幕| 99热碰碰热精品a中文| 在线观看视频 你懂的| 黄页网视频在线免费观看 | 久久三久久三久久三久久| 日本一区美女福利视频| 日韩一区二区电国产精品| 国产janese在线播放| 日本午夜久久女同精女女| 抽查舔水白紧大视频| 国产九色91在线观看精品| 天堂av在线官网中文| 91亚洲精品干熟女蜜桃频道 | 天堂av中文在线最新版| 久久久久久久久久久久久97| 在线免费观看日本片| 青青草视频手机免费在线观看| 亚洲av可乐操首页| 中文字幕无码一区二区免费| 黄色男人的天堂视频| 老司机在线精品福利视频| 五月精品丁香久久久久福利社| 亚洲天堂精品久久久| 成人国产小视频在线观看| 一区二区三区四区视频在线播放| 超黄超污网站在线观看| 欧美va不卡视频在线观看| 天天躁夜夜躁日日躁a麻豆| 国产品国产三级国产普通话三级| 91免费福利网91麻豆国产精品 | 91av精品视频在线| 成人久久精品一区二区三区| 99国产精品窥熟女精品| 色吉吉影音天天干天天操| 亚洲第一黄色在线观看| 久久久人妻一区二区| 风流唐伯虎电视剧在线观看| 五月天中文字幕内射| 1000部国产精品成人观看视频| 日本人妻少妇18—xx| 欧美3p在线观看一区二区三区| mm131美女午夜爽爽爽| av老司机精品在线观看| 99精品国自产在线人| 中文字幕一区二 区二三区四区 | 中文字幕在线第一页成人| jiuse91九色视频| 天天草天天色天天干| 欧美成一区二区三区四区| 国产午夜亚洲精品麻豆| 中文字幕视频一区二区在线观看| 亚洲一区二区三区精品乱码| 人人妻人人爽人人添夜| yellow在线播放av啊啊啊| 做爰视频毛片下载蜜桃视频1| 亚洲 中文字幕在线 日韩| 亚洲高清国产拍青青草原| av中文字幕福利网| 天堂女人av一区二区| 老司机福利精品视频在线| 人妻凌辱欧美丰满熟妇| 国产男女视频在线播放| 超碰中文字幕免费观看| 天天日天天爽天天干| 操人妻嗷嗷叫视频一区二区| 日韩在线中文字幕色| 亚洲视频在线视频看视频在线| 香蕉aⅴ一区二区三区| 久久这里只有精彩视频免费| 成人H精品动漫在线无码播放| av乱码一区二区三区| 100%美女蜜桃视频| 亚洲激情,偷拍视频| 黄色的网站在线免费看| 韩国男女黄色在线观看| 国产av自拍偷拍盛宴| 91国偷自产一区二区三区精品| 狠狠躁夜夜躁人人爽天天天天97| 黄色片黄色片wyaa| 欧美一区二区三区乱码在线播放| 动漫精品视频在线观看| 9色精品视频在线观看| 桃色视频在线观看一区二区 | 日本男女操逼视频免费看| 中文字幕日韩精品就在这里| 一区二区三区另类在线| 亚洲天堂第一页中文字幕| 日韩精品中文字幕福利| 亚洲自拍偷拍综合色| 久久久久五月天丁香社区 | 国产一区二区神马久久| 91国偷自产一区二区三区精品| 又粗又长 明星操逼小视频| 亚洲午夜高清在线观看| 国产超码片内射在线| 动漫黑丝美女的鸡巴| 最新国产精品拍在线观看| mm131美女午夜爽爽爽| 国产精品国产三级国产精东| 国产黄色片蝌蚪九色91| 岛国免费大片在线观看| 精品av久久久久久久| 久久一区二区三区人妻欧美| 国产精品国产三级国产精东 | 国产性生活中老年人视频网站| 欧美成人综合视频一区二区| 搡老妇人老女人老熟女| 91精品国产麻豆国产| 国产成人精品福利短视频| 黑人大几巴狂插日本少妇| 特级无码毛片免费视频播放 | 亚洲午夜伦理视频在线| 国产精品伦理片一区二区| 国产V亚洲V天堂无码欠欠| 欧美另类z0z变态| av乱码一区二区三区| 天堂av狠狠操蜜桃| 欧美视频不卡一区四区| 老司机午夜精品视频资源| yellow在线播放av啊啊啊| 中文字幕在线一区精品| 男生用鸡操女生视频动漫| 久久免费看少妇高潮完整版| 狠狠躁夜夜躁人人爽天天久天啪| 18禁免费av网站| 91精品综合久久久久3d动漫 | 国产精品久久综合久久| 老司机午夜精品视频资源| 适合午夜一个人看的视频| 在线亚洲天堂色播av电影| 2021久久免费视频| 这里只有精品双飞在线播放| 日本黄色特一级视频| 亚洲精品 欧美日韩| 美女 午夜 在线视频| 精品一区二区三区三区色爱| 最新国产精品网址在线观看| 日本a级视频老女人| 18禁美女黄网站色大片下载| 国产使劲操在线播放| 99热久久极品热亚洲| 人人妻人人爽人人添夜| 在线观看免费视频网| 亚洲自拍偷拍综合色| 在线观看免费岛国av| 日本性感美女视频网站| 自拍偷拍亚洲另类色图| 北条麻妃高跟丝袜啪啪| 人妻久久无码中文成人| 亚洲一区二区激情在线| 日本韩国免费一区二区三区视频 | 2022精品久久久久久中文字幕| 中文字幕成人日韩欧美| 亚洲国产精品黑丝美女| 亚洲欧美成人综合视频| 51国产偷自视频在线播放| 动漫黑丝美女的鸡巴| 国产精品sm调教视频| 在线观看av亚洲情色| 欧美日韩高清午夜蜜桃大香蕉 | 日韩欧美一级黄片亚洲| 9l人妻人人爽人人爽| 大陆胖女人与丈夫操b国语高清| 视频一区二区三区高清在线| 日本高清撒尿pissing| 一区二区三区在线视频福利| 日本午夜爽爽爽爽爽视频在线观看 | 欧美激情电影免费在线| 一区二区视频在线观看视频在线| caoporm超碰国产| 青青擦在线视频国产在线| 久草免费人妻视频在线| 亚洲av琪琪男人的天堂| 亚洲欧美激情国产综合久久久 | 久草视频在线看免费| 少妇被强干到高潮视频在线观看 | 一区二区三区四区中文| 九色视频在线观看免费| 大香蕉伊人国产在线| 国产日韩一区二区在线看| av手机在线观播放网站| 国产又粗又硬又猛的毛片视频| 人人妻人人爽人人澡人人精品| 精产国品久久一二三产区区别| 一区二区三区四区中文| 东京热男人的av天堂| 日本黄在免费看视频| 国产高清97在线观看视频| 超级av免费观看一区二区三区| 91精品资源免费观看| 午夜精品福利91av| 日韩无码国产精品强奸乱伦| 欧美视频不卡一区四区| 日本熟女50视频免费| 日韩美女福利视频网| 欧美第一页在线免费观看视频| 四川五十路熟女av| 四虎永久在线精品免费区二区| 果冻传媒av一区二区三区| 大鸡吧插逼逼视频免费看 | 91‖亚洲‖国产熟女| 熟女妇女老妇一二三区| 成人蜜桃美臀九一一区二区三区| 国产麻豆91在线视频| 日本女人一级免费片| 亚洲一级特黄特黄黄色录像片| 沙月文乃人妻侵犯中文字幕在线| 99精品视频之69精品视频| 少妇与子乱在线观看| 91传媒一区二区三区| 久草视频在线免播放| 瑟瑟视频在线观看免费视频| 人人妻人人爽人人澡人人精品| 北条麻妃高跟丝袜啪啪| 午夜在线一区二区免费| 午夜免费体验区在线观看| 青青青青操在线观看免费| 欧美日韩亚洲国产无线码| 亚洲特黄aaaa片| 亚洲综合乱码一区二区| 午夜激情高清在线观看| 亚洲久久午夜av一区二区| 91中文字幕免费在线观看| 少妇人妻100系列| 亚洲熟妇久久无码精品| 夜夜骑夜夜操夜夜奸| 丝袜肉丝一区二区三区四区在线| 清纯美女在线观看国产| 欧美国品一二三产区区别| 唐人色亚洲av嫩草| 精品日产卡一卡二卡国色天香 | 日韩av有码中文字幕|