学生问题总结

http://msdn.microsoft.com/library/chs/default.asp

1.CommandName 属性 (Common)返回引发事件的命令的名称。
2.CommandArgument 属性设置或返回与 ItemCommand 事件中的命令关联的参数。默认值为空字符串 ("")。
3.Eval 函数用于定义单向(只读)绑定。Bind 函数用于定义双向(可更新)绑定。Eval与Bind函数是Asp.net2.0是函数,在Asp.net1.1是

DataBinder.Eval())  http://msdn2.microsoft.com/zh-cn/library/ms178366.aspx
4.App_Data 文件夹 为了提高 ASP.NET 应用程序使用的数据的安全性,特为 ASP.NET 应用程序新增了名为 App_Data 的子文件夹。存储在

App_Data 文件夹中的文件不会对直接 HTTP 请求作出响应,它推荐将应用程序的数据存储在 App_Data 文件夹中,包括 .mdf (SQL Server

Express Edition)、.mdb (Microsoft Access) 或 XML 文件。请注意,使用 App_Data 文件夹存储应用程序数据时,应用程序的标识必须具

有对 App_Data 文件夹的读写权限。
5.GridView中批量删除事件
protected void delete_Click(object sender, EventArgs e)
    {
        int i;
     
        for (i = 0; i < this.GridView1.Rows.Count; i++)
        {

            if (((CheckBox)this.GridView1.Rows[i].Cells[4].FindControl("CheckBox1")).Checked == true)
            {
                string conn = System.Configuration.ConfigurationManager.ConnectionStrings["cityConnectionString2"].ToString

();

                SqlConnection con = new SqlConnection(conn);
                con.Open();

                DataSet ds = new DataSet();
                string sql = "delete from cityy where cityId=" + this.GridView1.Rows[i].Cells[0].Text.ToString();
                SqlDataAdapter da = new SqlDataAdapter();
                da.SelectCommand = new SqlCommand(sql, con);
                da.Fill(ds, "b");              
            }
        }
        BindData();
    }

5.asp.net 备份和恢复SQL SERVER 数据库   恢复数据库:
  关键字:Alter Database 被恢复的数据库名 Set Offline with Rollback immediate;
            restore database 被恢复的数据库名 from disk = '备份文件路径';
            Alter Database 被恢复的数据库名 Set OnLine With rollback Immediate;

/
    string sql = "Alter Database db Set Offline with Rollback immediate;"; //db 是要备份的数据库名
    sql +=  "restore database db from disk = '" ;
    sql += Server.MapPath("").ToString() +"//";
    sql += bakname + "'";  //bakname 是备份文件名
    sql += "Alter Database db Set OnLine With rollback Immediate;";
    try
    {
     连接 master 数据库 ;
     执行 sql  语句;
     Response.Write("<script language=javascript>alert('数据恢复成功!');</script>");
    }
    catch(Exception ex)
    {
     Response.Write("<script language=javascript>alert('数据恢复失败!');</script>");
     this.Label2.Text = ex.ToString();
    }

备份数据库:

关键字:backup database 被备份的数据库名 to disk ='备份文件路径';
//    
 string sql = "backup database db to disk = '" + Server.MapPath("").ToString() +"//"
    + bakname  //备份文件名
    + System.DateTime.Now.DayOfYear.ToString()
    + System.DateTime.Now.Millisecond.ToString() + ".bak'";
  try

  连接 被备份的数据库 ;
  执行 sql  语句;

   Response.Write("<script language=javascript>alert('备份成功!');location='restore.aspx'</script>");
}
    catch(Exception ex)
    {
     Response.Write("<script language=javascript>alert('备份失败!');</script>");
     this.Label2.Text = ex.ToString();
    }
 
6.javacript 验证函数
在ASP,ASP.NET里输入验证要用到一些常用的验证,比如姓名,E-MAIL,电话号码等,我把常用的记录下来,免得查起来不方便。

//校验是否全由数字组成
function isDigit(s)
{
var patrn=/^[0-9]{1,20}$/;
if (!patrn.exec(s)) return false
return true
}
//校验登录名:只能输入5-20个以字母开头、可带数字、“_”、“.”的字串
function isRegisterUserName(s)
{
var patrn=/^[a-zA-Z]{1}([a-zA-Z0-9]|[._]){4,19}$/;
if (!patrn.exec(s)) return false
return true
}

