用了这么久的webform,还记得刚开始根本不知道程序要写成什么样,只知道功能实现了就行,有很多现实的问题都没考虑到。所以程序改了又改,最后连自己做的什么都不知道了。所以,现在来总结一下。

会员功能 模块 大致分为 注册 登陆 用户信息管理 用户参与网站业务 4个方面。

1、注册。

因为网站运营的需要,可能注册页面不止一个。所以将注册的后台功能剥离出来,用注册的时候直接将信息发送到 register.ashx页面。

所以网站结构大概是 register.aspx.cs-->register.aspx-->register.ashx-->注册成功跳转。

数据库

1、网站配置数据库。记录被禁止注册登陆的IP地址。注册时间间隔(也可写在web.config中)

2、用户登陆信息表-安全信息表-用户业务信息表

登陆表 存登陆就要用的信息。

安全信息表 存注册时间,安全问题等

业务信息表 存用户网站的业务信息,如:钱包,积分,不常用的个人信息:邮箱、qq、职业等,最后登陆时间。。。。

register.aspx.cs进入注册页面时运行,功能:判断注册次数,IP是否禁用,注册间隔(是否重复注册)

protected void Page_Load(object sender, EventArgs e)
{
    string sqlConfig="select top 1 * from Web_Config";
    DataTable table = SqlHelper.GetDateTable(sqlConfig);
    )
    {
    ]["IPDisabled"].ToString();//禁止注册IP
    ]["ReRegTimeSpan"];//注册间隔
    ]["maxRegCount"];//同一IP最大注册数量
    string ip=获得IP();
    判断当前IP是否被限制(strDIP,ip );
    判断是否为重复注册(regSpan);
    检测IP注册次数(maxRegCount,ip);
    //如果都满足条件,进入register.aspx页面填写表单
    }
}
private void 判断当前IP是否被限制(string strDIP,string ip )//判断IP是否被限制的方法
{
    List<string> list = new List<string>(str.Split(new char[] { ',' }));
    if (list.Contains("*.*.*.*"))
    {
        base.Response.Write("当前暂停注册,请稍后再来尝试。");
        base.Response.End();
    }
    ))) || list.Contains(CutIP(iP, ))) || list.Contains(CutIP(iP, )))
    {
        base.Response.Write("您的IP段在被限制的范围内,不能进行注册,请联系我们的客服进行咨询。");
        base.Response.End();
    }
}
public string CutIP(string ip, int len)//公共方法在common.cs中,为了看起方便,暂时写在register.aspx.cs中
{
    )
    {
        if (string.IsNullOrEmpty(ip))
        {
            return "";
        }
        Match match = new Regex(@"(\d+)\.(\d+)\.(\d+)\.(\d+)", RegexOptions.Compiled | RegexOptions.IgnoreCase).Match(ip);
        if (match.Success)
        {
            ) ? ].Value, (len >= ) ? ].Value, (len >= ) ? ].Value, (len >= ) ? ].Value });
        }
    }
    return ip;
}
private void 判断是否为重复注册(string num)//判断是否为重复注册
{
    object obj2 = BCSTCache.Default.Get<CookiesCache>("RegDateTime");//这个方法是调用的第三方的类库中操作cookies的方法,注册成功后会将时间写入cookies。
    if ((obj2 != null) && CommonManager.String.IsDateTime(obj2.ToString()))
    {
    TimeSpan span = (TimeSpan)(DateTime.Now - DateTime.Parse(obj2.ToString()));
    if (span.TotalMinutes < num)
    {
    base.Response.Write("请不要重复注册。");
    base.Response.End();
    }
}
private void 检测IP注册次数(string maxRegCount,string ip)
{
    )
    {
    int num3 = (int)DbSession.Default.FromSql("select COUNT(1) FROM dbo.Web_Users WHERE RegisterIP='" + iP + "' AND DATEDIFF(d,RegisterTM,GETDATE())=0").ToScalar();
    if (num3 >= maxRegCount)
    {
    base.Response.Write("您的IP今日注册人数已达到限制数。");
    base.Response.End();
    }
}
private string 获得IP()
{
    if ((Request.ServerVariables["HTTP_X_FORWARDED_FOR"] != null) && (Request.ServerVariables["HTTP_X_FORWARDED_FOR"] != ""))
    {
    return Request.ServerVariables["HTTP_X_FORWARDED_FOR"];
    }
    return Request.ServerVariables["REMOTE_ADDR"];
}

好累啊,写文章和写代码果然不一样,代码写久了总会有一些自己收集的代码库,在文章中又不好表述。剩下的过两天再写。

(未完待续)

WebForm业务系列-会员功能的更多相关文章

  1. Dynamics AX 2012 R2 业务系列-销售业务流程

    在博文Dynamics AX R2 业务系列中,Reinhard对这个系列做了一个规划,下面我们就按照规划开始说业务吧. 1.销售的主要职责 其实这里说的职责主要是针对销售文员,并非整天外面满世界跑业 ...

  2. Dynamics AX 2012 R2 业务系列-采购业务流程

    在博文Dynamics AX R2 业务系列中,Reinhard对这个系列做了一个规划,下面我们就按照规划开始说业务吧. 国际惯例,从采购开始. 1.采购的主要职责 简单点说,采购的主要职责,是从供应 ...

  3. dede添加会员功能听语音

    http://jingyan.baidu.com/article/363872ec36d33f6e4ba16fb7.html 其实 dede里面的 会员功能就是圈子模版啦 圈子 安装了 基本上有 1, ...

  4. dede开启会员功能

    登陆后台,找到菜单里面的系统基本参数设置>会员设置>开启会员功能,选择“是”,保存即可

  5. 03.Web大前端时代之:HTML5+CSS3入门系列~H5功能元素

    Web大前端时代之:HTML5+CSS3入门系列:http://www.cnblogs.com/dunitian/p/5121725.html 2.功能元素 1.hgroup 对网页或区段(secti ...

  6. Dynamics AX 2012 R2 业务系列

    在之前的一系列博文里,Reinhard介绍了Dynamics AX Demo的安装与配置.相信同学们看完后,都已经成功拥有了一个测试环境. 众所周知的是,ERP作为一个特殊的软件系统,他有着背后的业务 ...

  7. Nginx实战系列之功能篇----后端节点健康检查(转)

    公司前一段对业务线上的nginx做了整理,重点就是对nginx上负载均衡器的后端节点做健康检查.目前,nginx对后端节点健康检查的方式主要有3种,这里列出:   1.ngx_http_proxy_m ...

  8. Nginx实战系列之功能篇----后端节点健康检查

    目前,nginx对后端节点健康检查的方式主要有3种,这里列出:   1.ngx_http_proxy_module 模块和ngx_http_upstream_module模块(自带)    官网地址: ...

  9. N32G4系列——复用功能重映射(USART为例)

    开发测试环境:SDK,N32G455x系列芯片 在国民MCU中G系列IO口有第二复用功能,这时需要用到重映射功能. 一.系列芯片手册定义 1.1.芯片IO口默认功能查看 如图,在该系列芯片的数据手册中 ...

随机推荐

  1. spring四种依赖注入方式

    一.Set注入 这是最简单的注入方式,假设有一个SpringAction,类中需要实例化一个SpringDao对象,那么就可以定义一个private的SpringDao成员变量,然后创建SpringD ...

  2. mysql awr 1.0.5 GA正式版发布

    1.0.5变更内容 1.修复centos 7下swap值不正确:2.中文乱码:3.begin/end snap下拉显示Mysql启动时间:4.两次快照间不能重启过:5.新增tab页面查看mysql存储 ...

  3. sea.js模块化编程

    * 为什么要模块化? 解决文件依赖 解决命名冲突 ; var var2 = 2; function fn1(){ } function fn2(){ } return { fn1: fn1, fn2: ...

  4. AlloyTouch与three.js 3D模型交互

    如你所见,上面的cube的旋转.加速.减速停止都是通过AlloyTouch去实现的. 演示 代码 <script src="asset/three.js"></s ...

  5. 基于Nuclear的Web组件-Todo的十一种写法

    刀耕火种 刀耕火种是新石器时代残留的农业经营方式.又称迁移农业,为原始生荒耕作制. var TodoApp = Nuclear.create({ add: function (evt) { evt.p ...

  6. listview侧滑删除

    自定义Listview,向左滑动,右边刚好显示删除按钮: public class SlideListView extends ListView { private int mScreenWidth; ...

  7. React Native 之 Touchable 介绍与使用

    前言 学习本系列内容需要具备一定 HTML 开发基础,没有基础的朋友可以先转至 HTML快速入门(一) 学习 本人接触 React Native 时间并不是特别长,所以对其中的内容和性质了解可能会有所 ...

  8. IOS 杂笔-9 (MD5 加密)

    首先是一段对MD5的简介 *出自一位大牛之手* Message Digest Algorithm MD5(中文名为消息摘要算法第五版)为计算机安全领域广泛使用的一种散列函数,用以提供消息的完整性保护 ...

  9. 2016 DTCC(中国数据库技术大会)

    上周去参加了2016 DTCC(数据库技术大会),会议总共持续3天,议题非常多,我这里搜集了最新的公开的PPT内容,有兴趣的同学可以下载看看,PPT合集下载链接为:http://pan.baidu.c ...

  10. linux ssh远程免登陆

    一.备份: 操作之前先将/root/.ssh/下的known_hosts备份成known_hosts.bak