成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

SQLite開發中的Mermbership Provider

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

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

如果對SQLite本地數據庫開發和數據庫進行開發的過程不太了解可以參考我上一篇文章《SQLite開發準備》。

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

SQL文運行完,數據庫中就會創建出如下六張數據表:

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

而mascix所寫的代碼的精華都在App_Code文件夾下的代碼里,為了以后復用這套代碼,我決定創建一個單獨的C#工程命名為SQLiteProviders。

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

新建的工程需要引用:

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

編譯后創建一個新的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> 

添加對SQLiteProviders項目的引用,別忘了以鏈接文件引用SQLite.Interop.DLL(見《SQLite開發準備》一文)然后編譯Web應用程序。

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

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

 

【編輯推薦】

  1. CouchDB和SQLite聯合推出NoSQL查詢語言
  2. 在SQLite中通過Replace來實現插入和更新
  3. 微軟WP7本地數據庫之SQLite編程技巧
  4. 微軟WP7本機數據庫解決方案之SQLite
責任編輯:艾婧 來源: 博客園
相關推薦

2013-01-06 09:52:43

SQLite

2013-04-09 16:04:06

iOS開發SQLite知識總結

2013-04-01 10:49:51

iOS開發sqlite數據庫

2013-03-27 09:47:01

Android開發SQAndroid SDK

2011-08-01 10:21:01

SQLite

2011-08-22 16:26:25

IOS開發Sqlite數據庫

2013-01-06 12:23:59

Android開發SQLite數據庫

2009-11-18 16:43:59

2011-08-02 16:16:08

iPhone開發 SQLite 數據庫

2009-07-31 15:42:38

自定義providerASP.NET2.0

2011-08-09 13:22:31

iPhoneSqlite數據庫

2009-12-30 08:52:17

Ubuntu Tora

2013-01-10 14:39:28

Android開發Content Pro組件

2011-09-02 19:12:59

IOS應用Sqlite數據庫

2013-05-02 13:06:05

C++遇到iOS應用開SQLITE

2011-07-27 10:16:41

iPhone SQLite 數據庫

2023-09-21 07:06:17

PSDriveProvider

2025-02-27 08:15:28

2009-07-21 10:40:36

ASP.NET Pro

2011-07-04 17:45:45

Qt Sqlite 數據庫
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 午夜不卡一区二区 | 成人欧美一区二区三区在线观看 | 婷婷精品 | 黄色一级电影在线观看 | 久久午夜国产精品www忘忧草 | 色呦呦在线 | 日韩午夜精品 | 久草成人网 | 在线一区观看 | 国产激情视频网站 | av在线一区二区三区 | 91精品国产麻豆 | 亚洲一区二区三区在线播放 | 一级在线观看 | 色资源在线观看 | 在线观看深夜视频 | 国产成人一区二区 | 粉嫩av在线| 日韩一级免费观看 | 美女国产一区 | 国产区精品| 一级二级三级在线观看 | 久久人人网 | a在线免费观看 | 欧美成人精品在线 | 亚洲精品视频导航 | 一区二区三区久久 | 亚洲成人午夜电影 | 日韩三区在线 | 粉嫩粉嫩芽的虎白女18在线视频 | 国产精品1区2区 | 亚洲一区二区视频 | 日韩欧美在线观看视频 | 激情婷婷成人 | 精品久久影院 | 精品国产精品三级精品av网址 | 在线看av的网址 | 一区二区三区四区免费观看 | 一区二区三区日本 | 国产精品69毛片高清亚洲 | 亚洲va欧美va天堂v国产综合 |