C#设计模式之Template模板方法模式实现ASP.NET自定义控件 密码强度检测功能
本文实例讲述了C#设计模式之Template模板方法模式实现ASP.NET自定义控件 密码强度检测功能。分享给大家供大家参考,具体如下:
一、理论定义
模板方法模式 预先定义实现了一些基本属性和方法,需要重新计算的部分,通过子类去重写 或 增加新方法来实现。
二、应用举例
需求描述: ASP.NET自定义控件有很多通用的属性和事件, 通过继承System.Web.UI.WebControls.WebControl类,可以实现自定义控件。
WebControl拥有控件基本的方法和事件,让我们定义控件时,可以站在巨人的肩上,
避免重复造轮子。WebControl就相当于一个模板,改变模板的属性,或者往模板里面加东西,显示的内容就不一样。
密码强度检测的例子,是通过修改Strength 属性,来控制密码的强度。
三、具体编码
1.一个 密码强度的枚举
using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace Com.Design.Gof.Template { /// <summary> /// 密码强度枚举属性 /// </summary> public enum StrengthOption { VeryLow=1,//很差 Normer=2,//一般 Good=3,//良好 Perfect=4//非常棒,非常强,极佳 } }
2.密码强度 自定义控件
using System; using System.Collections.Generic; using System.ComponentModel; using System.Linq; using System.Text; using System.Web; using System.Web.UI; using System.Web.UI.WebControls; [assembly: TagPrefix("Com.Design.Gof.Template", "asp")] namespace Com.Design.Gof.Template { [DefaultProperty("Text")] [ToolboxData("<{0}:PasswdStrength runat=server></{0}:PasswdStrength>")] public class PasswdStrength : WebControl { /// <summary> /// 当前密码强度 /// </summary> [Bindable(true)] [Category("Appearance")] [DefaultValue(StrengthOption.VeryLow)] [Localizable(true)] public StrengthOption Strength { get { object bag = ViewState["StrengthOption"]; if (bag == null) { return StrengthOption.VeryLow; } return (StrengthOption)ViewState["StrengthOption"]; } set { ViewState["StrengthOption"] = value; } } protected override void RenderContents(HtmlTextWriter output) { string css = ""; switch (Strength) { case StrengthOption.VeryLow: css = "bg1"; break; case StrengthOption.Normer: css = "bg2"; break; case StrengthOption.Good: css = "bg3"; break; case StrengthOption.Perfect: css = "bg4"; break; default: break; } output.Write("<div class='" + css + "'></div>"); } } }
3.ASPX页面调用控件
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Template_PasswdStrength.aspx.cs" Inherits="Com.Design.Gof.Test.Web.Template_PasswdStrength" %> <%@ Register Assembly="Com.Design.Gof" Namespace="Com.Design.Gof.Template" TagPrefix="asp" %> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title></title> <style type="text/css"> div{width: 180px; height: 7px; border-left: 1px solid rgb(255, 117, 6); margin-left: 5px; margin-top:10px} div.bg1{background: url("/images/pwd.png") no-repeat scroll 100% 0% transparent; } div.bg2{background: url("/images/pwd.png") no-repeat scroll 100% 32% transparent; } div.bg3{background: url("/images/pwd.png") no-repeat scroll 100% 65% transparent; } div.bg4{background: url("/images/pwd.png") no-repeat scroll 100% 100% transparent; } </style> </head> <body> <h3>密码强度四种情况,Strength是asp:PasswdStrength的控件的自定义属性</h3> <p>非常弱</p> <asp:PasswdStrength ID="PasswdStrength1" runat="server" /> <p>一般</p> <asp:PasswdStrength Strength=Normer ID="PasswdStrength2" runat="server" /> <p>良好</p> <asp:PasswdStrength Strength=Good ID="PasswdStrength3" runat="server" /> <p>很强</p> <asp:PasswdStrength Strength=Perfect ID="PasswdStrength4" runat="server" /> </body> </html>
4.运行结果
5.总结
自定义控件知识
附件里面包括了程序源码。也包括其他项目的测试,有控制台,有web。
此模式用Com.Design.Gof.Test.Web测试。
附:完整实例代码点击此处本站下载。
PS:这里再为大家提供两款相关在线工具供大家参考使用:
密码安全性在线检测:
http://tools.jb51.net/password/my_password_safe
高强度密码生成器:
http://tools.jb51.net/password/CreateStrongPassword
在线随机数字/字符串生成工具:
http://tools.jb51.net/aideddesign/suijishu
更多关于C#相关内容还可查看本站专题:《C#数据结构与算法教程》、《C#窗体操作技巧汇总》、《C#常见控件用法教程》、《WinForm控件用法总结》、《C#数组操作技巧总结》及《C#面向对象程序设计入门教程》
希望本文所述对大家C#程序设计有所帮助。
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- (在模仿中精进数据可视化01) 全国38城居住自由指数可视化
- js字符串/数组常用方法总结
- ThinkPHP5+mpdf 实现富文本生成 PDF文件
- nodejs使用readline逐行读取和写入文件
- go语言逐行读取和写入文件
- SpringBoot中Tomcat是如何启动的
- 自定义注解详解及应用
- 微服务开源框架TARS 之 框架服务解析
- dotnet 在 UOS 国产系统上使用 Xamarin Forms 创建 xaml 界面的 GTK 应用
- K8s集群上使用Helm部署2.4.6版本Rancher集群
- VMware下安装CentOS
- leetcode多线程之按序打印
- 表格的实现
- 使用 Node.js 定制你的技术雷达:中篇
- 数据库PostrageSQL-在Windows上从源代码安装