HttpHandler—APS.NET最后一课

2008.09.30 / 标签: / 分类: ASP.NET

应该算是ACCP5.0 ASP.NET中的有技术含量的最后一课了吧,为什么要说是ACCP5.0 ASP.NET中的有技术含量的最后一课,因为知识无尽头嘛!嘿嘿~
打开VS2005新建一个Web站点,然后在“添加新项”中选择“一般处理程序”接着点击“添加”。HttpHandler程序是以ashx为后缀名的,新创建的HttpHandler的默认内容为:

 
  1. <%@ WebHandler Language="C#" Class="Handler" %>//WebHandler指令,标记该处理程序的语言和类名称
  2.  
  3. using System;
  4. using System.Web;
  5.  
  6. public class Handler : IHttpHandler {//继承自IHttpHandler接口
  7.     
  8.     public void ProcessRequest (HttpContext context) {//最终处理方法
  9.         context.Response.ContentType = "text/plain";
  10.         context.Response.Write("Hello World");
  11.     }
  12.  
  13.     public bool IsReusable {//是否用于其他的IHttpHandler的实例
  14.         get {
  15.             return false;
  16.         }
  17.     }
  18.  
  19. }

 这段代码说明了context对象可以用来控制输出的内容和类型。
ContentType用于设置程序的输出类型,这段代码可以在页面上出处一段文本“Hello World”(不禁悄悄问一句:为啥无论什么程序语言,写的第一个小程序都是输出Hello World?)且次ashx文件是可以直接访问的。
注意:
实现HttpHandler得功能就必须实现IHttpHandler接口,而且,任何实现了该接口的类都可以用于处理输入的HTTP请求。
从上面的代码我们可以看到,实现该接口需要实现IsReusable属性和ProcessRequest方法。
IsReusable可以用来设置是否可以重用此实例。
ProcessRequest方法是整个HTTP请求最终的处理方法。如下图所示:

这个方法需要一个HttpContext类型的参数,即“http上下文”。它封装了有关一些HTTP请求的所有HTTP特定的信息。在这里,它被用在不同的HttpModule和HttpHandler之间进行数据传递,也可以用于保持某一个完整的请求的相应的一些信息。

6步学会ASP.NET自定义验证码+水印控件

2008.09.28 / 标签: / 分类: ASP.NET