//校验密码:只能输入6-20个字母、数字、下划线
function isPasswd(s)
{
var patrn=/^(/w){6,20}$/;
if (!patrn.exec(s)) return false
return true
}

//校验手机号码:必须以数字开头,除数字外,可含有“-”
function isMobil(s)
{
var patrn=/^([0-9]{11,13})?$/;
if (!patrn.exec(s)) return false
return true
}

function isEmail(src) {
    return (isEmail1.test(src) && isEmail2.test(src));
  }

  isEmail1    = /^/w+([/./-]/w+)*/@/w+([/./-]/w+)*/./w+$/;
  isEmail2    = /^.*@[^_]*$/;

function onlychinese()
{
 if ((window.event.keyCode >=32) && (window.event.keyCode <= 126))
 {
  window.event.keyCode = 0 ;
 }
}

网上好多验证只能输入汉字的函数,我试了一些,觉得这个很好用,在文本框里不是汉字的就不能输入上去,如果只是验证姓名的话,还得限

定字数,过滤掉特殊字符。
EG:
asp 中的用法:
<input name="UserNameCN" type="text" onKeyPress="onlychinese();">
 
今天有看到验证中文的
1、判断字符串是否为连续的中文字符(不包含英文及其他任何符号和数字):
Regex.IsMatch("中文","^[/u4e00-/u9fa5]+$");
2、判断字符串是否为中文字符串(仅不包含英文但可以包含其他符号及数字):
!Regex.IsMatch("中文",@"[a-zA-Z]");
这个很常见的。


