自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

SQLite開發(fā)中的Mermbership Provider

數(shù)據(jù)庫 其他數(shù)據(jù)庫
我們將mascix的代碼下載到本地打開,目錄中所見的ProviderSql.sql是Membership相關(guān)表的建表SQL文,我們使用SQLite Manager新建TestDatabas.sqlite數(shù)據(jù)庫。

偶然在CodeProject中發(fā)現(xiàn)土耳其人mascix已經(jīng)重寫了一套使用SQLite進(jìn)行用戶管理的Membership Provider,原文地址:http://www.codeproject.com/KB/aspnet/SQLiteProviders.aspx

如果對(duì)SQLite本地?cái)?shù)據(jù)庫開發(fā)和數(shù)據(jù)庫進(jìn)行開發(fā)的過程不太了解可以參考我上一篇文章《SQLite開發(fā)準(zhǔn)備》。

我們將mascix的代碼下載到本地打開,目錄中所見的ProviderSql.sql是Membership相關(guān)表的建表SQL文,我們使用SQLite Manager新建TestDatabas.sqlite數(shù)據(jù)庫。當(dāng)然我們也可以使用mascix在他的文章中推薦的SQLite Administrator來進(jìn)行數(shù)據(jù)庫的創(chuàng)建。

SQL文運(yùn)行完,數(shù)據(jù)庫中就會(huì)創(chuàng)建出如下六張數(shù)據(jù)表:

  • Roles
  • UsersInRoles
  • aspnet_applications
  • aspnet_profile
  • personalization
  • users

而mascix所寫的代碼的精華都在App_Code文件夾下的代碼里,為了以后復(fù)用這套代碼,我決定創(chuàng)建一個(gè)單獨(dú)的C#工程命名為SQLiteProviders。

并將App_Code代碼中的名稱空間都修改為SQLiteProviders(這里刪除了mascix.前綴,并不是忽視版權(quán)而是為了遵守代碼規(guī)范)。

新建的工程需要引用:

  • System.Web
  • System.Data.SQLite.DLL
  • System.Web.ApplicationServices
  • System.Security

編譯后創(chuàng)建一個(gè)新的Web工程,修改web.config代碼如下:

  1. <?xml version="1.0"?> 
  2. <configuration xmlns="http://schemas.microsoft.com/.NetConfiguration/v2.0"> 
  3.   <appSettings/> 
  4.   <connectionStrings> 
  5.     <add name="ConnString" 
  6.          connectionString="Data Source=|DataDirectory|users.sqlite;Version=3;" /> 
  7.   </connectionStrings> 
  8.   <system.web> 
  9.     <authorization> 
  10.       <deny roles="Admin" /> 
  11.     </authorization> 
  12.     <authentication mode="Forms" /> 
  13.     <compilation debug="true"> 
  14.     </compilation> 
  15.     <roleManager 
  16.       defaultProvider="SQLiteRoleProvider" 
  17.       enabled="true" 
  18.       cacheRolesInCookie="true" 
  19.       cookieName=".ASPROLES" 
  20.       cookieTimeout="30" cookiePath="/" 
  21.       cookieRequireSSL="false" 
  22.       cookieSlidingExpiration="true" 
  23.       cookieProtection="All"> 
  24.       <providers> 
  25.         <clear/> 
  26.         <add 
  27.           name="SQLiteRoleProvider" 
  28.           type="SQLiteProviders.SQLiteRoleProvider" 
  29.           connectionStringName="ConnString" 
  30.           applicationName="CoolSpirit" 
  31.           writeExceptionsToEventLog="true"/> 
  32.       </providers> 
  33.     </roleManager> 
  34.     <membership defaultProvider="SQLiteMembershipProvider" 
  35.                 userIsOnlineTimeWindow="15"> 
  36.       <providers> 
  37.         <clear/> 
  38.         <add 
  39.           name="SQLiteMembershipProvider" 
  40.           type="SQLiteProviders.SqliteMembershipProvider" 
  41.           connectionStringName="ConnString" 
  42.           applicationName="CoolSpirit" 
  43.           enablePasswordRetrieval="false" 
  44.           enablePasswordReset="true" 
  45.           requiresQuestionAndAnswer="false" 
  46.           requiresUniqueEmail="true" 
  47.           passwordFormat="Hashed" 
  48.           writeExceptionsToEventLog="true"/> 
  49.       </providers> 
  50.     </membership> 
  51.  
  52.     <profile defaultProvider="SQLiteProfileProvider"> 
  53.       <providers> 
  54.         <clear/> 
  55.         <add 
  56.           name="SQLiteProfileProvider" 
  57.           type="SQLiteProviders.SQLiteProfileProvider" 
  58.           connectionStringName="ConnString" 
  59.           applicationName="CoolSpirit"/> 
  60.       </providers> 
  61.       <properties/> 
  62.     </profile> 
  63.     <webParts> 
  64.       <personalization defaultProvider="personalizationProvider"> 
  65.         <providers> 
  66.           <clear /> 
  67.           <add name="personalizationProvider" 
  68.                type="SQLiteProviders.SQLitePersonalizationProvider" 
  69.                connectionStringName="ConnString" 
  70.                applicationName="CoolSpirit" 
  71.                description="SQLite Personalization Provider" 
  72.                /> 
  73.         </providers> 
  74.       </personalization> 
  75.     </webParts> 
  76.   </system.web> 
  77. </configuration> 