验证码大家应该经常看到吧,比如你在给网站留言,或者注册时就经常可以看到验证码的身影,验证码是很有必要的,因为现在灌水机,信息群发等严重扰乱正常的网站信息管理。
水印应该也都见过吧?它就好比一个我们日常生活中的印章印下的章子。它能够很好的保护发布人的著作权,防止他人盗用。这两个东西如此有用,你想不想知道如何自己动手做呢?想知道就继续看下去吧。
注:需要懂得ASP.NET技术。
1.首先使用VS2005新建一个WEB站点并添加Web用户控件(名为MyCode,语言选择Visual C#)。
2.进入MyCode.ascx文件的设计模式,分别拖入一个Image控件和一个LinkButton控件并将LinkButton控件的

Text属性改为:“我看不清,给我换一张”(你当然可以随便写什么)。
3.双击LinkButton控件进入后置代码中,在该文件中写一个私有的无返回类型的GetCode()方法,其代码如下:

 
  1. private void GetCode()
  2.     {
  3.         //创建验证码位图,宽为500个像素,高为150个像素
  4.         Bitmap myCode = new Bitmap(500, 150);
  5.         //获取位图物理路径
  6.         string codePath = Server.MapPath("~") + "\\code.jpg";
  7.         //创建随机数
  8.         Random rd = new Random();
  9.         //验证码字符串
  10.         string line = "";
  11.         for (int j = 0; j < 6; j++)
  12.         {
  13.             //随即产生大于等于0小于3的数
  14.             int i = rd.Next(3);
  15.             
  16.             if (i == 0)
  17.             {
  18.                 //若为0则生成A-Z的字符并追加到line
  19.                 line += char.ConvertFromUtf32(rd.Next(65, 92));
  20.             }
  21.             else if (i == 1)
  22.             {
  23.                 //若为1则生成a-z的字符串并追加到line
  24.                 line += char.ConvertFromUtf32(rd.Next(97, 123));
  25.             }
  26.             else
  27.             {
  28.                 //其他则生成0-9的数字并追加到line
  29.                 line += rd.Next(10);
  30.             }
  31.         }
  32.         //创建Graphics对象
  33.         Graphics g = Graphics.FromImage(myCode);
  34.         //画上字符串line,且字体随机,大小为90,采用红色实线,从位图的左上角开始画
  35.         g.DrawString(line, new Font(FontFamily.Families[rd.Next(2)], 90), new SolidBrush(Color.Red), 0, 0);
  36.         //给验证码画上10条随机线条加以干扰,黄绿实线,粗度为2,起始位置,终止位置均为不超过位图大小的随机数
  37.         for (int i = 0; i < 10; i++)
  38.         {
  39.             g.DrawLine(new Pen(new SolidBrush(Color.LightGreen), 3), new Point(rd.Next(500), rd.Next(150)), new Point(rd.Next(500), rd.Next(150)));
  40.         }
  41.         //获得水印图片
  42.       &
    nbsp; System.Drawing.Image water = System.Drawing.Image.FromFile(Server.MapPath(
    "~") + "\\water.jpg");
  43.         //将水印画至位图右下角
  44.         g.DrawImage(water, new Point(500-water.Width,150-water.Height));
  45.         //销毁Graphics
  46.         g.Dispose();
  47.         //保存验证码
  48.         myCode.Save(codePath, System.Drawing.Imaging.ImageFormat.Jpeg);
  49.         //销毁位图对象
  50.         myCode.Dispose();
  51.         //显示至网页
  52.         this.Image1.ImageUrl = "code.jpg";
  53.     }

4.在LinkButton1_Click事件中调用GetCode()方法,在Page_Load事件中写入:
if (!IsPostBack)
{
       GetCode();
}
其意是当第一次打开网页的时候调用GetCode()方法。
5.新建一个Web窗体文件TestMyCode.aspx并进入其设计模式,将刚才创建的用户控件MyCode.ascx文件拖入其中


6.运行TestMyCode.aspx文件即可看到如下图中的效果,当单击“我看不清,给我换一张”时便会更换一张新的

验证码。


注:code.jpg为位图文件由编写的代码生成,water.jpg文件为自备水印文件。

ASP.NET使用正则表达式屏蔽垃圾信息

2008.09.25 / 标签: / 分类: ASP.NET

找资料,看看如何实现使用正则表达式屏蔽垃圾信息,找来找去找出来的都不怎么好,有不详细的,有代码缺失的。最后还是找到了微软,先摘过来,大概思路已经有了,只需把下面微软给的样例代码修改一下即可,具体能不能行还不知道,先睡一觉,起来再慢慢研究。
Regex 类
表示不可变的正则表达式。

命名空间:System.Text.RegularExpressions

Regex 类包含若干 static(在 Visual Basic 中为 Shared)方法,使您无需显式创建 Regex 对象即可使用正

则表达式。在 .NET Framework 2.0 版中,将缓存通过调用静态方法而编译的正则表达式,而不会缓存通过调

用实例方法而编译的正则表达式。默认情况下,正则表达式引擎将缓存 15 个最近使用的静态正则表达式。因

此,在过度地依赖一组固定的正则表达式来提取、修改或验证文本的应用程序中,您可能更愿意调用这些静态

方法,而不是其相应的实例方法。IsMatch、Match、Matches、Replace 和 Split 方法的静态重载可用。

 
  1. using System;
  2. using System.Text.RegularExpressions;
  3.  
  4. public class Test
  5. {
  6.    public static void Main ()
  7.    {
  8.       // Define a regular expression for currency values.
  9.          Regex rx = new Regex(@"^-?\d+(\.\d{2})?$");
  10.           
  11.          // Define some test strings.
  12.          string[] tests = {"-42""19.99""0.001""100 USD"
  13.                            ".34""0.34""1,052.21"};
  14.           
  15.          // Check each test string against the regular expression.
  16.          foreach (string test in tests)
  17.          {
  18.             if (rx.IsMatch(test))
  19.             {
  20.                Console.WriteLine("{0} is a currency value.", test);
  21.             }
  22.             else
  23.             {
  24.                Console.WriteLine("{0} is not a currency value.", test);
  25.             }
  26.          }
  27.    }    
  28. }

 

实践理解流式布局

2008.09.24 / 标签: / 分类: ASP.NET

自从我给尼克技术博客换上J-Spring模板加上了点小修改后在IE核心的浏览器下都很正常,自己也没有装FF就没注意去测试是否效果一样好。多亏长河同学的提醒,FF下文章排行严重错位了,在此感谢一下长河同学,哎~突然不禁感慨,每天来我这里的人也上百人呢,怎么按说用FF来的应该也不少(从流量统计能看到),怎么就没人给我提醒一下呢?郁闷~
牢骚发完了,我们看看是怎么个回事,为什么IE下显示正常,而FF下就严重错位了。学过HTML的人应该都知道网页默认情况下是流式布局的—从上到下,从左到右。
现在来看看我原先的模板代码:

 
  1. <ul class="msg trackback">
  2.     <li class="tbname">文章排行:</li>
  3. <div class="function">
  4.    <h3>最新文章</h3>
  5.    <ul id="ulRandomsortnew">
  6.    <script language="JavaScript" type="text/javascript">strBatchInculde+="ulRandomsortnew=randomsortnew,"</script>
  7.    </ul>
  8. </div>
  9.  
  10. <div class="function">
  11.    <h3>评论排行</h3>
  12.    <ul id="ulRandomsortcommonth">
  13.    <script language="JavaScript" type="text/javascript">strBatchInculde+="ulRandomsortcommonth=randomsortcommonth,"</script>
  14.    </ul>
  15. </div>
  16.  
  17. <div class="function">
  18.    <h3>随机推荐</h3>
  19.    <ul id="ulRandomsortallrand">
  20.    <script language="JavaScript" type="text/javascript">strBatchInculde+="ulRandomsortallrand=randomsortallrand,"</script>
  21.    </ul>
  22. </div>
  23. </ul>
  24.  
  25. <ul class="msg mutuality">
  26.     <li class="tbname"><#ZC_MSG231#>:</li>
  27.     <li class="msgarticle"><#template:article_mutuality#></li>
  28. </ul>

试了好几下终于找到了办法,把<ul class="msg trackback">…</ul>这段HTML标签用<div style="float:right"></div>套起来,这样一来文章排行就会靠右漂浮,将<ul class="msg mutuality">挤下去并靠左,于是乎FF下也都整齐了。

ASP.NET中5种数据验证控件

2008.09.17 / 标签: ,, / 分类: ASP.NET
Sofa

为什么需要数据验证
数据的插入和更新涉及到用户的操作,难免有用户不了解你的系统,或者用户手误,输入格式不正确的数据。比如价格本来应该是数字“0”,而用户不小心输入了个字符“o”进去,就会出错。所以我们有必要通过技术手段,尽量减少一些可能发生的错误,这就需要数据验证。
阅读全文>>

数据源控件的使用

2008.09.10 / 标签: ,,,, / 分类: ASP.NET
Sofa

在之前的[SiteMapPath控件] 中其实就已经用到过数据源控件了。
所有的数据源控件都是派生自System.Web.UI.DataSourceControls类。下面是一些常用数据源控件以及它们各自的作用。
阅读全文>>

ASP.NET作业 信息网系统框架

2008.09.09 / 标签: , / 分类: ASP.NET
Sofa

 1,业务畅想
 
1)发表信息:发表各种类别的分类信息(实效性强)
2)搜索信息:各种分类信息的快速搜索,按照分类的搜索(分类科学)
3)订阅感兴趣的信息:使用(信息通)可以进行信息订阅
4)信息评论,信息评级: 对信息可以进行自己的分享的感觉
5)发表收费信息:通过付费,能够获得置顶等推广
6)在线沟通(信息通):所有用户都可以在线等待自己信息的订阅。
基础流量大约500人/天:产生和消费信息:5条/人 30天最长有效期,
月数据量 30*500*5 = 75000条(保守估计)
月人流量 (50 + 500)*30 / 2 = 8250 IP
 
