QQ基本代码

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Data.SqlClient;
using MyQQ;
namespace qq
{
    public partial class LoginFrm : Form
    {
        public LoginFrm()
        {
            InitializeComponent();
        }
        //窗体加载时
        private void LoginFrm_Load(object sender, EventArgs e)
        {
            this.picFace.Image = this.imageFace.Images[0];
        }
        //文本框改变时发生的窗体
        private void txtNum_TextChanged(object sender, EventArgs e)
        {
            if (this.txtNum.Text.Trim().Length == 5)
            {
                this.txtPwd.Focus();
                string sql = string.Format("select FaceId from Users where Id = {0}", this.txtNum.Text);
                SqlCommand cmd = new SqlCommand(sql, DbHelper.conn);
                try
                {
                    DbHelper.opendb();
                    this.picFace.Image = this.imageFace.Images[Convert.ToInt32(cmd.ExecuteScalar())];
                }
                catch (Exception ex)
                {
                    MessageBox.Show(ex.ToString());
                }
                finally
                {
                    DbHelper.closedb();
                }
            }
            else
            {
                this.picFace.Image = this.imageFace.Images[0];
            }
        }
        //判断QQ号密码是否填写
        public bool ValidateInput()
        {
            if (this.txtNum.Text == "")
            {
                MessageBox.Show("QQ号码必填!","登录提示",MessageBoxButtons.OK,MessageBoxIcon.Asterisk);
                this.txtNum.Focus();
                return false;
            }
            if (this.txtPwd.Text == "")
            {
                MessageBox.Show("密码必填!", "登录提示", MessageBoxButtons.OK, MessageBoxIcon.Asterisk);
                this.txtPwd.Focus();
                return false;
            }
            return true;
        }
        //判断登录状态
        public int GetLoginState()
        {
            int loginState = 0;
            string sql = "";
            SqlCommand cmd = new SqlCommand();
            SqlDataReader reader = null;
            try
            {
                DbHelper.opendb();
                sql = string.Format("select loginState from users where id = {0}", this.txtNum.Text);
                cmd.CommandText = sql;
                cmd.Connection = DbHelper.conn;
                reader = cmd.ExecuteReader();
                if (reader.Read())
                {
                    loginState = Convert.ToInt32(reader[0]);
                }
                reader.Close();
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.ToString());
            }
            finally
            {
                DbHelper.closedb();
            }
            return loginState;
        }
        //点击登录按钮到主窗体上
        private void btnLogin_Click(object sender, EventArgs e)
        {
            if (ValidateInput())
            {
                string sql = string.Format("select COUNT(*) from users where Id = {0} and LoginPwd = '{1}'", this.txtNum.Text, this.txtPwd.Text);
                SqlCommand cmd = new SqlCommand(sql, DbHelper.conn);
                try
                {
                    if (GetLoginState() == 0)
                    {
                        DbHelper.opendb();
                        if (Convert.ToInt32(cmd.ExecuteScalar()) == 1)
                        {
                            //保存登录者QQ   
                            LoginHelper.fromQQ = Convert.ToInt32(this.txtNum.Text);
                            sql = string.Format("update users set loginState=1 where id = {0}", txtNum.Text);
                            cmd.CommandText = sql;
                            cmd.Connection = DbHelper.conn;
                            cmd.ExecuteNonQuery();
                            MainFrm ma = new MainFrm();
                            ma.Show();
                            this.Hide();
                        }
                        else
                        {
                            MessageBox.Show("账户或者密码错误!", "登录提示", MessageBoxButtons.OK, MessageBoxIcon.Asterisk);
                            this.txtNum.Text = "";
                            this.txtPwd.Text = "";
                            this.txtNum.Focus();
                        }
                    }
                    else
                    {
                        MessageBox.Show("账号已在此电脑登陆", "登录提示", MessageBoxButtons.OK, MessageBoxIcon.Asterisk);
                        this.txtNum.Text = "";
                        this.txtPwd.Text = "";
                        this.txtNum.Focus();
                        return;
                    }
                }
                catch (Exception ex)
                {
                    MessageBox.Show(ex.ToString());
                }
                finally
                {
                    DbHelper.closedb();
                }
            }
        }
        //只能输入数字
        private void btnCancel_Click(object sender, EventArgs e)
        {
            Application.Exit();
        }
        private void txtNum_KeyPress(object sender, KeyPressEventArgs e)
        {
            if (Convert.ToInt32(e.KeyChar) < 48 || Convert.ToInt32(e.KeyChar) > 57)
            {
                e.Handled = true;
            }
            if (Convert.ToInt32(e.KeyChar) == 8)
            {
                e.Handled = false;
            }
        }
        //防止注释攻击
        private void txtPwd_KeyPress(object sender, KeyPressEventArgs e)
            {
                if (Convert.ToInt32(e.KeyChar) == 39)
                {
                    e.Handled = true;
                }
                if (Convert.ToInt32(e.KeyChar) == 45)
                {
                    e.Handled = true;
                }
            }
        //到注册窗体
         private void linkwangjimima_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
         {
             RegisterFrm f2 = new RegisterFrm();
             f2.ShowDialog();
         }
        //退出程序
         private void LoginFrm_FormClosed(object sender, FormClosedEventArgs e)
         {
             Application.Exit();
         }
        //到忘记密码窗体
         private void linkLabel1_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
         {
             ResetPwdFrm wj = new ResetPwdFrm();
             wj.ShowDialog();
         }
    }
}

你可能感兴趣的:(QQ基本代码)