谁能给个java的小例子,实现swing调用sql的表,并能进行增删改查操作。
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了谁能给个java的小例子,实现swing调用sql的表,并能进行增删改查操作。相关的知识,希望对你有一定的参考价值。
可以给我一个简单的SQL数据库,比如几行数据,包括ID,Name,Age,Sex那种
我是初学者(接触JAVA刚1个多月),java先调驱动连接SQL数据库那段我会,swing组件也都会,用java拼接SQL语句这也懂一些,就是如何把SQL中的表添加到JTable里面比较麻烦,如果用二维数组不知道大小,如何生成也不太懂;
如果添加进来,Statement一些方法executeQuery跟executeUpdate的使用也不是很了解,自己看了一下午API也没个头绪,可能没有个好的方法。先谢谢了~最好能有个完整的代码,太麻烦的话给点儿之前我提到不懂得那些代码段也成。
首先谢楼下的回答,你说的TableModel我知道怎么用,我主要的症结在于用swing来对数据库里面的数据进行操作...单纯的swing框架的Table修改了之后我回数据库看还是没变...
其次在你的swing中定义一个table,然后实例化你定义的这个model,然后用table.setMode(DefaultTableModel),把你实例化的那个model传入到table中,这样就会在tabale中显示了你要的结果,至于你说要与数据库连接操纵,这里你就需要加入相关的鼠标listener了,在这个例子中,我给你加入了删除和修改两个操作,就是当对这表格点击鼠标的时候,会出现相应的选择。这你需要用到JPopupMenu, 和JPopupMenu的元素JMenuItem了
首先给你tablemodel的类:
//这个类定义了你如何在表格中显示数据和如何获得表格中的数据,需要把二维数组传入这个类,所以在构造函数中传入了二维数组
public class FriendTableModel extends DefaultTableModel
private String[] columns = "学号","姓名","性别","年龄","邮箱";
private Object a[][];
public FriendTableModel(Object [][] a)
this.a=a;
public Object getUserAt(int rowIndex)
Object[] u = a[rowIndex];
return u;
public void removeRow(int row)
a[row]=null;
@Override
public Object getValueAt(int rowIndex, int columnIndex)
Object[] u = a[rowIndex];
switch(columnIndex)
case 0:
return u[0];
case 1:
return u[1];
case 2:
return u[2];
case 3:
return u[3];
case 4:
return u[4];
default:
return "";
@Override
public int getColumnCount()
return columns.length;
@Override
public int getRowCount()
if (a==null) return 0;
return a.length;
@Override
public boolean isCellEditable(int r, int c)
return false;
@Override
public String getColumnName(int columnIndex)
return columns[columnIndex];
然后给你主类,这个类中包含了与数据连接,把数据转换二维数组,定义各个操作的listener,等
public class DataFrame extends JFrame implements ActionListener
public static void main(String args[])
new DataFrame();
Connection con;
Statement stmt;
ResultSet rs;
Object a[][]; //这里的a[][]就是一个i行j列的表,用来显示数据库中数据用的
Object b[]; //从tablemode返回的一行数据, 当你修改数时,向数据库更新的时候,数据从这个对象中获得;
int row;//你修改或者要删除的行
int i=0; //输据的条数
JTable jTable = null;//用来显示表格
JPopupMenu jPopupMenu;//用来显示你对表格的操作
private JMenuItem delete; //删除操作
private JMenuItem upload;//修改操作
Object header[]="学号","姓名","性别","年龄","邮箱";//e是一个j列的表头,用来存储字段名称的,比如说上面的"学号","姓名"等字符串
DataFrame()
try
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
catch(ClassNotFoundException e)
System.out.println("Error:"+e);
try
con=DriverManager.getConnection("jdbc:odbc:mysql","sa","123");
stmt=con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);
rs=stmt.executeQuery("select * from student");
while(rs.next())//把数据库数据写入二维数组
a[i][0]=rs.getInt(1);
a[i][1]=rs.getString(2);
a[i][2]=rs.getString(3);
a[i][3]=rs.getInt(4);
a[i][4]=rs.getString(5);
i++;
catch(SQLException e)
System.out.println("SqlError:"+e);
jTable = new JTable();
jTable.addMouseListener(new inMouseEven()); //给鼠标定义事件,就是你点击鼠标的时候,会发生的事情
jTable.setShowGrid(false);
jPopupMenu = new JPopupMenu();
delete = new JMenuItem();
delete.setText("删除");
delete.addMouseListener(new Delete_mouseAdapter());//给点击删除时增加事件
upload = new JMenuItem();
upload.setText("修改");
upload.addMouseListener(new Uoload_mouseAdapter());//给点击更新时增加事件
jPopupMenu.add(delete);
jPopupMenu.add(upload);
FriendTableModel ftm = new FriendTableModel(a); //实例化tablemodel,把二维数组传进去
if (ftm.getRowCount() > 0)
jTable.setModel(ftm);//把Tablemodel传入table中
Container con=getContentPane();
getContentPane().add(new JScrollPane(jTable),BorderLayout.CENTER);
setSize(400,300);
addWindowListener(new WindowAdapter()
public void windowClosing(WindowEvent e)
System.exit(0);
);
setVisible(true);
validate();
public void actionPerformed(ActionEvent e)
throw new UnsupportedOperationException("Not supported yet.");
//当你点击表格中的一行,出现选项,让你选择具体操作,此处是点击鼠标事件的具体代码
private class inMouseEven extends MouseAdapter
@Override
public void mouseClicked(MouseEvent e)
if (e.getClickCount() < 1)
return;
row = jTable.getSelectedRow(); //返回你点击的行数
if (row >= 0)
FriendTableModel ftm =(FriendTableModel) jTable.getModel();
b= ftm.getUserAt(row ); //返回此行的数据
jPopupMenu.show(DataFrame.this, e.getX() + 160, e.getY() + 75);//出现操作选项
//删除操作的listenr,对应的code
private class Delete_mouseAdapter extends MouseAdapter
@Override
public void mousePressed(MouseEvent e)
try
String sql = "delete from **where id = " + b[0]; //此处b[]是上面当你点击鼠标是返回的那一行数据,b[]中对应的是表格中一行数据。
stmt.executeQuery(sql);
FriendTableModel ftm =(FriendTableModel) jTable.getModel();
ftm.removeRows(0, row );
jTable.updateUI();
catch (SQLException ex)
Logger.getLogger(DataFrame.class.getName()).log(Level.SEVERE, null, ex);
//更新操作对应的code
private class Uoload_mouseAdapter extends MouseAdapter
@Override
public void mousePressed(MouseEvent e)
String sql ="UPDATE Student SET Address = %s, City = %s WHERE id = %s" %b[1],b[2],b[0]...//这里sql自己写,就是更新所有的数据,新数据从b[...]中获得
stmt.executeQuery(sql);
其中一些sql语句没有给你写出,这个你照着你的数据库写,还有数据库的链接你需要改一下,上面的代码没有经过测试,因为我没有链接数据库,但是整体思路就应该是这样,对应你的具体要求,修改代码,我想应该可以运行起来的,你需要去理解这些代码,然后写出sql语句,给出正确的数据库配置,修改其中可能的错误。
所有代码都是亲手写的,希望对刚接触java的你有用。
如果你从中得到帮助,记得肯定我的劳动,给我分哦。 参考技术A 如果要写出来代码太多了,给你个思路:JTable本身只是一个框架,它不承载数据,你看到的数据,也就是表格中的数据,其实是TableModel在显示,TableModel里面包含了一系列的增、删、改、查,相信你能看得懂API的,别人给你例子,永远都是别人的,除非你自己写出来。如果再不会,我们再联系 参考技术B 你可以用JDBC连接数据库!import java.sql.*;
public class db
String conURL="jdbc:odbc:Driver=MicroSoft Access Driver (*.mdb); "+"DBQ=db.mdb";
private Connection Ex1Con=null;
private Statement st=null;
private ResultSet rs=null;
public db()
try
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
catch (ClassNotFoundException e1)
// TODO 自动生成 catch 块
e1.printStackTrace();
try
Ex1Con=DriverManager.getConnection(conURL);
catch (SQLException e)
// TODO 自动生成 catch 块
e.printStackTrace();
try
st=Ex1Con.createStatement();
catch (SQLException e)
// TODO 自动生成 catch 块
e.printStackTrace();
//修改操作
public int exsql(String sql)
int num=0;
try
st.executeUpdate(sql);
catch (SQLException e)
// TODO 自动生成 catch 块
e.printStackTrace();
return num;
//查询操作
public ResultSet exselect(String sql)
try
rs=st.executeQuery(sql);
catch (SQLException e)
// TODO 自动生成 catch 块
e.printStackTrace();
return rs;
//添加操作
public int exinsert(String sql)
int num=0;
try
num=st.executeUpdate(sql);
catch (SQLException e)
// TODO 自动生成 catch 块
e.printStackTrace();
return num;
//删除操作
public int exdelete(String sql)
int num=0;
try
num=st.executeUpdate(sql);
catch (SQLException e)
// TODO 自动生成 catch 块
e.printStackTrace();
return num;
//关闭数据库
public void close()
rs=null;
try
st.close();
catch (SQLException e)
// TODO 自动生成 catch 块
e.printStackTrace();
try
Ex1Con.close();
catch (SQLException e)
// TODO 自动生成 catch 块
e.printStackTrace();
这是我写的一个连接数据库和对数据库操作的类,你参考参考!用SWING就是调用的问题!
JAVA编写的聊天工具
谁能给个JAVA编写的聊天程序我啊!
急用于制作JAVA期末课程设计!谢谢
设计要求:(1)有登陆、注册的功能和界面
(2)能实现客户的交流(聊天)
帮助注意:(1)附带后台服务器
(2)代码能运行
(3)最好附带详细的注释说明
注:万分感谢能帮上我的人!谢谢!
太长话,可以通过邮箱发送给我,在百度知道上注上你的邮箱地址。谢谢!
本人的邮箱:denghui@163.com
import javax.swing.*;
import java.awt.*;
import java.awt.event.*;
import java.io.*;
import java.net.*;
import java.applet.*;
public class regit extends JApplet implements ActionListener,ItemListener//接口
String s=null;
//对象的声明
JLabel labelname,labelpass,labelsxe,labeladdress,labelmail,labelphone;//标签
JTextField textname,textaddress,textmail,textphone;//文本框
JRadioButton r1,r2;//单选按纽
ButtonGroup bg;//组
JPasswordField textpass;//密码域
JButton buttonregit,buttonreset;//注册按纽 重写按纽
JPanel p;//面板
String sex;//定义性别字符串
URL url;//统一资源定位
BufferedWriter out1,out2;//流
BufferedReader in;
//布局方式
GridBagLayout gbl;
GridBagConstraints gc;
AppletContext co;//接口
//初始化
public void init()
//new 对象
labelname=new JLabel("用 户 名:");
labelpass=new JLabel("用户密码:");
labelsxe=new JLabel("性别:");
labeladdress=new JLabel("地址:");
labelmail=new JLabel("电子邮件:");
labelphone=new JLabel("联系电话:");
textname=new JTextField(15); textname.setForeground(Color.red);
textname.setToolTipText("请在这输入你的用户名");
textaddress=new JTextField(15);textaddress.setForeground(Color.red);
textaddress.setToolTipText("请在这输入你的地址");
textmail=new JTextField(15); textmail.setForeground(Color.red);
textmail.setToolTipText("请在这里输入你的E-mail地址");
textphone=new JTextField(15); textphone.setForeground(Color.red);
textphone.setToolTipText("请在这输入你的电话号码");
r1=new JRadioButton("男"); r1.setBackground(new Color(47,177,210));//设置颜色
r2=new JRadioButton("女"); r2.setBackground(new Color(47,177,210));//设置颜色
bg=new ButtonGroup();
bg.add(r1);bg.add(r2);//加入组,实现单选
textpass=new JPasswordField(15);
textpass.setToolTipText("在这里输入密码");
textpass.setForeground(Color.red);
buttonregit=new JButton("注册"); buttonregit.setBackground(new Color(47,177,210));//设置颜色
buttonregit.setToolTipText("点击按纽完成注册");
buttonreset=new JButton("填写"); buttonreset.setBackground(new Color(47,177,210));//设置颜色
buttonreset.setToolTipText("点击按纽刷新重写");
gbl=new GridBagLayout(); ///////////////////////////////////////
gc=new GridBagConstraints(); //////采用GridBagLayout布局方式////////
p=new JPanel();
p.setLayout(gbl);
p.setBackground(new Color(47,177,210));
this.getContentPane().add(p);//加入面板
gc.anchor=GridBagConstraints.NORTHWEST;
gc.gridx=2;
gc.gridy=2;
gbl.setConstraints(labelname,gc);
p.add(labelname);
gc.anchor=GridBagConstraints.NORTHWEST;
gc.gridx=4;
gc.gridy=2;
gbl.setConstraints(textname,gc);
p.add(textname);
gc.anchor=GridBagConstraints.NORTHWEST;
gc.gridx=2;
gc.gridy=4;
gbl.setConstraints(labelpass,gc);
p.add(labelpass);
gc.anchor=GridBagConstraints.NORTHWEST;
gc.gridx=4;
gc.gridy=4;
gbl.setConstraints(textpass,gc);
p.add(textpass);
gc.anchor=GridBagConstraints.NORTHWEST;
gc.gridx=2;
gc.gridy=6;
gbl.setConstraints(labelsxe,gc);
p.add(labelsxe);
gc.anchor=GridBagConstraints.NORTHWEST;
gc.gridx=4;
gc.gridy=6;
gbl.setConstraints(r1,gc);
p.add(r1);
gc.anchor=GridBagConstraints.NORTHWEST;
gc.gridx=5;
gc.gridy=6;
gbl.setConstraints(r2,gc);
p.add(r2);
gc.anchor=GridBagConstraints.NORTHWEST;
gc.gridx=2;
gc.gridy=8;
gbl.setConstraints(labeladdress,gc);
p.add(labeladdress);
gc.anchor=GridBagConstraints.NORTHWEST;
gc.gridx=4;
gc.gridy=8;
gbl.setConstraints(textaddress,gc);
p.add(textaddress);
gc.anchor=GridBagConstraints.NORTHWEST;
gc.gridx=2;
gc.gridy=10;
gbl.setConstraints(labelmail,gc);
p.add(labelmail);
gc.anchor=GridBagConstraints.NORTHWEST;
gc.gridx=4;
gc.gridy=10;
gbl.setConstraints(textmail,gc);
p.add(textmail);
gc.anchor=GridBagConstraints.NORTHWEST;
gc.gridx=2;
gc.gridy=12;
gbl.setConstraints(labelphone,gc);
p.add(labelphone);
gc.anchor=GridBagConstraints.NORTHWEST;
gc.gridx=4;
gc.gridy=12;
gbl.setConstraints(textphone,gc);
p.add(textphone);
gc.anchor=GridBagConstraints.NORTHWEST;
gc.gridx=2;
gc.gridy=16;
gbl.setConstraints(buttonregit,gc);
p.add(buttonregit);
gc.anchor=GridBagConstraints.NORTHWEST;
gc.gridx=4;
gc.gridy=16;
gbl.setConstraints(buttonreset,gc);
p.add(buttonreset);
/////////////////////////////////////////////
co=this.getAppletContext();
/////////////////////////////////////////////
buttonregit.addActionListener(this);//按纽事件的监听
buttonreset.addActionListener(this);//按纽事件的监听
r1.addItemListener(this);//选择事件的监听
r2.addItemListener(this);//选择事件的监听
textphone.addActionListener(this);
public void actionPerformed(ActionEvent e)
//注册按纽事件
if(e.getSource()==buttonregit)
String s1=textname.getText(); ////////////////////
String s2=new String(textpass.getPassword());////////////////////
String s3=textaddress.getText(); // 定义字符串 //
String s4=textmail.getText(); ////////////////////
String s5=textphone.getText(); ////////////////////
//判断注册资料 信息 是否为空
if(s1.length()==0 || s2.length()==0 ||s3.length()==0 ||s4.length()==0 ||s5.length()==0)
int error=JOptionPane.INFORMATION_MESSAGE;
JOptionPane.showMessageDialog(null,"资料不能为空,请重新注册!","【温馨提示】",error);
return;//弹出对话框并返回
try//写入到txt文件
in=new BufferedReader(new FileReader("d:\\迷离视线聊天室\\password.txt"));
catch(Exception ee)
String ss=s1;
try
while((s=in.readLine())!=null)
if(s.startsWith(ss))
JOptionPane.showMessageDialog(null,"用户名已经存在,请更换名字!");
textname.setText("");//设置为空,重新输入
textpass.setText("");
textaddress.setText("");
textmail.setText("");
textphone.setText("");
return;
catch(Exception ee)
///////////////////////////以上代码判断是否有同名
try
out1=new BufferedWriter(new FileWriter("d:\\迷离视线聊天室\\password.txt",true));
out2=new BufferedWriter(new FileWriter("d:\\迷离视线聊天室\\message.txt",true));
//创建文件
catch(Exception ee)
try
out1.write(s1+"#"+s2);//写
out1.newLine();
out2.write("用户名:"+s1);
out2.newLine();
out2.write("密码:"+s2);
out2.newLine();
out2.write("性别:"+sex);
out2.newLine();
out2.write("地址:"+s3);
out2.newLine();
out2.write("电子邮件:"+s4);
out2.newLine();
out2.write("电话:"+s5);
out2.newLine();
out1.flush();
out2.flush();//清理缓冲
out1.close();
out2.close();
catch(Exception ee)
JOptionPane.showMessageDialog(null,"注册成功!");
try
String qss="http://localhost/chatroom/chatjiemian.htm";
url=new url(/qss);//连接上网址
co.showDocument(url);
catch(Exception exx)
//////////////////////以下为回车事件
if(e.getSource()==textphone)
String s1=textname.getText(); ////////////////////
String s2=new String(textpass.getPassword());////////////////////
String s3=textaddress.getText(); // 定义字符串 //
String s4=textmail.getText(); ////////////////////
String s5=textphone.getText(); ////////////////////
//判断注册资料 信息 是否为空
if(s1.length()==0 || s2.length()==0 ||s3.length()==0 ||s4.length()==0 ||s5.length()==0)
int error=JOptionPane.INFORMATION_MESSAGE;
JOptionPane.showMessageDialog(null,"资料不能为空,请重新注册!","【温馨提示】",error);
return;//弹出对话框并返回
try//写入到txt文件
in=new BufferedReader(new FileReader("d:\\迷离视线聊天室\\password.txt"));
catch(Exception ee)
String ss=s1;
try
while((s=in.readLine())!=null)
if(s.startsWith(ss))
JOptionPane.showMessageDialog(null,"用户名已经存在,请更换名字!");
textname.setText("");//设置为空,重新输入
textpass.setText("");
textaddress.setText("");
textmail.setText("");
textphone.setText("");
return;
catch(Exception ee)
///////////////////////////以上代码判断是否有同名
try
out1=new BufferedWriter(new FileWriter("d:\\迷离视线聊天室\\password.txt",true));
out2=new BufferedWriter(new FileWriter("d:\\迷离视线聊天室\\message.txt",true));
//创建文件
catch(Exception ee)
try
out1.write(s1+"#"+s2);//写
out1.newLine();
out2.write("用户名:"+s1+"密码:"+s2+"性别:"+sex+"地址:"+s3+"电子邮件:"+s4+"电话:"+s5);//写
out2.newLine();
out1.flush();
out2.flush();//清理缓冲
out1.close();
out2.close();
catch(Exception ee)
JOptionPane.showMessageDialog(null,"注册成功!");
try
String qss="http://localhost/chatroom/chatjiemian.htm";
url=new url(/qss);//连接上网址
co.showDocument(url);
catch(Exception exx)
if(e.getSource()==buttonreset)//刷新重写事件
textname.setText("");
textpass.setText("");
textaddress.setText("");
textmail.setText("");
textphone.setText("");
//////////////////////////////////////////
//
public void itemStateChanged(ItemEvent ex)
if(ex.getSource()==r1)
sex=new String("男");
else if(ex.getSource()==r2)
sex=new String("女");
参考资料:试试看,刚在网上找的
参考技术A //聊天室的客户端import java.applet.*;
import java.awt.*;
import java.io.*;
import java.net.*;
import java.awt.event.*;
public class ChatClient extends Applet
protected boolean loggedIn;//登入状态
protected Frame cp;//聊天室框架
protected static int PORTNUM=7777; //缺省端口号7777
protected int port;//实际端口号
protected Socket sock;
protected BufferedReader is;//用于从sock读取数据的BufferedReader
protected PrintWriter pw;//用于向sock写入数据的PrintWriter
protected TextField tf;//用于输入的TextField
protected TextArea ta;//用于显示对话的TextArea
protected Button lib;//登入按钮
protected Button lob;//登出的按钮
final static String TITLE ="Chatroom applet>>>>>>>>>>>>>>>>>>>>>>>>";
protected String paintMessage;//发表的消息
public ChatParameter Chat;
public void init()
paintMessage="正在生成聊天窗口";
repaint();
cp=new Frame(TITLE);
cp.setLayout(new BorderLayout());
String portNum=getParameter("port");//呢个参数勿太明
port=PORTNUM;
if (portNum!=null) //书上是portNum==null,十分有问题
port=Integer.parseInt(portNum);
//CGI
ta=new TextArea(14,80);
ta.setEditable(false);//read only attribute
ta.setFont(new Font("Monospaced",Font.PLAIN,11));
cp.add(BorderLayout.NORTH,ta);
Panel p=new Panel();
Button b;
//for login button
p.add(lib=new Button("Login"));
lib.setEnabled(true);
lib.requestFocus();
lib.addActionListener(new ActionListener()
public void actionPerformed(ActionEvent e)
login();
lib.setEnabled(false);
lob.setEnabled(true);
tf.requestFocus();//将键盘输入锁定再右边的文本框中
);
//for logout button
p.add(lob=new Button ("Logout"));
lob.setEnabled(false);
lob.addActionListener(new ActionListener()
public void actionPerformed(ActionEvent e)
logout();
lib.setEnabled(true);
lob.setEnabled(false);
lib.requestFocus();
);
p.add(new Label ("输入消息:"));
tf=new TextField(40);
tf.addActionListener(new ActionListener()
public void actionPerformed(ActionEvent e)
if(loggedIn)
//pw.println(Chat.CMD_BCAST+tf.getText());//Chat.CMD....是咩野来?
int j=tf.getText().indexOf(":");
if(j>0) pw.println(Chat.CMD_MESG+tf.getText());
else
pw.println(Chat.CMD_BCAST+tf.getText());
tf.setText("");//勿使用flush()?
);
p.add(tf);
cp.add(BorderLayout.SOUTH,p);
cp.addWindowListener(new WindowAdapter()
public void windowClosing(WindowEvent e)
//如果执行了setVisible或者dispose,关闭窗口
ChatClient.this.cp.setVisible(false);
ChatClient.this.cp.dispose();
logout();
);
cp.pack();//勿明白有咩用?
//将Frame cp放在中间
Dimension us=cp.getSize(),
them=Toolkit.getDefaultToolkit().getScreenSize();
int newX=(them.width-us.width)/2;
int newY=(them.height-us.height)/2;
cp.setLocation(newX,newY);
cp.setVisible(true);
paintMessage="Window should now be visible";
repaint();
//登录聊天室
public void login()
if(loggedIn) return;
try
sock=new Socket(getCodeBase().getHost(),port);
is=new BufferedReader(new InputStreamReader(sock.getInputStream()));
pw=new PrintWriter(sock.getOutputStream(),true);
catch(IOException e)
showStatus("Can't get socket: "+e);
cp.add(new Label("Can't get socket: "+e));
return;
//构造并且启动读入器,从服务器读取数据,输出到文本框中
//这里,长成一个线程来避免锁住资源(lockups)
new Thread (new Runnable()
public void run()
String line;
try
while(loggedIn &&((line=is.readLine())!=null))
ta.appendText(line+"\n");
catch(IOException e)
showStatus("我的天啊,掉线了也!!!!");
return;
).start();
//假定登录(其实只是打印相关信息,并没有真正登录)
// pw.println(Chat.CMD_LOGIN+"AppletUser");
pw.println(Chat.CMD_LOGIN+"AppletUser");
loggedIn =true;
//模仿退出的代码
public void logout()
if(!loggedIn)
return;
loggedIn=false;
try
if(sock!=null)
sock.close();
catch(IOException ign)
// 异常处理哦
//没有设置stop的方法,即使从浏览器跳到另外一个网页的时候
//聊天程序还可以继续运行
public void paint(Graphics g)
Dimension d=getSize();
int h=d.height;
int w=d.width;
g.fillRect(0,0,w,2);
g.setColor(Color.black);
g.drawString(paintMessage,10,(h/2)-5);
聊天室服务器端
import java.net.*;
import java.io.*;
import java.util.*;
public class ChatServer
//聊天室管理员ID
protected final static String CHATMASTER_ID="ChatMaster";
//系统信息的分隔符
protected final static String SEP=": ";
//服务器的Socket
protected ServerSocket servSock;
//当前客户端列表
protected ArrayList clients;
//调试标记
protected boolean DEBUG=false;
public ChatParameter Chat;
//主方法构造一个ChatServer,没有返回值
public static void main(String[] argv)
System.out.println("Chat server0.1 starting>>>>>>>>>>>>>>>>");
ChatServer w=new ChatServer();
w.runServer();
System.out.println("***ERROR*** Chat server0.1 quitting");
//构造和运行一个聊天服务
ChatServer()
Chat=new ChatParameter();
clients=new ArrayList();
try
servSock=new ServerSocket(7777);//实有问题拉,不过可能是他自己定义既一个class.
System.out.println("Chat Server0.1 listening on port:"+7777);
catch(Exception e)
log("IO Exception in ChatServer.<init>");
System.exit(0);
public void runServer()
try
while(true)
Socket us=servSock.accept();
String hostName=us.getInetAddress().getHostName();
System.out.println("Accpeted from "+hostName);
//一个处理的线程
ChatHandler cl=new ChatHandler(us,hostName);
synchronized(clients)
clients.add(cl);
cl.start();
if(clients.size()==1)
cl.send(CHATMASTER_ID,"Welcome!You are the first one here");
else
cl.send(CHATMASTER_ID,"Welcome!You are the latest of"+
clients.size()+" users.");
catch(Exception e)
log("IO Exception in runServer:"+e);
System.exit(0);
protected void log(String s)
System.out.println(s);
//处理会话的内部的类
protected class ChatHandler extends Thread
//客户端scoket
protected Socket clientSock;
//读取socket的BufferedReader
protected BufferedReader is ;
//在socket 上发送信息行的PrintWriter
protected PrintWriter pw;
//客户端出主机
protected String clientIP;
//句柄
protected String login;
public ChatHandler (Socket sock,String clnt)throws IOException
clientSock=sock;
clientIP=clnt;
is=new BufferedReader(
new InputStreamReader(sock.getInputStream()));
pw=new PrintWriter (sock.getOutputStream(),true);
//每一个ChatHandler是一个线程,下面的是他的run()方法
//用于处理会话
public void run()
String line;
try
while((line=is.readLine())!=null)
char c=line.charAt(0);//我顶你老母啊 ,果只Chat.CMD咩xx冇定义 扑啊///!!!
line=line.substring(1);
switch(c)
//case Chat.CMD_LOGIN:
case 'l':
if(!Chat.isValidLoginName(line))
send(CHATMASTER_ID,"LOGIN"+line+"invalid");
log("LOGIN INVALID from:"+clientIP);
continue;
login=line;
broadcast(CHATMASTER_ID,login+" joins us,for a total of"+
clients.size()+" users");
break;
// case Chat.CMD_MESG:
case 'm':
if(login==null)
send(CHATMASTER_ID,"please login first");
continue;
int where =line.indexOf(Chat.SEPARATOR);
String recip=line.substring(0,where);
String mesg=line.substring (where+1);
log("MESG: "+login+"--->"+recip+": "+mesg);
ChatHandler cl=lookup(recip);
if(cl==null)
psend(CHATMASTER_ID,recip+"not logged in.");
else
cl.psend(login,mesg);
break;
//case Chat.CMD_QUIT:
case 'q':
broadcast(CHATMASTER_ID,"Goodbye to "+login+"@"+clientIP);
close();
return;//ChatHandler结束
// case Chat.CMD_BCAST:
case 'b':
if(login!=null)
broadcast(login,line);
else
log("B<L FROM"+clientIP);
break;
default:
log("Unknow cmd"+c+"from"+login+"@"+clientIP);
catch(IOException e)
log("IO Exception :"+e);
finally
//sock 结束,我们完成了
//还不能发送再见的消息
//得有简单的基于命令的协议才行
System.out.println(login+SEP+"All Done");
synchronized(clients)
clients.remove(this);
if(clients.size()==0)
System.out.println(CHATMASTER_ID+SEP+
"I'm so lonely I could cry>>>>>");
else if(clients.size()==1)
ChatHandler last=(ChatHandler)clients.get(0);
last.send(CHATMASTER_ID,"Hey,you are talking to yourself again");
else
broadcast(CHATMASTER_ID,"There are now"+clients.size()+" users");
protected void close()
if(clientSock==null)
log("close when not open");
return;
try
clientSock.close();
clientSock=null;
catch(IOException e)
log("Failure during close to "+clientIP);
//发送一条消息给用户
public void send(String sender,String mesg)
pw.println(sender+SEP+"*>"+mesg);
//发送私有的消息
protected void psend(String sender ,String msg)
send("<*"+sender+"*>",msg);
//发送一条消息给所有的用户
public void broadcast (String sender,String mesg)
System.out.println("Broadcasting"+sender+SEP+mesg);
for(int i=0;i<clients.size();i++)
ChatHandler sib=(ChatHandler)clients.get(i);
if(DEBUG)
System.out.println("Sending to"+sib);
sib.send(sender,mesg);
if(DEBUG) System.out.println("Done broadcast");
protected ChatHandler lookup(String nick)
synchronized(clients)
for(int i=0;i<clients.size();i++)
ChatHandler cl=(ChatHandler)clients.get(i);
if(cl.login.equals(nick))
return cl;
return null;
//将ChatHandler对象转换成一个字符串
public String toString()
return "ChatHandler["+login+"]";
public class ChatParameter
public static final char CMD_BCAST='b';
public static final char CMD_LOGIN='l';
public static final char CMD_MESG='m';
public static final char CMD_QUIT='q';
public static final char SEPARATOR=':';//?????
public static final int PORTNUM=7777;
public boolean isValidLoginName(String line)
if (line.equals("CHATMASTER_ID"))
return false;
return true;
public void main(String[] argv)
以上代码由于界面限制的原因 可能有点儿乱
把它整个复制出去 重新整理修改一下就行了
参考资料:CSDN社区
以上是关于谁能给个java的小例子,实现swing调用sql的表,并能进行增删改查操作。的主要内容,如果未能解决你的问题,请参考以下文章
谁能给个C语言socket 通信,用UDP协议的代码例子。。
谁能给个简单的JAVA连接MYSQL实现增删改查的实例.谢谢了啊,我的邮箱是ah1363454335@qq.com
java swing如何把获取的文本框值添加到Table表格中,能否给个简单的例子,急用!急用!谢谢
谁能给个SQL中用CREATE TABLE 创建数据库表的建表事例,急
如何用C# .NEt开发基于http的接口,只支持post方式传参,除webservice以外,谁能给个例子,万分感谢!