2,网站架构
 
采用SQL2000 与 ASP.NET 技术进行开发。
架构采用微软的N层架构:简单工厂+ 反射
 网站架构
 
 

 

【工作01】建立三层架构工程
 
1,业务分析与设计
1,业务名词分析: 信息 用户 评论 信息类别
2,业务讨论并划出用例图(客户用我们系统能够做什么事情):
【工作02】创建用例图

 

用例图

[普通用户用例图]

 

[注册用户用例图]

 

[管理用户用例图]

 

1,寻找名词的属性并创建类图

 

【工作03】创建类图并建立关系

 

 

1,根据类图建立数据库(注意 类之间的关系是用外键的方式在数据库中表示)

【工作04】创建数据库表并建立关系

1,代码编写
1)Models层编写,实体类的撰写
【工作05】编写Models
2)IDAL层编写,主要是定义数据访问层的对象都应该具有哪些方法,所以应该定义接口,名为[I+对象名+Service]; (注:接口中方法名前不能有public)
【工作06】编写IDAL
3)SqlServerDAL编写,实现IDAL中定义的接口,名为[对象名+Service];
【工作07】编写SqlServerDAL
 
2,工具使用
3,文档撰写
4,项目总结

 

 

 

ASP.NET数据绑定

2008.09.09 / 标签: / 分类: ASP.NET
Sofa

