用了这么久的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. WCF入门教程3——WCF通信模式

    本章内容 请求/响应模式 单工模式 双工模式 WCF异步调用 请求与响应模式 请求/响应     请求/响应通信是指客户端向服务端发送消息后,服务端会向客户端发送响应.这也意味着在接收到服务的响应以前 ...

  2. SpringMVC + Spring + MyBatis 整合 + Spring shrio + easyUI + 权限管理框架,带shrio session和shrio cache集群实现方案

    工作之余先来写了一个不算规范的简单架子 基于spring mvc + spring + mybatis + Spring shrio 基于redis的集群方案 系统权限部分,分成多个机构,其中每个机构 ...

  3. ViewPager 重新加载 及 PagerAdapter 使用

    PagerAdapter 简介 PagerAdapter是android.support.v4包中的类,它的子类有FragmentPagerAdapter, FragmentStatePagerAda ...

  4. 高仿ios版美团框架项目源码

    高仿美团框架基本已搭好.代码简单易懂,适合新人.适合新人.新人. <ignore_js_op>     源码你可以到ios教程网那里下载吧,这里我就不上传了,http://ios.662p ...

  5. redis数据结构存储Linked List设计细节(redis的设计与实现笔记)

    redis里拥有一个灵活扩展且获取表头表尾复杂度为O(1)的双端列表,分为list和listNode2部分组成. list: typedef struct list {//链表 listNode *h ...

  6. Oracle学习笔记三 SQL命令

    SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)  

  7. BZOJ 1251: 序列终结者 [splay]

    1251: 序列终结者 Time Limit: 20 Sec  Memory Limit: 162 MBSubmit: 3778  Solved: 1583[Submit][Status][Discu ...

  8. Nginx模块之http.md

    ngx_http_access_module ngx_http_access_module模块允许限制对某些客户端地址的访问. 访问也可以通过密码,子请求的结果或JWT来限制. 通过地址和密码的同时访 ...

  9. PAT 1048. 数字加密(20)

    本题要求实现一种数字加密方法.首先固定一个加密用正整数A,对任一正整数B,将其每1位数字与A的对应位置上的数字进行以下运算:对奇数位,对应位的数字相加后对13取余--这里用J代表10.Q代表11.K代 ...

  10. html之select标签

    循环select标签 <select name="group_id"> {% for row in group_list %} <option value={{r ...