添加對(duì)SQLiteProviders項(xiàng)目的引用,別忘了以鏈接文件引用SQLite.Interop.DLL(見《SQLite開發(fā)準(zhǔn)備》一文)然后編譯Web應(yīng)用程序。

編譯通過后,在Visual Studio的菜單“項(xiàng)目”-“ASP.NET配置”,即可打開ASP.NET配置站點(diǎn),在安全鏈接的右側(cè),如果能看見“使您能夠設(shè)置和編輯用戶、角色和對(duì)站點(diǎn)的訪問權(quán)限。 現(xiàn)有用戶: 0 ”的字樣即代表配置成功,隨后可以像ASP.NET Membership Provider一樣通過登陸控件等實(shí)現(xiàn)系統(tǒng)登陸、用戶注冊(cè)、用戶和角色管理等功能了。

原文鏈接:http://www.cnblogs.com/richardc2k/archive/2011/07/30/2121961.html

 

【編輯推薦】

  1. CouchDB和SQLite聯(lián)合推出NoSQL查詢語言
  2. 在SQLite中通過Replace來實(shí)現(xiàn)插入和更新
  3. 微軟WP7本地?cái)?shù)據(jù)庫之SQLite編程技巧
  4. 微軟WP7本機(jī)數(shù)據(jù)庫解決方案之SQLite
責(zé)任編輯:艾婧 來源: 博客園
相關(guān)推薦

2013-01-06 09:52:43

SQLite

2013-04-09 16:04:06

iOS開發(fā)SQLite知識(shí)總結(jié)

2013-04-01 10:49:51

iOS開發(fā)sqlite數(shù)據(jù)庫

2013-03-27 09:47:01

Android開發(fā)SQAndroid SDK

2011-08-01 10:21:01

SQLite

2011-08-22 16:26:25

IOS開發(fā)Sqlite數(shù)據(jù)庫

2013-01-06 12:23:59

Android開發(fā)SQLite數(shù)據(jù)庫

2009-11-18 16:43:59

2011-08-02 16:16:08

iPhone開發(fā) SQLite 數(shù)據(jù)庫

2009-07-31 15:42:38

自定義providerASP.NET2.0

2013-01-10 14:39:28

Android開發(fā)Content Pro組件

2011-08-09 13:22:31

iPhoneSqlite數(shù)據(jù)庫

2009-12-30 08:52:17

Ubuntu Tora

2011-09-02 19:12:59

IOS應(yīng)用Sqlite數(shù)據(jù)庫

2011-07-27 10:16:41

iPhone SQLite 數(shù)據(jù)庫

2013-05-02 13:06:05

C++遇到iOS應(yīng)用開SQLITE

2023-09-21 07:06:17

PSDriveProvider

2009-07-21 10:40:36

ASP.NET Pro

2025-02-27 08:15:28

2011-07-04 17:45:45

Qt Sqlite 數(shù)據(jù)庫
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)