在以前的Winform中我们使用DataGridView控件来直接指定数据源就可以显示数据内容。
那么在ASP.NET中,也可以指定控件的数据源来绑定数据。
在ASP.NET中,我们有两种方式可以绑定数据源。
阅读全文>>

ASP.NET网站开发用到的数据库访问类

2008.09.08 / 标签: / 分类: ASP.NET

最近开始学ASP.NET了,Mr.Liu给了一个新的用于数据库访问的公共类。
看了一下和以前的公共类的区别:
1.此类的各个属性和方法都静态化了,可以直接通过类名访问了,不再需要去new了。
2.没有了以前的全局的SqlCommand和SqlDataReader了,取而代之的是using (SqlCommand cmd = new SqlCommand(sql, conn))。
3.没有了以前的CloseConnection()方法了。
有些不明白,QQ上问了一下Mr.Liu。
问:是不是少了个关闭链接的方法?查询完也要关闭啊 。
Mr.Liu答:不用,这里使用了CommandBehavior。
问:就是这? using (SqlCommand comm = new SqlCommand(sql, conn)用完就消失?
Mr.Liu答:对。
还是有些疑问,不过不问Mr.Liu了,我改问百度大叔了。
问:using (SqlCommand comm = new SqlCommand(sql, conn)
百度大叔说了一大堆给,可是我没发现我想要的。
继续问:CommandBehavior
百度大叔说:我给你两个地方,一个Microsoft,一个CSDN。
告别百度大叔,俺就分别拜访了Microsoft和CSND。
以下分别是这两位大牛给俺的解释:
Microsoft

.NET Framework 类库
CommandBehavior 枚举
提供对查询结果和查询对数据库的影响的说明。

此枚举有一个 FlagsAttribute 属性,该属性使其成员值按位组合。

命名空间:  System.Data
程序集:  System.Data(在 System.Data.dll 中)

C#语法:
[FlagsAttribute]
public enum CommandBehavior

成员:

成员名称 说明

Default             此查询可能返回多个结果集。执行查询可能会影响数据库状态。Default 不设置 CommandBehavior 标志,因此调用 ExecuteReader(CommandBehavior.Default) 在功能上等效于调用 ExecuteReader()。
SingleResult        查询返回一个结果集。
SchemaOnly          查询仅返回列信息。当使用 SchemaOnly 时,用于 SQL Server 的 .NET Framework 数据提供程序将在要执行的语句前加上 SET FMTONLY ON。
KeyInfo         此查询返回列和主键信息。 
SingleRow         查询应返回一行。执行查询可能会影响数据库的状态。一些 .NET Framework 数据提供程序可能(但不要求)使用此信息来优化命令的性能。用 OleDbCommand 对象的 ExecuteReader 方法指定 SingleRow 时,用于 OLE DB 的 .NET Framework数据提供程序使用 OLE DB IRow 接口(如果可用)执行绑定。否则,它使用 IRowset 接口。如果您的 SQL 语句应该只返回一行,则指定 SingleRow 还可以提高应用程序性能。在执行返回多个结果集的查询时,可以指定 SingleRow。在这种情况下,仍返回多个结果集,但每个结果集只有一行。
SequentialAccess    提供一种方法,以便 DataReader 处理包含带有大二进制值的列的行。SequentialAccess 不是加载整行,而是使 DataReader 将数据作为流来加载。然后可以使用 GetBytes 或 GetChars 方法来指定开始读取操作的字节位置以及正在返回的数据的有限的缓冲区大小。
CloseConnection     在执行该命令时,如果关闭关联的 DataReader 对象,则关联的 Connection 对象也将关闭。(这个是我们想要的,其他就当是知识拓展)

CSDN给出的解释:

当 DataReader 处于使用中时,关联的 DbConnection 正忙于为 DataReader 服务。当处于此状态时,除了关闭 Connection 外,不能对其执行其他任何操作。除非调用 DataReader 的 Close 方法,否则会一直处于此状态。如果创建了 DataReader 并将 CommandBehavior 设置为 CloseConnection,则关闭 DataReader 会自动关闭此连接。

OK了,还是CSDN解释的一针见血啊!俺这下完全明白了。
最后给贴出这个数据库访问类:

 
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Text;
  4. using System.Data;
  5. using System.Data.SqlClient;
  6. using System.Configuration;
  7.  
  8.  
  9. namespace ConsoleApplication6
  10. {
  11.     public class DbHelper
  12.     {
  13.         /// <summary>
  14.         /// 连接字符串
  15.         /// </summary>
  16.         static string connectionString;
  17.  
  18.         /// <summary>
  19.         /// 公用的连接
  20.         /// </summary>
  21.         static SqlConnection conn;
  22.  
  23.         /// <summary>
  24.         /// 静态构造,用来初始化连接字符串
  25.         /// </summary>
  26.         static DbHelper()
  27.         {
  28.             connectionString = System.Configuration.ConfigurationSettings.AppSettings["ConnectionString"].ToString();
  29.         }
  30.  
  31.  
  32.         /// <summary>
  33.         /// 获得一个连接
  34.         /// </summary>
  35.         static void GetConnection()
  36.         {
  37.            conn = new SqlConnection(connectionString);
  38.         }
  39.  
  40.         /// <summary>
  41.         /// 执行查询
  42.         /// </summary>
  43.         /// <param name="sql"></param>
  44.         /// <returns></returns>
  45.         public static SqlDataReader ExecuteQuery(string sql)
  46.         {
  47.             GetConnection();
  48.             using (SqlCommand comm = new SqlCommand(sql, conn))
  49.             {
  50.                 conn.Open();
  51.                 return comm.ExecuteReader(CommandBehavior.CloseConnection);
  52.             }
  53.         }
  54.  
  55.         /// <summary>
  56.         /// 带参数的查询
  57.         /// </summary>
  58.         /// <param name="sql"></param>
  59.         /// <param name="paras"></param>
  60.         /// <returns></returns>
  61.         public static SqlDataReader ExecuteQuery(string sql, SqlParameter[] paras)
  62.         {
  63.             GetConnection();
  64.             using (SqlCommand comm = new SqlCommand(sql, conn))
  65.             {
  66.                 comm.Parameters.AddRange(paras);
  67.                 conn.Open();
  68.                 return comm.ExecuteReader(CommandBehavior.CloseConnection);
  69.             }
  70.         }
  71.  
  72.         /// <summary>
  73.         /// 执行增删改
  74.         /// </summary>
  75.         /// <param name="sql">已经拼写好的Sql语句</param>
  76.         /// <returns></returns>
  77.         public static bool ExecuteUpdate(string sql)
  78.         {
  79.             GetConnection();
  80.             using (SqlCommand comm = new SqlCommand(sql, conn))
  81.             {
  82.                 bool success;
  83.                 conn.Open();
  84.                 int i = comm.ExecuteNonQuery();
  85.                 if (i > 0)
  86.                 {
  87.                     success = true;
  88.                 }
  89.                 else
  90.                 {
  91.                     success = false;
  92.                 }
  93.                 conn.Close();
  94.                 return success;
  95.             }
  96.         }
  97.  
  98.         /// <summary>
  99.         /// 执行增删改
  100.         /// </summary>
  101.         /// <param name="sql">带参数的SQL语句</param>
  102.         /// <returns></returns>
  103.         public static bool ExecuteUpdate(string sql, SqlParameter[] paras)
  104.         {
  105.             GetConnection();
  106.             using (SqlCommand comm = new SqlCommand(sql, conn))
  107.             {
  108.                 comm.Parameters.AddRange(paras);
  109.                 bool success;
  110.                 conn.Open();
  111.                 int i = comm.ExecuteNonQuery();
  112.                 if (i > 0)
  113.                 {
  114.                     success = true;
  115.                 }
  116.                 else
  117.                 {
  118.                     success = false;
  119.                 }
  120.                 conn.Close();
  121.                 return success;
  122.             }
  123.         }
  124.  
  125.         /// <summary>
  126.         /// 执行查询返回第一行的第一列
  127.         /// </summary>
  128.         /// <param name="sql"></param>
  129.         /// <returns></returns>
  130.         public static object ExecuteScalar(string sql)
  131.         {
  132.             GetConnection();
  133.             using (SqlCommand comm = new SqlCommand(sql, conn))
  134.             {
  135.                 conn.Open();
  136.                 object obj = comm.ExecuteScalar();
  137.                 conn.Close();
  138.                 return obj;
  139.             }
  140.             
  141.         }
  142.  
  143.         /// <summary>
  144.         /// 执行查询返回第一行的第一

浅谈ASP.NET表示层

2008.09.06 / 标签: , / 分类: ASP.NET
Sofa

ASP.NET中的表示层负责内容的展现和与用户的交互。它给予用户直接的体验。当今的许多项目往往表示层是项目成败的关键,而这往往被程序员所忽视。
阅读全文>>

无觅相关文章插件,快速提升流量