设为首页 收藏本站
查看: 1626|回复: 0

[经验分享] 使用MS sql CDC功能记录用户登录情况

[复制链接]

尚未签到

发表于 2018-10-20 09:46:39 | 显示全部楼层 |阅读模式
  本文部分内容转载自:追踪记录每笔业务操作数据改变的利器——SQLCDC
  http://www.cnblogs.com/artech/archive/2010/11/20/cdc.html
  SharePoint foundation使用form user的认证方式。最近企业开始了等保测评。其中有两个整改意见比较头疼:
  1、账号使用强壮型密码验证
  2、用户登录需要有审计日志
  第一点,formuser里通过webconfig的设置参数达到效果,具体可以看之前我的一篇文章
  SqlMembership参数说明  http://fishvsfrog.blog.51cto.com/388027/1927484
  第二点,头疼了
  刚开始有几个思路
  1、开启iis日志,然后开发个小程序进行数据提取和分析。
  需要代码开发,协调开发资源。中间成本过高
  2、开启SharePoint的审计功能
  SharePoint能通过配置开启针对列表、文档库的审计功能,wss需要通过命令行配合页面代码实现。开发量不是很大,但是和上面说的登录审计的需求有一些不匹配,感觉有点大材小用了。学过项目管理的应该明白,我们坚决不能“镀金”,不然怎么增长(pian)业务(qian)啊
DSC0000.gif

  一天,突发奇想,formuser是记录在ASP.NET membership的数据库里的。是否能通过sql存储过程或者触发器来记录每条user记录的改变呢?!
  下图问,ASP.NET membership数据表关系图,对比可以看出我们只要用到aspnet_usersaspnet_membership里面的信息就够了
DSC0001.jpg

  网上找资料,发现这个在Ms sql 2005时代是非常痛苦的,需要写很多触发器,而且影响数据库性能。而在2008以后,微软开启了CDC功能。简介如下:
  CDC的全名为Change Data Capture,顾名思义,就是用于追踪和捕捉数据改变。CDC是在SQL Server 2008中才出现的新特性,而这个特性则在很早之前就出现在了Oracle中。对于SQL Server之前版本来说,在没有CDC的情况下,如果需要记录基于某个数据表的数据改变,我们只能采用触发器,具体来说就是通过手工创建After Insert、After Update和After Delete触发器去记录变化的数据。而CDC给了我们一种更为方便、易用和省心的方式去记录某个数据表的历史操作。
  心中窃喜,我们用的是MS sql server 2008 R2。说干就干。
  第一步、准备工作
  1、确保SQL server版本在2008以上
  2、CDC功能是依赖于SQL agent服务的,确保开启
  第二步、开启数据库的CDC功能
  以数据库名称testDB为例子
Use TestDbGoExec sys.sp_cdc_enable_dbGo  检查是否开启,可以使用如下语句,0为未开启,1为开启:
DSC0002.png

  第三步、开启数据表的CDC功能
  
Use TestDbGoExec sys.sp_cdc_enable_table 'dbo', 'aspnet_Users', @role_name = NULLGoExec sys.sp_cdc_enable_table 'dbo', 'aspnet_Membership', @role_name = NULLGo  
  说明:数据表的CDC特性的开启通过执行sys.sp_cdc_enable_table存储过程实现。调用该存储过程的最简的方式就是指定数据表的Schema、名称和用于提取改变数据必须具有的权限(角色)。我通过执行下面的T-SQL将我们创建的Users表的CDC特性打开,其中@role_name参数被设置成NULL,表明我不对读取改变数据操作进行授权。sys.sp_cdc_enable_table具有很多参数,至于相应参数所影响的CDC行为,可以参考SQL Server 2008在线文档。
  第四步、完成,可以去找到对应CDC数据表看记录了
  完成后
  1、在SQL server代理项中,自动生成了2个作业
DSC0003.jpg

  2、在开启了CDC的数据库中,进入到系统表,可以看到CDC自动创建的跟踪记录表
DSC0004.jpg

  3、我们来查询一下
select userid,[__$operation],[LastLoginDate] from [sysystemaccount].[cdc].[dbo_aspnet_Membership_CT]
DSC0005.png 说明:

  __$operation字段为2表示的是“插入”操作,3表示的是修改之前的数据,4表示的是修改之后的数据
  第五步、后续
  数据表有了,自己输出的字段名称优化一下,一张完整登录日志就完成了,嵌入到html页面中,完美



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-623926-1-1.html 上篇帖子: SQL Server 2005 实例之间克隆帐号、密码 下篇帖子: sql按照in排序
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表