ASPNET登陆总结
昨天晚上看了视频,今天早上起来就凭着记忆与视频里的代码试着做了一个登陆,基本功能是实现了。
0x0:首先,第一步是做一个界面。。。。直接扒别人做好的页面。。。。。各种改改路径啥的,用浏览器打开,恩,发现基本界面是对的就ok
0x1:解决验证码。添加一个一般处理程序ValidateCode。直接封装好了一个类,具体是使用GDI+实现的。类里面的方法直接返回了image/jpeg。然后在aspx界面代码里面加上JS代码,为验证码图片注册点击事件,每点击一次,就将src属性改变一次(在后面加1),重新请求一次。同时在这个一般处理程序实现的接口加上IRequiresSessionState,这个接口转到定义后发现是空的,就是起到一个标志的作用,可以使用Session。在ValidateCode.ashx的代码后面加上 context.Session["ValidateCode"] = strCode; 将这次生成的验证码记录到本次会话中。
0x2:Cookie。第一次请求的话,就将上次登录的用户名放到文本框中。
if (!IsPostBack)
{
//第一次请求从cookie中拿到上次登陆的用户名,并放到文本框中
LastLoginName = Request.Cookies["UserName"] == null ? string.Empty : Request.Cookies["UserName"].Value;
}
0x3:如果是IsPostBack的话,意味着这是一次登录请求,首先将现在登录的用户名写入cookie中:Request.Cookies["UserName"].Value = Request["txtClientID"];
然后校验验证码:
string requestCode = Request["txtCode"];
string sessionCode = Session["ValidateCode"] == null ? string.Empty : Session["ValidateCode"].ToString();
Session["ValidateCode"] = null;//匹配一次就清空
获得用户输入的验证码,存在会话中的验证码,然后清空会话中的验证码。
然后就可以拿这两个验证码进行校验,如果相同且都不为空,意味着验证码正确,可以进行用户名和密码的校验;如果两次验证码不一样或者为空,意味着验证码校验失败。(ps:为什么要清空会话中的验证码呢?是为了防止暴力破解,如果不清空的话,可以伪造http请求不停地试验证码。Burp Suite就可以很轻松的做到爆破~);
如果验证失败,可以在前台弹出一个提示。为了方便,直接在前台预留一个坑 <%= ShowMsg %>,在后台代码中添加属性ShowMsg。这样需要在这个坑里面写什么样的代码就都可以了。例如:(<script>alert('验证码输入失败!');</script>);
0x4:验证用户名密码就太简单了,BLL层里直接调用自己写的方法就ok了,方法返回结果是一个List<T>集合。如果成功了就直接Response.Redirect()跳转到后台主页面就行了,并且将这次成功的List<T>中的元素添加到Session中。失败的话就在ShowMsg坑里面弹弹弹,弹走鱼尾纹~
0x5:问题来了,我们登陆成功了就能跳转到主页面了,可是我们不登陆,直接在浏览器地址栏里面输入地址也是一样可以到达主页面的,这尼玛登陆就没有任何意义了,所有一定要做验证,如果不是登陆成功的会话请求就直接让他滚去登陆,直接Response.Redirect()到登陆页面。后台这样需要验证是否是登陆进来的请求实在是太多了,而且为了方便,我们直接生成一个类。
具体如何做?我们发现我们生成的aspx的Web窗体程序都是集成自System.Web.UI.Page类的。我们可以让我们自己生成的类集成System.Web.UI.Page这个类,然后让我们那些需要验证会话的那些web窗体继承我们自己生成的类,这样就相当于在web窗体和System.Web.UI.Page之间加了一层东西,我们就在这个加的一层里面动手脚。
我们在这个类里面加上一个属性。因为我们前面在Session内存里面储存的是list<T>里的元素,所以我们增加的属性的类型就是T,用来校验是否存在会话。代码如下:
public Model.HKSJ_USERS CurrentLoginUsers { get; set;}
protected void Page_Init(object sender, EventArgs e)
{
CurrentLoginUsers = Session["LoginUser"] as Model.HKSJ_USERS;
if (CurrentLoginUsers==null)
{
Response.Redirect("Login.aspx");
}
}
Page_Init 事件代表的是页面初始化,比Page_Load发生的还要早。web窗体继承了这个类,所以他们在页面初始化的时候就会校验是否存在会话。
0x6:在视频里面看到,会话过期的话,iframe标签跳转的话,会在iframe的地方直接跳转到登陆页面,形成嵌套的效果,简直丑陋!!以前入侵网站放上的大马,就是这样,一段时间不操作,就会那样嵌套,当时就觉得简直shit!!
我先是登陆进了后台,然后重新生成,按理说Session已经断开了,我也应该遇到那样的情况才对啊,可是现实不是这样的,我在后台还能继续操作,直接在浏览器地址栏Get请求才会跳转到登陆界面,由此可见,我的Session也是断开了才对啊~难道我在后台的那些操作没有经过Page_Init吗?可是视屏里面就是嵌套跳转了的啊?算了,我也不钻牛角尖了,以后肯定还会遇到的,现在先把解决方案贴出来:
<%--<script type="text/javascript">
if (window != window.top.window) {
window.top.window.location.href = "/Admin/Login.aspx";
}
</script>--%>
跳转的时候先看看自己是不是顶级窗口,如果不是,就让顶级窗口跳到登陆界面;如果是,那还费什么话啊,赶紧跳啊!
第一次写这样的博客,思路还是很乱的。。。写之前,我的思路还要更混乱,写着写着,思路渐渐的就理顺了一些,果然写博客还是有用处的!还有,就是花的时间有点多,不过这样的总结我觉得还是很有必要的。
ASPNET登陆总结的更多相关文章
- Microsoft.AspNet.Identity 的简单使用
要完成一个简单的注册,登陆,至少需要实现Identity中的3个接口 IUser IUserStore<TUser> : IDisposable where TUser : IUser I ...
- asp.net.core网站重启后登陆无效问题(部署在IIS)
一.问题 在使用asp.net.core时,把网站发布到IIS后,在后续更新中需要停止网站,然后重启网站,发现已经登陆的用户会退出登陆.过程如下 1.登陆代码(测试) [AllowAnonymous] ...
- Aspnet Mvc 前后端分离项目手记(四)vue项目的搭建(一)(iview)
一项目创建 1,搭建vue-cli脚手架(依赖npm) 没有安装npm的同学,请先使用npm install -g vue-cli ,然后再进行这一步 安装的过程中有几项 ? Project name ...
- Asp.Net MVC 5使用Identity之简单的注册和登陆
由于.Net MVC 5登陆和注册方式有很多种,但是Identity方式去实现或许会更简单更容易理解 首先新建一个项目 其次如下选择Empty和MVC的选项 然后打开NuGet包管理器分别安装几个包 ...
- [linux]阿里云主机的免登陆安全SSH配置与思考
公司服务器使用的第三方云端服务,即阿里云,而本地需要经常去登录到服务器做相应的配置工作,鉴于此,每次登录都要使用密码是比较烦躁的,本着极速思想,我们需要配置我们的免登陆. 一 理论概述 SSH介绍 S ...
- Python 爬虫模拟登陆知乎
在之前写过一篇使用python爬虫爬取电影天堂资源的博客,重点是如何解析页面和提高爬虫的效率.由于电影天堂上的资源获取权限是所有人都一样的,所以不需要进行登录验证操作,写完那篇文章后又花了些时间研究了 ...
- 调用AJAX做登陆和注册
先建立一个页面来检测一下我们建立的用户名能不能用,看一下有没有已经存在的用户名吗 可以通过ajax提示一下 $("#uid").blur(function(){ //取用户名 va ...
- Android调用微信登陆、分享、支付
前言:用了微信sdk各种痛苦,感觉比qq sdk调用麻烦多了,回调过于麻烦,还必须要在指定包名下的actvity进行回调,所以我在这里写一篇博客,有这个需求的朋友可以借鉴一下,以后自己别的项目有用到也 ...
- 如何将VCSA添加到微软域控环境,并且实现微软域账号登陆vCenter
v:* { } o:* { } w:* { } .shape { } p.msonormal,li.msonormal,div.msonormal { margin: 0cm; margin-bott ...
随机推荐
- STL——静态常量整数成员在class内部直接初始化
如果class内含const static integral data member,那么根据C++标志规格,我们可以在class之内直接给予初值.所谓integral泛指所有的整数型别(包括浮点数) ...
- CDOJ 92 Journey(LCA&RMQ)
题目连接:http://acm.uestc.edu.cn/#/problem/show/92 题意:给定一棵树,最后给加一条边,给定Q次查询,每次查询加上最后一条边之后是否比不加这条边要近,如果近的话 ...
- Day7 - Python基础7 面向对象编程进阶
Python之路,Day7 - 面向对象编程进阶 本节内容: 面向对象高级语法部分 经典类vs新式类 静态方法.类方法.属性方法 类的特殊方法 反射 异常处理 Socket开发基础 作业:开发一个 ...
- MVC4使用EF6连接mysql数据库
1.需要安装MySql.Data.Entity.EF6,此dll可以在项目——>管理NuGet程序包里联机搜索MySql.Data.Entity.EF6并安装即可 2.连接字符串需要添加prov ...
- 使用WMI来控制Windows目录 和windows共享机制
1.使用WMI来控制Windows目录 本文主要介绍如何使用WMI来查询目录是否存在.文件是否存在.如何建立目录.删除目录,删除文件.如何利用命令行拷贝文件,如何利用WMI拷贝文件 using Sys ...
- Solr配置集群
1.主机SolrConfig.xml <requestHandler name="/replication" class="solr.ReplicationHand ...
- js单条新闻向上滚动
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xht ...
- hdu1230火星A+B (大数题)
Problem Description 读入两个不超过25位的火星正整数A和B,计算A+B.需要注意的是:在火星上,整数不是单一进制的,第n位的进制就是第n个素数.例如:地球上的10进制数2,在火星上 ...
- Open vSwitch在openstackHavana概述
最近再看Open vSwitch一些东西,我认为openstack官网上对这一块做了一些了解,所以就把这一块翻译出来以供参考,英语不好,翻译得很粗糙. Open vSwitch插件是最有名的核心插件之 ...
- PHP开发套件
Windows系统下开发 环境配置: PHPstudy----立即下载 开发工具: PHPstorm----立即下载 引用一个注册服务器地址:潘田--phpstorm 2016.1注册码 当然推荐大家 ...