ASP.NET连接LDAP数据库的有关信息

一、封装在DAL层中的获取用户信息的函数

/// <summary>

/// 按照用户Id查找用户信息

/// </summary>

/// <param name="userId"></param>

/// <returns></returns>

publicDirectoryEntry GetUser(string username)

{

string path = System.Configuration.ConfigurationManager.ConnectionStrings["path"].ConnectionString;

string pname = System.Configuration.ConfigurationManager.ConnectionStrings["pname"].ConnectionString;

string pwd = System.Configuration.ConfigurationManager.ConnectionStrings["pwd"].ConnectionString;

// 3个连接数据库的信息写在配置文件里

DirectoryEntry  deuser;  //定义变量

try

{

DirectoryEntry de = newDirectoryEntry (path, pname, pwd, AuthenticationTypes.Secure);

DirectorySearcher deSearch = newDirectorySearcher(de); //连接LDAP数据库

deSearch.Filter = "(&(objectClass=userinfo)(LOGINNAME=" + username + "))";  //筛选比对

//上面这句话修改为:mySearcher.Filter = "(&(objectClass=userinfo)(&(LOGINNAME=" + txtUserId.Text + ")(LOGINPASSWORD=" + txtUserPwd.Text + ")))";//作为登录是用户帐号和密码认证

deSearch.SearchScope = SearchScope.Subtree;

SearchResult result = deSearch.FindOne(); //筛选比对得出一个结果,存储在result中

if (result != null)

{

deuser = result.GetDirectoryEntry(); //得到筛选结果,并赋值给deuser中

return deuser;

}

else

{

returnnull;

}

}

catch(Exception ex)

{

// LogManage.SaveInfo(ex.ToString());

returnnull;

}

二、配置文件信息

<connectionStrings>

<add name="path"

connectionString="LDAP://192.168.1.1/OU=123,DC=123,DC=COM" />

<add name="pname"

connectionString="123" />

<add name="pwd"

connectionString="123" />

</connectionStrings>

三、实现层

1、页面信息

用户id:(textbox框)

用户名称:(textbox框)
用户密码:(textbox框)
电子邮箱:(textbox框)
ButtonID="butquchu"(读取数据按钮)

2、事件函数代码

protectedvoid butquchu_Click(object sender, EventArgs e)

{

ldapDAO ld= newldapDAO ();

string username = Session["LOGINNAME"].ToString(); //根据上一页的登录信息获取用户帐号,存储在session中。

labname.Text = username;

DirectoryEntry de = ld.GetUser(username); //调用ldapDAO中的获取用户信息函数

if (de != null)

{

if (de != null)

{

if (de.Properties["USERID"].Value != null)

{

txtuserid.Text = de.Properties["USERID"].Value.ToString();

}

if (de.Properties["LOGINNAME"].Value != null)

{

txtusername.Text = de.Properties["LOGINNAME"].Value.ToString();

}

if (de.Properties["LOGINPASSWORD"].Value != null)

{

txtpwd.Text = de.Properties["LOGINPASSWORD"].Value.ToString();

}

if (de.Properties["EMAIL"].Value != null)

{

txtmail.Text = de.Properties["EMAIL"].Value.ToString();

}

}

asp.net连接LDAP数据,并从LDAP中取出相关数据(1)的更多相关文章

  1. 从JSON数据中取出相关数据

    参考: http://www.cnblogs.com/shuilangyizu/p/6019561.html JSON数据如下: { "total": 1, "rows& ...

  2. (26)ASP.NET Core EF保存(基本保存、保存相关数据、级联删除、使用事务)

    1.简介 每个上下文实例都有一个ChangeTracker,它负责跟踪需要写入数据库的更改.更改实体类的实例时,这些更改会记录在ChangeTracker中,然后在调用SaveChanges时会被写入 ...

  3. 大数据系列-CDH环境中SOLR入数据

    1       创建集合 SSH远程连接到安装了SOLR的CDH节点. 运行solrctl  instancedir  --generate  /solr/test/GX_SH_TL_TGRYXX_2 ...

  4. for循环中进行联网请求数据、for循环中进行异步数据操作,数据排序错乱问题解决;

    for循环中进行联网请求数据,由于网络请求是异步的,第一个网络请求还没有回调,第二次第三次以及后续的网络请求又已经发出去了,有可能后续的网络请求会先回调:这时我们接收到的数据的排序就会错乱:怎么才能让 ...

  5. 利用excel数据透视表实现快速统计相关数据

    昨天ytkah在做数据报表时需要做一些具体统计数字:公司每天都有人申请铅笔.笔记本等一些文具用品,现在想要统计每天申请铅笔多少支.笔记本多少本,如下图所示,这个要如何实现呢? excel数据透视表怎么 ...

  6. [python]mysql数据缓存到redis中 取出时候编码问题

    描述: 一个web服务,原先的业务逻辑是把mysql查询的结果缓存在redis中一个小时,加快请求的响应. 现在有个问题就是根据请求的指定的编码返回对应编码的response. 首先是要修改响应的bo ...

  7. 【记录】T-SQL 分组排序中取出最新数据

    示例 Product 表结构: 示例 Product 表数据: 想要的效果是,以 GroupName 字段分组,取出分组中通过 Sort 降序最新的数据,通过示例数据,可以推算出结果数据的 ID 应该 ...

  8. [Tips]ASP.NET MVC 发布到服务器后Model中属性相关的Attribute失效

    Asp.net MVC4 开发的项目,发布到真实环境环境后Model中的一个属性设置的了Attribute,但是这些Attribute都失效. 经过对比和坚持代码发现控制长度的Attribute使用错 ...

  9. sqoop导入数据到hive表中的相关操作

    1.使用sqoop创建表并且指定对应的hive表中的字段的数据类型,同时指定该表的分区字段名称 sqoop create-hive-table --connect "jdbc:oracle: ...

随机推荐

  1. Mac 终端自动补全忽略大小写

    打开终端,输入:nano .inputrc 在里面粘贴上以下语句: set completion-ignore-case onset show-all-if-ambiguous onTAB: menu ...

  2. git中如何查看一个文件的修改(更新)历史

    有些时候有些文件或文件夹被移除了, 或者更换了路径或被改名了, 想跟踪一下这个文件被修改(更新)的历史, 可以用如下命令: git log -p matser -- filename 格式是: git ...

  3. 第一天开始使用Oracle

    上半年虽然已经学习了Oracle,但是基本上实验课都没怎么实践过,感觉自己之前过得太水了! 在我的印象里,Oracle 的难度相当于工程师的建设一个亚洲最大的医院一样,也如医生的99%失败率的手术: ...

  4. spring-mybatis.xml配置

    1.自动扫描 <context:component-scan base-package="com.javen" /> 2.引入配置文件 <bean id=&quo ...

  5. ssh连接不上排查方法总结

    //常见报错信息 # No route to host --> server端没有开机或是网络不通(这个原因很多,最简单的是网线没有插.还有就是可能会是网卡down了等) 如果是网卡down了i ...

  6. TCP的状态兼谈Close_Wait和Time_Wait的状态

    原文链接: http://www.2cto.com/net/201208/147485.html TCP的状态兼谈Close_Wait和Time_Wait的状态   一 TCP的状态: 1).LIST ...

  7. MemCached缓存操作

    Web项目在运行时,通常需要从数据库中进行读写.随着操作数据量的增大,以及访问量的集中,数据库的负载增加,数据库响应变慢,网站访问速度变慢的情况.Memcached就是用来解决这些问题的. Memca ...

  8. nginx 服务器篇

    Nginx 服务器类型 1. Web服务器 Web服务器用于提供HTTP(包括HTTPS)的访问,例如Nginx.Apache.IIS等. 2. 应用程序服务器 应用程序服务器能够用于应用程序的运行, ...

  9. 后门技术和Linux LKM Rootkit详解

    2010-01-15 10:32 chinaitlab chinaitlab 字号:T | T 在这篇文章里, 我们将看到各种不同的后门技术,特别是 Linux的可装载内核模块(LKM). 我们将会发 ...

  10. 20165301 2017-2018-2 《Java程序设计》第三周学习总结

    20165301 2017-2018-2 <Java程序设计>第三周学习总结 教材学习内容总结 第四章:类与对象 类: 类的声明:class+类名 类体:成员变量的声明+方法(局部变量+语 ...