7.Asp.net(C#)实现验证码功能
 
新建一个专门用来创建验证码图片的页面ValidateCode.aspx
它的后台cs文件代码如下:
PageLoad

private void Page_Load(object sender, System.EventArgs e)
        {
            string checkCode = CreateRandomCode(4);
            Session["CheckCode"] = checkCode;
            CreateImage(checkCode);
        }
其中CreateRandomCode是自定义的函数,参数代表验证码位数

private string CreateRandomCode(int codeCount)
        {
            string allChar = "0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,W,X,Y,Z" ;
            string[] allCharArray = allChar.Split(',');
            string randomCode = "";
            int temp = -1;

            Random rand = new Random();
            for(int i = 0; i < codeCount; i++)
            {
                if(temp != -1)
                {
                    rand = new Random(i*temp*((int)DateTime.Now.Ticks));
                }
                int t = rand.Next(35);
                if(temp == t)
                {
                    return CreateRandomCode(codeCount);
                }
                temp = t;
                randomCode += allCharArray[t];
            }
            return randomCode;
        }
CreateImage也是一个自定义的函数,用于生成图

private void CreateImage(string checkCode)
        {
            int iwidth = (int)(checkCode.Length * 11.5);
            System.Drawing.Bitmap image = new System.Drawing.Bitmap(iwidth, 20);
            Graphics g = Graphics.FromImage(image);
            Font f = new System.Drawing.Font("Arial", 10, System.Drawing.FontStyle.Bold);
            Brush b = new System.Drawing.SolidBrush(Color.White);
            //g.FillRectangle(new System.Drawing.SolidBrush(Color.Blue),0,0,image.Width, image.Height);
            g.Clear(Color.Blue);
            g.DrawString(checkCode, f, b, 3, 3);

            Pen blackPen = new Pen(Color.Black, 0);
            Random rand = new Random();
            for (int i=0;i<5;i++)
            {
                int y = rand.Next(image.Height);
                g.DrawLine(blackPen,0,y,image.Width,y);
            }
           
            System.IO.MemoryStream ms = new System.IO.MemoryStream();
            image.Save(ms,System.Drawing.Imaging.ImageFormat.Jpeg);
            Response.ClearContent();
            Response.ContentType = "image/Jpeg";
            Response.BinaryWrite(ms.ToArray());
            g.Dispose();
            image.Dispose();
        }
//g.FillRectangle(new System.Drawing.SolidBrush(Color.Blue),0,0,image.Width, image.Height);
g.Clear(Color.Blue);
这两种方法都可以改变生成图片的背景颜色
下面那个for循环用来生成一些随机的水平线

在需要用到验证码的页面添加一个<asp:Image>控件即可,但是要把ImageUrl指向生成验证码的页面

<asp:Image Runat="server" ID="ImageCheck" ImageUrl="ValidateCode.aspx"></asp:Image>

 

8.简单的生成登录验证码的程序Function.cs

/** <summary>
        /// 生成随机数
        /// </summary>
        /// <param name="codeCount">要生成的随机数位数</param>
        /// <returns></returns>
        public static string CreateRandomCode(int codeCount)
        {
            string allChar = "0,1,2,3,4,5,6,7,8,9";
            string[] allCharArray = allChar.Split(',');
            string randomCode = "";
            int temp = -1;

            Random rand = new Random();
            for(int i = 0; i < codeCount; i++)
            {
                if(temp != -1)
                {
                    rand = new Random(i*temp*((int)DateTime.Now.Ticks));
                }
                int t = rand.Next(9);
                if(temp == t)
                {
                    return CreateRandomCode(codeCount);
                }
                temp = t;
                randomCode += allCharArray[t];
            }
            return randomCode;
        }
        /** <summary>
        /// 生成验证码图片
        /// </summary>
        /// <param name="checkCode"></param>
        public static void CreateImage(string checkCode)
        {
            int iwidth = (int)(checkCode.Length * 11.5);
            System.Drawing.Bitmap image = new System.Drawing.Bitmap(iwidth, 20);
            Graphics g = Graphics.FromImage(image);
            Font f = new System.Drawing.Font("Arial", 10, System.Drawing.FontStyle.Bold);
            Brush b = new System.Drawing.SolidBrush(Color.White);
            //g.FillRectangle(new System.Drawing.SolidBrush(Color.Blue),0,0,image.Width, image.Height);
            g.Clear(Color.Blue);
            g.DrawString(checkCode, f, b, 3, 3);

            Pen blackPen = new Pen(Color.Brown,0);
            Random rand = new Random();
            for (int i=0;i<5;i++)
            {
                int y = rand.Next(image.Height);

                //g.DrawLine(blackPen,0,y,image.Width,y);
            }
           
            System.IO.MemoryStream ms = new System.IO.MemoryStream();
            for(int i=0; i<90; i++)
            {
                int x = rand.Next(image.Width);
                int y = rand.Next(image.Height);
                image.SetPixel(x, y, Color.FromArgb(rand.Next()));
            }
            image.Save(ms,System.Drawing.Imaging.ImageFormat.Jpeg);
            System.Web.HttpContext.Current.Response.ClearContent();
            System.Web.HttpContext.Current.Response.ContentType = "image/Jpeg";
            System.Web.HttpContext.Current.Response.BinaryWrite(ms.ToArray());
            g.Dispose();
            image.Dispose();
        }
ValidateCode.aspx.cs
private void Page_Load(object sender, System.EventArgs e)
        {
            // 在此处放置用户代码以初始化页面
            string checkCode = LemongTree.BLL.Function.CreateRandomCode(4);
            Session["CheckCode"] = checkCode;
            LemongTree.BLL.Function.CreateImage(checkCode);
        }
.aspx文件的调用
<asp:image id="Image1" runat="server" ImageUrl="validatecode.aspx" />

 9 .同时验证手机号码与座机号码(含区号 ,7位的也能验证)的正则表达式 

(^[0-9]{3,4}/-[0-9]{3,8}/-[0-9]{1,4}$)|(^[0-9]{3,4}/-[0-9]{3,8}$)|(^[0-9]{3,8}$)|(^/([0-9]{3,4}/)[0-9]{3,8}$)|(^0{0,1}13[0-9]{9}$)

联系电话输入要求:
                                        (1)电话号码由数字、'('、')'和'-'构成
                                        (2)电话号码为3到8位
                                        (3)如果电话号码中包含有区号,那么区号为三位或四位
                                        (4)区号用'('、')'或'-'和其他部分隔开
                                        (5)移动电话号码为11或12位,如果为12位,那么第一位为0
                                        (6)11位移动电话号码的第一位和第二位为'13'
                                        (7)12位移动电话号码的第二位和第三位为'13'
 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值