1. 程式人生 > >c#窗體之登入頁(已連線資料庫)

c#窗體之登入頁(已連線資料庫)

  1. 效果圖:

 

原始碼:

頁面:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Data.SqlClient;


 

namespace login
{
    public partial class Form1 : Form
    {
        
public Form1() { InitializeComponent(); // this.BackgroundImage = Image.FromFile(@"C:\Users\mmmjh\Desktop\login\login\bin\Debug\mm.jpg"); } private void button1_Click(object sender, EventArgs e) { if (!this.textBox3.Text.Equals(validCode.CheckCode))//
驗證是否輸入正確 { MessageBox.Show(" 請輸入正確的驗證碼!", this.Text); this.textBox3.Focus(); this.textBox3.Text = ""; return; } else { //後面拼寫查詢語句要用到窗體的資訊 string user = textBox1.Text;
string pwd = textBox2.Text; //建立資料庫連線類的物件 SqlConnection con = new SqlConnection("server=.;database=user;user=*****;pwd=******"); //將連線開啟 con.Open(); //執行con物件的函式,返回一個SqlCommand型別的物件 SqlCommand cmd = con.CreateCommand(); //把輸入的資料拼接成sql語句,並交給cmd物件 cmd.CommandText = "select*from userinfor where username='" + user + "'and password='" + pwd + "'"; //用cmd的函式執行語句,返回SqlDataReader物件dr,dr就是返回的結果集(也就是資料庫中查詢到的表資料) SqlDataReader dr = cmd.ExecuteReader(); //用dr的read函式,每執行一次,返回一個包含下一行資料的集合dr,在執行read函式之前,dr並不是集合 if (dr.Read()) { //dr[]裡面可以填列名或者索引,顯示獲得的資料 MessageBox.Show(dr[1].ToString() + "登陸成功"); } //用完後關閉連線,以免影響其他程式訪問 con.Close(); } } /*private void button2_Click(object sender, EventArgs e)//按鈕跳轉 { Form2 fm2 = new Form2(); this.Hide(); fm2.ShowDialog(); Application.ExitThread(); }*/ private void textBox1_TextChanged(object sender, EventArgs e) { } private void textBox2_TextChanged(object sender, EventArgs e) { } ValidCode validCode = new ValidCode(5, ValidCode.CodeType.Numbers);//例項化驗證碼這個物件 private void Form1_Load(object sender, EventArgs e){ skinEngine1.SkinFile = Application.StartupPath + @"\MP10.ssk"; pictureBox1.Image = Bitmap.FromStream(validCode.CreateCheckCodeImage());//載入驗證碼圖片 } private void linkLabel1_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)//超連結跳轉 { linkLabel1.LinkVisited = true; Form2 fm2 = new Form2(); this.Hide(); fm2.ShowDialog(); Application.ExitThread(); } private void pictureBox1_Click(object sender, EventArgs e) { pictureBox1.Image = Bitmap.FromStream(validCode.CreateCheckCodeImage());//點選圖片更換驗證碼 } private void textBox3_TextChanged(object sender, EventArgs e) { } private void label3_Click(object sender, EventArgs e) { } } }

驗證碼:(建立一個驗證碼類)

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

using System.IO;
using System.Drawing;
using System.Drawing.Drawing2D;
namespace login
{
    class ValidCode
    {
        #region Private Fields

        private const double PI = 3.1415926535897932384626433832795;

        private const double PI2 = 6.283185307179586476925286766559;

        //private readonly int _wordsLen = 4; 

        private int _len;

        private CodeType _codetype;

        private readonly Single _jianju = (float)18.0;

        private readonly Single _height = (float)24.0;

        private string _checkCode;

        #endregion

        #region Public Property

        public string CheckCode
        {

            get
            {
               return _checkCode;

            }

        }

        #endregion

        #region Constructors

        /// <summary> 

        /// public constructors 

        /// </summary> 

        /// <param name="len"> 驗證碼長度 </param> 

        /// <param name="ctype"> 驗證碼型別:字母、數字、字母+ 數字 </param> 

        public ValidCode(int len, CodeType ctype)
        {

            this._len = 4;

            this._codetype = ctype;

        }

        #endregion

        #region Public Field

        public enum CodeType { Words, Numbers, Characters, Alphas }

        #endregion

        #region Private Methods



        private string GenerateNumbers()
        {

            string strOut = "";

            System.Random random = new Random();

            for (int i = 0; i < _len; i++)
            {

                string num = Convert.ToString(random.Next(10000) % 10);

                strOut += num;

            }

            return strOut.Trim();

        }



        private string GenerateCharacters()
        {

            string strOut = "";

            System.Random random = new Random();

            for (int i = 0; i < _len; i++)
            {

                string num = Convert.ToString((char)(65 + random.Next(10000) % 26));

                strOut += num;

            }

            return strOut.Trim();

        }

        // 

        private string GenerateAlphas()
        {

            string strOut = "";

            string num = "";

            System.Random random = new Random();

            for (int i = 0; i < _len; i++)
            {

                if (random.Next(500) % 2 == 0)
                {

                    num = Convert.ToString(random.Next(10000) % 10);

                }

                else
                {

                    num = Convert.ToString((char)(65 + random.Next(10000) % 26));

                }

                strOut += num;

            }

            return strOut.Trim();

        }



        private System.Drawing.Bitmap TwistImage(Bitmap srcBmp, bool bXDir, double dMultValue, double dPhase)
        {

            System.Drawing.Bitmap destBmp = new Bitmap(srcBmp.Width, srcBmp.Height);



            // 將點陣圖背景填充為白色 

            System.Drawing.Graphics graph = System.Drawing.Graphics.FromImage(destBmp);

            graph.FillRectangle(new SolidBrush(System.Drawing.Color.White), 0, 0, destBmp.Width, destBmp.Height);

            graph.Dispose();



            double dBaseAxisLen = bXDir ? (double)destBmp.Height : (double)destBmp.Width;



            for (int i = 0; i < destBmp.Width; i++)
            {

                for (int j = 0; j < destBmp.Height; j++)
                {

                    double dx = 0;

                    dx = bXDir ? (PI2 * (double)j) / dBaseAxisLen : (PI2 * (double)i) / dBaseAxisLen;

                    dx += dPhase;

                    double dy = Math.Sin(dx);



                    // 取得當前點的顏色 

                    int nOldX = 0, nOldY = 0;

                    nOldX = bXDir ? i + (int)(dy * dMultValue) : i;

                    nOldY = bXDir ? j : j + (int)(dy * dMultValue);



                    System.Drawing.Color color = srcBmp.GetPixel(i, j);

                    if (nOldX >= 0 && nOldX < destBmp.Width

                     && nOldY >= 0 && nOldY < destBmp.Height)
                    {

                        destBmp.SetPixel(nOldX, nOldY, color);

                    }

                }

            }



            return destBmp;

        }

        #endregion

        #region Public Methods

        public Stream CreateCheckCodeImage()
        {

            string checkCode;

            switch (_codetype)
            {

                case CodeType.Alphas:

                    checkCode = GenerateAlphas();

                    break;

                case CodeType.Numbers:

                    checkCode = GenerateNumbers();

                    break;

                case CodeType.Characters:

                    checkCode = GenerateCharacters();

                    break;

                default:

                    checkCode = GenerateAlphas();

                    break;

            }

            this._checkCode = checkCode;

            MemoryStream ms = null;

            // 

            if (checkCode == null || checkCode.Trim() == String.Empty)

                return null;

            Bitmap image = new System.Drawing.Bitmap((int)Math.Ceiling((checkCode.Length * _jianju)), (int)_height);

            Graphics g = Graphics.FromImage(image);

            try
            {

                Random random = new Random();

                g.Clear(Color.White);

                // 畫圖片的背景噪音線 

                for (int i = 0; i < 18; i++)
                {

                    int x1 = random.Next(image.Width);

                    int x2 = random.Next(image.Width);

                    int y1 = random.Next(image.Height);

                    int y2 = random.Next(image.Height);

                    g.DrawLine(new Pen(Color.FromArgb(random.Next()), 1), x1, y1, x2, y2);

                }

                Font font = new System.Drawing.Font("Times New Roman", 14, System.Drawing.FontStyle.Bold);

                LinearGradientBrush brush = new LinearGradientBrush(new Rectangle(0, 0, image.Width, image.Height), Color.Blue, Color.DarkRed, 1.2f, true);

                if (_codetype != CodeType.Words)
                {

                    for (int i = 0; i < checkCode.Length; i++)
                    {

                        g.DrawString(checkCode.Substring(i, 1), font, brush, 2 + i * _jianju, 1);

                    }

                }
                else
                {

                    g.DrawString(checkCode, font, brush, 2, 2);

                }

                // 畫圖片的前景噪音點 

                for (int i = 0; i < 150; i++)
                {

                    int x = random.Next(image.Width);

                    int y = random.Next(image.Height);

                    image.SetPixel(x, y, Color.FromArgb(random.Next()));

                }

                // 畫圖片的波形濾鏡效果 

                if (_codetype != CodeType.Words)
                {

                    image = TwistImage(image, true, 3, 1);

                }

                // 畫圖片的邊框線 

                g.DrawRectangle(new Pen(Color.Silver), 0, 0, image.Width - 1, image.Height - 1);



                ms = new System.IO.MemoryStream();

                image.Save(ms, System.Drawing.Imaging.ImageFormat.Gif);

            }

            finally
            {

                g.Dispose();

                image.Dispose();

            }

            return ms;

        }

        #endregion

    }
}