微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

asp.net – 如何使用Membership API与自己的应用程序相关数据相结合?

在asp.net 4中设计一个新的应用程序我必须决定如何在MS sql数据库中使用MS sql Membership API和我自己的数据.首先,我需要以更灵活的方式存储和访问用户配置文件数据,然后配置文件提供程序支持.其次,我想链接其他用户相关信息(例如订单).

无论您在何处存储aspnetdb表(在单独的数据库中或与数据存储在同一数据库中),问题仍然存在于如何保持数据同步.

经过研究,我看到以下相关选项:
1.来自asp_Users的外键UserId(在this教程中建议).
2.没有外键 – 使用交易(建议here).
3.没有外键 – 使用自定义的AccountController(无论是什么,建议here).
4.将Membership UserId(uid)与自定义UserId(int)相链接的附加表.
5. …

一方面,我喜欢第一个解决方案,因为它非常简单,并在官方的asp.net教程中提出.

另一方面,反对者非常合理地指出,使用外键打破了提供者的一般想法,这些提供者应该帮助分离关注点并且可以互换.但不幸的是,他们并没有深入了解实施细节,因此从相关性和易于实施的角度来估计这些建议并不容易.

那么解决这个问题的最佳选择是什么?此外,实现将如何?仅仅使用额外的ADO.NET或LINQ等代码是否足够,还是值得实现自定义成员资格和/或配置文件提供程序?

先感谢您.

解决方法

第一种是最简单的方法.在相关表中添加用户的GUID作为外键(f.e.Ordered_by).我没有看到它打破分离问题的地方.如果您想将订单记录保存在数据库中,您还必须保留已订购的用户,这非常有意义.

我在当前的应用程序中成功使用了选项4.我创建了一个表aspnet_UserID,其中idUser int作为主键,fiUser(aspnet_Users的GUID)作为外键.这是模型:

(注意:User是通过aspnet_regsql.exe创建的标准aspnet_Users表,aspnet_UserId是我的自定义表,它将每个Guid映射到我的int-ID)

现在我只在所有相关表中存储我的idUser作为FK(如在Order-Table中).这样做的好处是存储空间更小,UserID更易读(我永远不会记住GUID).也许它与这个“包装表”有点分离,但这不是我的主要意图.

如果要控制行为,可以更改外键上的delete-rule.如果你是f.e.将它设置为Cascade.想删除您要删除用户订购的所有订单,或者如果要保留此订单,则将其设置为无操作.

我不能为配置文件问题提出任何替代方案,因为您没有提到“您需要以更灵活的方式存储和访问用户配置文件数据,而不是配置文件提供程序支持”.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


这篇文章主要讲解了“WPF如何实现带筛选功能的DataGrid”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“WPF...
本篇内容介绍了“基于WPF如何实现3D画廊动画效果”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这...
Some samples are below for ASP.Net web form controls:(from http://www.visualize.uk.com/resources/asp
问题描述: 对于未定义为 System.String 的列,唯一有效的值是(引发异常)。 For columns not defined as System.String, the only vali
最近用到了CalendarExtender,结果不知道为什么发生了错位,如图在Google和百度上找了很久,中文的文章里面似乎只提到了如何本地化(就是显示中文的月份)以及怎么解决被下拉框挡住的问题,谈
ASP.NET 2.0 page lifecyle ASP.NET 2.0 event sequence changed a lot since 1.1. Here is the order: App
静态声明: ' Style="position: relative" AppendDataBoundItems="True"> (无 或 空 或
以下内容是从网络上搜集资料,然后整理而来的。不当之处,请不吝指教。(The following were from network, and edited by myself. Thanks in a
Imports System Imports System.Reflection Namespace DotNetNuke '*********************************
Ok so you have all seen them: “8 million tools for web development”, “5 gagillion tools that if you