/*一个山寨版本的QQ,然后凭着我们上课老师讲的一个实例,和自己的修改写的。
* 1422942883这是我的QQ,欢迎各位学习编程的同学加我好友,
* 或者给我的个人主页留言(http:jayxigua.iteye.com)
* ,一起讨论,学习。呵呵。
*
主要的知识点是:一,GUI,操作,完成一个类似于QQ登录界面的小窗口。
TextField Choice Checkbox Button Panel bottom事件 Dialog diag
二,就是JDBC 的小运用:输入姓名和密码,进入数据库进行判断?
然后返回不同的对话框。
(我数据库里面的一个学生是:“kb”“24”)
数据库的sql语句,导入到mysql就OK了!
create database ascent_jdbc;
use ascent_jdbc;
create table student
(sid varchar(10) not null,
sname varchar(50),
spassword varchar(20),
primary key(sid)
);
insert into student values('1','kb','24');
insert into student values('2','kg','5');
*/
import java.awt.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
import java.sql.*;
public class Ascent20100621_dbdc_myqq extends Frame {
private Label name, pawd, regist, getPawd, st;
private TextField username, password;
private Choice status;
private Checkbox rem, auto;
private Button setup, login;
private Panel top, center, bottom;
private Dialog diag;
public Ascent20100621_dbdc_myqq(String title) {
super(title);
this.name = new Label("账号:", Label.CENTER);
this.pawd = new Label("密码:", Label.CENTER);
this.regist = new Label("注册新账号", Label.LEFT);
this.getPawd = new Label("取回密码", Label.LEFT);
this.st = new Label("状态:");
this.username = new TextField("<请输入账号>", 40);
this.password = new TextField(40);
this.password.setEchoChar('*');
this.top = new Panel(new GridLayout(2, 3, 5, 10));
this.top.add(this.name);
this.top.add(this.username);
this.top.add(this.regist);
this.top.add(this.pawd);
this.top.add(this.password);
this.top.add(this.getPawd);
this.st = new Label("状态:");
this.status = new Choice();
this.status.add("我在线上");
this.status.add("忙碌");
this.status.add("离开");
this.rem = new Checkbox("记住密码", false);
this.auto = new Checkbox("自动登陆", false);
this.center = new Panel();
this.center.add(this.st);
this.center.add(this.status);
this.center.add(this.rem);
this.center.add(this.auto);
this.bottom = new Panel(new FlowLayout(FlowLayout.CENTER, 100, 5));
this.setup = new Button("设置");
this.login = new Button("登陆");
MyListener ml = new MyListener();
this.login.addActionListener(ml);
this.setup.addActionListener(ml);
this.bottom.add(this.setup);
this.bottom.add(this.login);
this.add(this.top, BorderLayout.NORTH);
this.add(this.center);
this.add(this.bottom, BorderLayout.SOUTH);
this.addWindowListener(new WindowAdapter() {
public void windowClosing(WindowEvent e) {
setVisible(false);
dispose();
System.exit(0);
}
});
this.setBounds(200, 200, 350, 180);
this.setResizable(false);
this.setVisible(true);
}
class MyListener implements ActionListener {
public void actionPerformed(ActionEvent e) {
if (e.getSource() == login) {
String name = username.getText();
String pass = password.getText();
if (isValidUser(name, pass)) {
diag = new Dialog(Ascent20100621_dbdc_myqq.this, "正确",
false);
} else {
diag = new Dialog(Ascent20100621_dbdc_myqq.this, "错误",
false);
}
diag.addWindowListener(new WindowAdapter() {
public void windowClosing(WindowEvent e) {
diag.setVisible(false);
diag.dispose();
}
});
diag.setBounds(300, 300, 200, 150);
diag.add(new Label("真的要退出吗?", Label.CENTER));
diag.setVisible(true);
} else if (e.getSource() == setup) {
diag = new Dialog(Ascent20100621_dbdc_myqq.this, "设置页面", false);
diag.setBounds(300, 300, 200, 500);
diag.add(new Label("进行设置", Label.CENTER));
diag.setVisible(true);
}
}
}
public Connection getConnection() {
String url = "jdbc:mysql://localhost:3306/ascent_jdbc?useUnicode=true&characterEncoding=gbk";
String user = "root";
String DbPassword = "root";
try {
Class.forName("com.mysql.jdbc.Driver");
} catch (ClassNotFoundException e) {
System.out.println("mysql未驱动");
e.printStackTrace();
}
Connection conn = null;
try {
Class.forName("com.mysql.jdbc.Driver");
conn = DriverManager.getConnection(url, user, DbPassword);
} catch (SQLException e) {
System.out.println("SQL 异常");
e.printStackTrace();
} catch (ClassNotFoundException e) {
System.out.println("数据库没有找到");
e.printStackTrace();
}
return conn;
}
// 判断密码是否正确!
boolean isValidUser(String name, String pass) {
Connection conn = this.getConnection();
Statement comm = null;
ResultSet rs;
boolean flag = false;
try {
String sql2 = "select * from student where sname = '" + name
+ "' and spassword = '" + pass + "'";
comm = conn.createStatement();
rs = comm.executeQuery(sql2);
if (rs.next() == false) {
System.out.print("用户名,密码错误!");
flag = false;
} else {
System.out.print("用户名,密码正确!");
flag = true;
}
} catch (SQLException e) {
System.out.println("异常!");
}
System.out.print(flag);
return flag;
}
void getSystemDBMD() {
Connection conn = this.getConnection();
try {
DatabaseMetaData dmd = conn.getMetaData();
System.out.println(dmd.getDatabaseProductName());
System.out.println(dmd.getDatabaseProductVersion());
System.out.println(dmd.getDatabaseMajorVersion());
System.out.println(dmd.getDatabaseMinorVersion());
System.out.println(dmd.getJDBCMajorVersion());
System.out.println(dmd.getJDBCMinorVersion());
} catch (SQLException e) {
e.printStackTrace();
}
}
void getfieldDBMD() {
Connection conn = this.getConnection();
Statement comm = null;
try {
comm = conn.createStatement();
} catch (SQLException e1) {
e1.printStackTrace();
}
String sql = "select* from student";
ResultSet rs;
try {
rs = comm.executeQuery(sql);
DatabaseMetaData dmd = conn.getMetaData();
// System.out.println(dmd.getJDBCMinorVersion());
} catch (SQLException e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
Ascent20100621_dbdc_myqq myqq = new Ascent20100621_dbdc_myqq("QQ山寨版");
myqq.getSystemDBMD();
// 测试,一个正确,一个错误!
myqq.isValidUser("kb", "24");
myqq.isValidUser("kb", "224");
}
}
分享到:
相关推荐
而"类似于QQ的小工具 -java"可能是项目源代码的打包文件,包含了所有实现上述功能的Java类和资源文件。 综上,这个项目涵盖了Java基础、网络编程、多线程、GUI设计等多个领域的知识,对于学习Java编程和理解即时...
【标题】"仿OICQ界面源代码"指的是一个编程项目,其目标是创建一个类似于腾讯QQ(OICQ)的用户界面。OICQ是中国最早的即时通讯软件之一,其简洁明了的设计风格和易用性深受用户喜爱。开发者通过这个项目可以学习到...
这个压缩包文件“[其他类别]QQ闪字程序_ztxiu毕业设计—(包含完整源码,可运行).rar”显然包含了某位名为ztxiu的学生的毕业设计项目,该项目专注于开发一个能够实现QQ闪字效果的应用程序。源码的提供意味着我们可以...
基于51单片机protues仿真的多功能万用表设计(仿真图、源代码、AD原理图、流程图) 数字多用表既可以测量电压,也可以测量电流、电阻,功能齐全,使用便捷。 本选题采用8位8路A/D转换器ADC0808和8051单片机设计一台数字多用表,能进行电压、电流和电阻的测量,测量结果通过LED数码管显示,通过安检进行测量功能转换。电压测量范围0~5V,测量误差约为±0.02V,电流测量范围为1~100mA,测量误差约为±0.5mA,电阻测量范围0~1000Ω,测量误差约为±2Ω。 1、通过按键设置测量模式; 2、电压采用直接测量方式;电流使用差压放大测量;电阻使用恒流源把阻值转换成电压。 预计难易程度:难度适中预计工作量大小:8周 1.熟练掌握单片机设计基本原理;熟悉8051单片机的工作原理; 2.熟练掌握Proteus软件的使用方法; 3.利用Proteus软件仿真实现数字多用表的测量功能。
内容概要:本文详细探讨了综合能源系统(IES)中引入阶梯式碳交易和供需灵活响应机制后的优化调度方法。首先介绍了碳排放计算的分段线性化处理,通过Python代码实现了燃气机组的碳排放曲线计算。接着讨论了电、热、气负荷之间的替代关系及其在不同场景下的应用,展示了如何利用替代矩阵进行负荷调整。此外,文章还介绍了有机朗肯循环(ORC)技术的应用,使热电联产机组能够灵活调整出力。最后,通过混合整数线性规划(MILP)构建了优化模型,并采用CPLEX求解器进行了求解,展示了如何通过分解时间段和预处理变量来提升求解效率。实验结果显示,该模型能使某园区的碳排量降低18%,运行成本节省12%。 适合人群:从事综合能源系统研究和开发的技术人员,以及对碳交易和能源优化感兴趣的学者和工程师。 使用场景及目标:适用于需要优化能源调度、降低成本并减少碳排放的工业和商业园区。目标是通过合理的碳交易机制和灵活的供需响应,实现经济效益和环境效益的最大化。 其他说明:文中提供了详细的代码片段,帮助读者理解和实现具体的优化算法。同时强调了在实际应用中需要注意的历史数据分析和设备物理限制等问题。
内容概要:本文主要探讨了在Delphi环境下使用IdHTTPServer时遇到的TIdHTTP请求报错HTTP1.1 0 Unknown Response Code的问题及其解决方案。错误的根本原因在于未指定返回状态码,解决方法是在IdHTTPServer1CommandGet事件处理程序中明确设置AResponseInfo.ResponseNo为200(或其他适当的HTTP状态码),并设置AResponseInfo.ResponseText。文中还提供了HTTP服务器端和客户端的具体代码实例,包括GET和POST请求的处理逻辑,以及如何正确配置字符集、内容类型和响应内容。此外,文章最后列出了常见的HTTP状态码及其在Delphi中使用IdHTTP控件时的处理方式,帮助开发者更好地理解和解决类似问题。; 适合人群:具有一定Delphi编程经验,特别是对网络通信和HTTP协议有一定了解的开发人员。; 使用场景及目标:①解决Delphi中IdHTTPServer组件使用过程中出现的HTTP1.1 0 Unknown Response Code错误;②掌握正确的HTTP状态码设置方法;③学习如何构建简单的HTTP服务器和客户端进行数据交互。; 阅读建议:重点理解IdHTTPServer的事件处理机制,特别是如何正确设置响应状态码和响应文本,同时参考提供的代码示例进行实际操作和调试。
内容概要:本文详细介绍了利用滑膜控制和模糊推理系统实现后轮主动转向系统(ARS)与直接横摆力矩控制(DYC)的协同控制方法。通过多段代码实例展示了如何在不同路面条件下(如冰面与柏油路交界),通过上层模糊控制决策、滑膜控制快速响应以及下层精确的力矩分配,使车辆保持稳定的行驶状态。具体措施包括采用三层模糊推理系统进行实时姿态参数处理,使用滑膜控制实现非线性切换,以及构建三维查找表进行力矩分配。 适合人群:从事汽车工程、自动控制领域的研究人员和技术人员,尤其是关注车辆稳定性控制系统的专业人士。 使用场景及目标:适用于研究和开发能够应对复杂道路环境的高级驾驶辅助系统(ADAS)。主要目标是在极端天气或特殊路况下提高车辆的安全性和操控性能。 其他说明:文中提到的技术不仅限于理论探讨,还包括大量实车测试数据支持,证明了所提出的方法能够在实际应用中有效降低横摆角速度误差并抑制钟摆效应。此外,作者展望了未来结合轨迹跟踪和强化学习进一步优化控制策略的可能性。
1、文件说明: Centos8操作系统tesseract-langpack-ara-4.0.0-6.el8.rpm以及相关依赖,全打包为一个tar.gz压缩包 2、安装指令: #Step1、解压 tar -zxvf tesseract-langpack-ara-4.0.0-6.el8.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm
员工离职通知单-模板.doc
内容概要:本文详细介绍了如何利用Pandat工具进行镍基合金(Ni-Cr-Al系)的高通量计算,以确定液相线、固相线以及相含量的变化。通过编写Python脚本,实现了成分空间的大规模自动扫描,解决了传统手动计算耗时费力的问题。文中不仅提供了完整的代码示例,还涵盖了数据预处理、错误排查、结果验证等多个方面,并展示了如何使用Matplotlib、Seaborn等工具进行数据可视化的技巧。此外,作者强调了选择正确热力学数据库的重要性,并分享了一些实用的经验和优化建议。 适合人群:从事材料科学尤其是合金研究的专业人士,熟悉Python编程语言的研究人员。 使用场景及目标:适用于需要快速探索大量合金成分组合及其物性变化的研究项目,旨在提高科研效率,减少重复劳动,为后续实验提供理论依据和技术支持。 其他说明:文章中提到的技术手段可以推广应用于其他类型的合金系统或其他物理化学性质的高通量计算。
内容概要:本文详细介绍了对国际知名大厂的三个逆向ADC电路(SAR ADC、Sigma-Delta ADC和Pipeline ADC)进行深入剖析。作者通过Cadence Virtuoso平台研究了这些电路的标准单元库设计,探讨了各个电路的关键技术和实现细节。对于24bit Sigma-Delta ADC,重点讨论了其调制器部分的时钟相位分配和噪声整形技术;对于16bit SAR ADC,则关注其比较器阵列的独特设计以及动态锁存比较器的应用;而对于14bit Pipeline ADC,着重分析了其级间放大器设计和电荷共享技术。此外,文中还提到了在将这些设计适配到自家工艺过程中遇到的问题及其解决方案,如电容寄生效应、时序约束调整、运放结构优化等。 适合人群:从事模拟集成电路设计的专业人士,尤其是对ADC设计感兴趣的工程师和技术研究人员。 使用场景及目标:帮助读者深入了解高精度ADC的工作原理和设计技巧,掌握逆向工程技术在实际项目中的应用,提高对不同工艺节点下ADC设计的理解和适应能力。 其他说明:文中提供了大量具体的代码片段和仿真命令,便于读者理解和实践。同时,作者分享了许多宝贵的经验教训,强调了在逆向工程中需要注意的技术细节和潜在风险。
内容概要:本文详细介绍了基于PWM整流器的3.3kW新能源汽车车载充电机仿真模型的设计与实现。前级采用双闭环PFC控制,确保直流母线电压稳定并使网侧电流呈正弦波形,后级则使用移相全桥开环控制来调节输出电压。文中探讨了电压环和电流环的PI参数整定方法,以及如何通过坐标变换提高电流跟踪精度。此外,还讨论了仿真过程中遇到的问题及其解决方案,如不同仿真软件之间的步长同步问题和滤波器的应用。最终,仿真结果显示整机效率可达92%-94.7%。 适合人群:从事新能源汽车充电技术研发的工程师和技术爱好者。 使用场景及目标:适用于需要深入了解车载充电机电能转换机制的研究人员,旨在优化充电机性能,提升电能转换效率。 其他说明:文中提供了具体的MATLAB和PLECS代码片段,帮助读者更好地理解和复现实验结果。同时强调了仿真过程中需要注意的关键技术和常见陷阱。
1、文件说明: Centos8操作系统tdb-tools-1.4.3-1.el8.rpm以及相关依赖,全打包为一个tar.gz压缩包 2、安装指令: #Step1、解压 tar -zxvf tdb-tools-1.4.3-1.el8.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm
内容概要:本文探讨了风光水火储多能系统的分层优化调度策略,旨在提高系统灵活性和经济效益。文章详细介绍了上层优化(主要针对储能系统)和下层优化(主要针对火电机组)的具体实现方法及其相互协作机制。上层优化通过最小化净负荷波动并考虑储能收益,确保电网稳定性;下层优化则关注火电机组的成本最小化以及应对可再生能源的不确定性。文中还讨论了交替方向乘子法(ADMM)用于协调上下层优化的过程,并展示了基于改进IEEE30节点系统的实验结果。 适合人群:从事电力系统优化、智能电网研究的专业人士和技术爱好者。 使用场景及目标:适用于希望深入了解多能系统优化调度策略的研究人员,尤其是那些致力于提高电力系统灵活性和经济效益的人群。目标是掌握如何利用数学模型和算法解决实际工程问题。 其他说明:文章强调了在构建优化模型时不仅要考虑理论上的最优解,还要兼顾设备的实际物理特性。此外,作者提醒读者在设置模型参数时应注意避免不合理配置导致设备损坏等问题。
电子硬件课程设计项目资源
线性代数
按需激励――荣誉点激励法
Delphi 12.3控件之DBTreed7.rar
标注工作日,非工作日,调休,可以直接使用