博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
1. asp.net实现单点登陆
阅读量:6716 次
发布时间:2019-06-25

本文共 2631 字,大约阅读时间需要 8 分钟。

一、简单说明:

单点登录(Single Sign On)简称SSO,是目前比较流行的企业业务整合的解决方案之一。在开发企业门户网站或电子商务系统时,设计一个用户只能在同一个网站进行唯一登录的功能,可以避免一个用户名和密码在多个地址进行登录。

二、技术要点:

Cache对象主要用户Web应用程序的缓存,对于每个应用程序都需要创建Cache对象的一个实例,并且只要对应的应用程序域保持活动,该实例便保持有效,有段Cache对象实例的所有信息都需要通过HttpContext对象的Cache属性或Page对象的Cache属性来提供。

 

三、代码实现

 

using System; using System.Data; using System.Configuration; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.WebControls.WebParts; using System.Web.UI.HtmlControls; using System.Web.Caching; using System.Data.SqlClient; public partial class _Default : System.Web.UI.Page {
protected void Page_Load(object sender, EventArgs e) {
} protected void btnLogin_Click(object sender, EventArgs e) {
int i = this.checkLogin(txtName.Text, txtPwd.Text); if (i > 0) {
// 作为唯一标识的str_Key,应该是唯一的,这可根据需要自己设定规则。 // 做为测试,这里用用户名和密码的组合来做标识;也不进行其它的错误检查。 // 生成str_Key string str_Key = txtName.Text + "_" + txtPwd.Text; // 得到Cache中的给定str_Key的值 string str_User = Convert.ToString(Cache[str_Key]); // Cache中没有该str_Key的项目,表名用户没有登录,或者已经登录超时 if (str_User == String.Empty) {
// TimeSpan构造函数,用来重载版本的方法,进行判断是否登录。 TimeSpan SessTimeOut = new TimeSpan(0, 0, HttpContext.Current.Session.Timeout, 0, 0); HttpContext.Current.Cache.Insert(str_Key, str_Key, null, DateTime.MaxValue, SessTimeOut, CacheItemPriority.NotRemovable, null); Session["User"] = str_Key; // 首次登录成功 Response.Write("

你好,登录成功!"); } else {
// 在 Cache 中存在该用户的记录,表名已经登录过,禁止再次登录 Response.Write("

抱歉,您好像已经登录了!"); return; } } else {
Response.Write("用户名称或密码错误!!!"); } } protected void btnCandel_Click(object sender, EventArgs e) {
txtName.Text = ""; txtPwd.Text = ""; } public int checkLogin(string loginName, string loginPwd) {
SqlConnection con = new SqlConnection("Server=(local);database=db_18;Uid=sa;Pwd="); SqlCommand myCommand = new SqlCommand("select count(*) from 系统管理员表 where 用户名称=@loginName and 密码=@loginPwd", con); myCommand.Parameters.Add(new SqlParameter("@loginName", SqlDbType.NVarChar, 20)); myCommand.Parameters["@loginName"].Value = loginName; myCommand.Parameters.Add(new SqlParameter("@loginPwd", SqlDbType.NVarChar, 20)); myCommand.Parameters["@loginPwd"].Value = loginPwd; myCommand.Connection.Open(); int i = (int)myCommand.ExecuteScalar(); myCommand.Connection.Close(); return i; } }

转载地址:http://saxlo.baihongyu.com/

你可能感兴趣的文章
前端爬坑之旅--echarts渲染时canvas变为100px
查看>>
CODING 最佳实践:快课网研发效能提升之路
查看>>
实现一个平行四边形
查看>>
基于http协议使用protobuf进行前后端交互
查看>>
elasticsearch v6.5.4配置
查看>>
Python2+Selenium入门01-环境准备
查看>>
golang协程池设计
查看>>
android 中文字体向上偏移解决方案
查看>>
Project-Euler第69题
查看>>
Spring Cloud OAuth2 资源服务器CheckToken 源码解析
查看>>
jQuery DOM操作
查看>>
高频写入redis场景优化
查看>>
一直在做业务的程序员技术会进步吗?我们该如何跳出舒适圈
查看>>
Promise 源码分析
查看>>
mobx
查看>>
C++ Primer 第三章 学习笔记及习题答案
查看>>
Lodash学习小记
查看>>
webpack4 系列教程(十六):开发模式和生产模式·实战
查看>>
Elasticsearch 参考指南(查询和过滤器上下文)
查看>>
python 历险记——一个 Java 程序员的告白(一)
查看>>