精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

淺析SQL Server 2008中的代碼安全之一:存儲過程加密與安全上下文

數據庫 SQL Server
編者最近對SQL Server 2008的安全入門略作小結,以作備忘。本文主要是針對存儲過程加密與安全上下文 來作分析。

最近對SQL Server 2008的安全入門略作小結,以作備忘。本文主要是針對存儲過程加密與安全來作分析。

<一>存儲過程加密

其實,用了這十多年的SQL server,我已經成了存儲過程的忠實擁躉。在直接使用SQL語句還是存儲過程來處理業務邏輯時,我基本會毫不猶豫地選擇后者。

理由如下:

1、使用存儲過程,至少在防非法注入(inject)方面提供更好的保護。因為,存儲過程在執行前,首先會執行預編譯,(如果由于非法參數的原因)編譯出錯則不會執行,這要某種程度上提供一層天然的屏障。

我至今還記得大約八、九年前采用的一個權限控制系統就是通過拼湊一個SQL語句,最終得到了一個形如“ where 1=1 and dataID in (1,2) and ModelID in (2,455) And ShopID in (111) and departID in ( 1,3) and ([Name] like %myword%) ”的where條件子句來獲取符合條件的結果集。

注意:這個參數是通過地址欄web應用的地址欄或Winform的UI界面來輸入的,所以對惡意注入需要花費一定的成本來維護。因為一些常用的關鍵字(或敏感詞)很難區分是惡意或非惡意。

2、使用存儲過程而不是直接訪問基表,可以提供更好的安全性。你可以在行級或列級控制數據如何被修改。相對于表的訪問,你可以確認有執行權限許可的用戶執行相應的存儲過程。這也是訪問數據服務器的惟一調用途徑。因此,任何偷窺者將無法看到你的SELECT語句。換句話說,每個應用只能擁有相應的存儲過程來訪問基表,而不是“SLEECT *”。

3、存儲過程可以加密。(這點非常實用,設想一下,您的數據庫服務器是托管的或租用的,你是否能心安理得的每天睡個安穩覺。如果競爭對手“一不小心”登上你的SQL Server,或通過注入得到了你的存儲過程,然后相應的注入惡意的SQL,將您的業務邏輯亂改一通,而恰巧您五分鐘前又沒做備份,那會怎么樣?)

(注意:加密存儲過程前應該備份原始存儲過程,且加密應該在部署到生產環境前完成。)

存儲過程的加密非常簡單,我們看一個例子:

插入測試表

  1. use testDb2  
  2. go  
  3. /**********測試表*****************/  
  4. SET ANSI_PADDING ON 
  5. GO  
  6. CREATE TABLE [dbo].[tb_demo](      
  7. [id] [intNOT NULL,      
  8. [submitdate] [datetime] NULL,      
  9. [commment] [nvarchar](200) NULL,  
  10. )  
  11. GO  
  12. SET ANSI_PADDING OFFGO  
  13. Insert into [tb_demo]  
  14. select 1024, getdate(),REPLICATE('A',100);  
  15. WAITFOR DELAY '00:00:04';  
  16. Insert into [tb_demo]  
  17. select 1024, getdate(),REPLICATE('B',50);  
  18. go 

插入存儲過程

  1. /***************創建未加密的存儲過程*******************/  
  2. Create Procedure CPP_test_Original  
  3. AS 
  4. select * from [tb_demo]  
  5. go  
  6. /***************創建加密的存儲過程*******************/  
  7. Create Procedure CPP_test_Encryption   
  8. with encryption  
  9. AS 
  10. ----可以換成任意的邏輯  
  11. execute CPP_test_Original  
  12. go 

未加密的存儲過程:

 

加密的存儲過程:

 

此時,至少,存儲過程的內容不會被輕易看到(雖然解密也是有可能的)。應用這個,我們可以對某些關鍵的存儲過程進行加密。但此時,存儲過程仍然能被execute、alter和drop

<二>安全上下文

除了加密sql文本的內容,我們還可以使用EXECUTE AS 子句設定存儲過程的安全上下文,以滿足不同的安全級別需求。

如果你對這些不感興趣,請直接路過帶下劃線的段落。

(關于EXECUTE AS 子句的詳細用法,請參看MSDN:http://msdn.microsoft.com/zh-cn/library/ms188354.aspx)

此處,我們需要了解的是:

1、在 SQL Server 中,可以定義以下用戶定義模塊的執行上下文:函數(內聯表值函數除外)、過程、隊列和觸發器。

通過指定執行模塊的上下文,可以控制數據庫引擎使用哪一個用戶帳戶來驗證對模塊引用的對象的權限。這有助于人們更靈活、有力地管理用戶定義的模塊及其所引用對象所形成的對象鏈中的權限。必須而且只需授予用戶對模塊自身的權限,而無需授予用戶對被引用對象的顯式權限。只有運行模塊的用戶必須對模塊訪問的對象擁有權限。

針對函數、過程、隊列和觸發器,對應的參數也不同。存儲過程對應的參數包括(CALLER | SELF | OWNER | 'user_name')。

CALLER      指定模塊內的語句在模塊調用方的上下文中執行。執行模塊的用戶不僅必須對模塊本身擁有適當的權限,還要對模塊引用的任何數據庫對象擁有適當權限。 CALLER 是除隊列外的所有模塊的默認值,與 SQL Server 2005 行為相同。 CALLER 不能在 CREATE QUEUE 或 ALTER QUEUE 語句中指定。
SELF         EXECUTE AS SELF 與 EXECUTE AS user_name 等價,其中指定用戶是創建或更改模塊的用戶。創建或更改模塊的用戶的實際用戶 ID 存儲在 sys.sql_modulessys.service_queues 目錄視圖的 execute_as_principal_id 列中。SELF 是隊列的默認值。
OWNER     指定模塊內的語句在模塊的當前所有者上下文中執行。如果模塊沒有指定的所有者,則使用模塊架構的所有者。不能為 DDL 或登錄觸發器指定 OWNER。注意:OWNER 必須映射到單獨帳戶,不能是角色或組。
'user_name'   指定模塊內的語句在 user_name 指定的用戶的上下文中執行。將根據 user_name 來驗證對模塊內任意對象的權限。不能為具有服務器作用域的 DDL 觸發器或登錄觸發器指定 user_name。請改用 login_name。user_name 必須存在于當前數據庫中,并且必須是單獨帳戶。user_name 不能是組、角色、證書、密鑰或內置帳戶,如 NT AUTHORITY\LocalService、NT AUTHORITY\NetworkService 或 NT AUTHORITY\LocalSystem。執行上下文的用戶 ID 存儲在元數據中,可以在 sys.sql_modules 或 sys.assembly_modules 目錄視圖的 execute_as_principal_id 列查看。

2、所有權鏈具有以下限制:

僅適用于 DML 語句:SELECT、INSERT、UPDATE 和 DELETE

調用和被調用對象的所有者必須相同。

不適用于模塊內的動態查詢。

我們看一個示例:
第一步、創建一個測試存儲過程,用來delete表tb_Demo的所有數據
  1. USE testDb2  
  2. GO  
  3. CREATE PROCEDURE dbo.[CPP_DEL_ALL_Tb_Demo]  
  4. AS 
  5. -- Deletes all rows prior to the data feed  
  6. DELETE dbo.[tb_Demo]  
  7. GO 
第二步:創建一個賬號TonyZhang,并賦于該賬號對該存儲過程的exec權限

  1. USE master  
  2. GO  
  3. CREATE LOGIN TonyZhang WITH PASSWORD = '123b3b4' 
  4. USE testDb2  
  5. GO  
  6. CREATE USER TonyZhang  
  7. GO  
  8. GRANT EXEC ON dbo.[CPP_DEL_ALL_Tb_Demo] to TonyZhang 

以該賬號登錄SQL Server,并執行:

  1. EXECUTE dbo.CPP_DEL_ALL_Tb_Demo  
  2. /**  
  3. (4 row(s) affected)  
  4. **/ 

注意:此時,雖然TonyZhang除了執行存儲過程[CPP_DEL_ALL_Tb_Demo]之外沒有任何其他權限,但仍然執行了存儲過程,并刪除了表記錄。
如果我們修改存儲過程為:

  1. Alter PROCEDURE dbo.[CPP_DEL_ALL_Tb_Demo]  
  2. AS 
  3. -- Deletes all rows prior to the data feed  
  4. truncate table dbo.[tb_Demo]  
  5. GO 

此時,再以TonyZhang登錄,并執行存儲過程,會提示: 

這是因為所有者權鏈只限定SELECT、INSERT、UPDATE 和 DELETE。而不包括Truncate,換句話說,系統授于的Exec只既定于SELECT、INSERT、UPDATE 和 DELETE

有人可能會問:如果在存儲過程內部調用動態語句,而不是明確的表名,我們如何限定權限呢?
第三步:我們建立一個存儲過程,功能是傳入一個參數表名,查詢該表的記錄數。

  1. CREATE PROCEDURE dbo.[CPP_SEL_CountRowsFromAnyTable]  
  2. @SchemaAndTable nvarchar(255)  
  3. AS 
  4. EXEC ('SELECT COUNT(1) FROM ' + @SchemaAndTable)  
  5. GO 

授于Tonyzhang 以執行該存儲過程的權限:

  1. GRANT EXEC ON dbo.[CPP_SEL_CountRowsFromAnyTable] to TonyZhang  
  2. go 

此時,以Tonyzhang登錄,執行存儲過程,會提示:

注意,此時,tonyzhang雖然有執行存儲過程的權限,但是沒有參數表的select權限,所以執行失敗
第四步:修改存儲過程的上下文
創建一個新賬號jackwang,賦于表tb_Demo的select權限

  1. USE master  
  2. GO  
  3. CREATE LOGIN JackWang WITH PASSWORD = '123b3b4' 
  4. USE Testdb2  
  5. GO  
  6. CREATE USER JackWang  
  7. GRANT SELECT ON OBJECT::dbo.[tb_Demo] TO JackWang  
  8. GO  
  9. /*******  
  10. 注意:此時,JackWang 可以執行dbo.[tb_Demo的Select   
  11. *******/ 

修改存儲的執行者

  1. USE Testdb2  
  2. GO  
  3. alter PROCEDURE dbo.[CPP_SEL_CountRowsFromAnyTable]  
  4. @SchemaAndTable nvarchar(255)  
  5. WITH EXECUTE AS 'JackWang' 
  6. AS 
  7. EXEC ('SELECT COUNT(1) FROM ' + @SchemaAndTable)  
  8. GO 

注意:這樣,我們再調用存儲過程[CPP_SEL_CountRowsFromAnyTable]時,會自動以JackWang的身份運行該存儲過程。
此時,我們仍以Tonyzhang登錄,再執行:

小結:
本文通過簡單的兩個示例開始SQL server代碼的安全之旅,
1、存儲過程的加密,(注意:加密存儲過程前應該備份原始存儲過程,且加密應該在部署到生產環境前完成。
2、存儲過程的安全上下文。可以通過上下文設置更加嚴格的數據訪問級別。(主要是對SELECT、INSERT、UPDATE 和 DELETE語句的訪問限制

后續部分將會涉及SQL server 2008新增的透明加密(TDE)功能。

原文鏈接:http://www.cnblogs.com/downmoon/archive/2011/02/28/1966662.html

【編輯推薦】

  1. SQL Server 2005數據庫SA的相關安全性設置
  2. SQL Server與Oracle數據庫在安全性上的異同
  3. Sql server安全設置九大措施
  4. SQL Server安全解析
  5. sql server安全的兩層模型
責任編輯:艾婧 來源: 博客園
相關推薦

2011-03-16 08:42:22

SQL Server證書加密

2011-03-15 09:51:09

2011-03-18 09:11:14

SQL Server透明加密

2011-03-03 10:45:51

2012-12-31 10:01:34

SELinuxSELinux安全

2011-03-14 10:38:10

SQL Server非對稱密鑰加密

2011-03-14 15:06:49

SQL Server 安全

2011-03-10 15:03:40

SQL Server主密鑰

2017-05-11 14:00:02

Flask請求上下文應用上下文

2011-03-18 10:27:00

SQL Server目錄索引

2011-08-19 11:26:41

SQL Server 主密鑰

2010-07-15 12:38:14

SQL Server存

2011-03-03 09:30:24

downmoonsql登錄觸發器

2009-04-16 17:34:19

2023-03-17 08:04:15

云存儲安全Veritas

2009-02-16 16:10:49

安全審計安裝SQL Server

2009-04-16 18:25:55

2011-09-01 15:40:42

SQL Server存儲過程和存儲函數的加

2011-09-01 17:25:03

SQL Server 查看死鎖存儲過程

2011-02-28 13:19:50

SQL Server SQL死鎖
點贊
收藏

51CTO技術棧公眾號

一区二区三区日韩| 久久人人精品| 精品国产免费一区二区三区香蕉| 国产精品久久久久久久乖乖| 午夜激情小视频| 男男视频亚洲欧美| 欧美国产精品日韩| 魔女鞋交玉足榨精调教| 日韩亚洲国产免费| 欧美午夜视频一区二区| 一区二区三区av在线| 欧美自拍偷拍一区二区| 奇米精品一区二区三区在线观看一 | 黄色高清无遮挡| 国产三区视频在线观看| 91浏览器在线视频| 97av影视网在线观看| 一级片免费在线播放| 欧美激情第10页| 一区二区日韩精品| 国产美女视频免费观看下载软件| 成人黄色在线| 欧美午夜片在线免费观看| 精品无码av无码免费专区| 国产精品天堂| 99久久精品国产网站| 成人黄色免费在线观看| 成人av网站在线播放| 亚洲高清在线| 久久99热精品这里久久精品| 中国特黄一级片| 你懂的视频欧美| 欧美军同video69gay| 99精品免费在线观看| 91美女精品| 亚洲亚洲人成综合网络| 九九精品在线视频| 欧美尤物巨大精品爽| 中文字幕av久久爽一区| 一区二区美女| 亚洲国产精品成人一区二区| 欧美性猛交xx| 91九色成人| 欧美高清一级片在线| 九色porny91| 日韩一级二级 | 国产黄色片免费在线观看| 免费a级毛片在线播放| 国产欧美精品国产国产专区| 欧美日韩精品久久| 九色视频在线观看免费播放| 久久久久久麻豆| 精品视频一区在线| 少妇又色又爽又黄的视频| 福利一区在线观看| 国产伦理一区二区三区| 三级网站在线看| 99久久久久久| 免费在线一区二区| 国产一区二区三区福利| 国产亚洲欧美一级| 深夜福利成人| 欧美一区二区三区在线观看免费| 国产精品无码永久免费888| 日韩av高清在线播放| 在线观看免费版| 一区精品在线播放| 天堂av在线中文| 欧美极品少妇videossex| 亚洲亚洲精品在线观看| 日本精品一区在线观看| 美女网站视频一区| 欧美日韩一区二区三区免费看| 色综合色综合色综合色综合| 久久免费福利| 亚洲第一区在线| 亚洲a v网站| 久久亚洲影视| 欧美激情一区二区三区高清视频| 欧美日韩乱国产| 美女一区二区视频| 99爱精品视频| 精品视频一二三| 亚洲人成网站色在线观看| 激情五月婷婷六月| 345成人影院| 欧美美女一区二区在线观看| 国产免费无码一区二区| 深爱激情综合| 欧美成人全部免费| 国产又大又粗又爽| 国产资源在线一区| 久久久久久九九九九| 日本激情在线观看| 亚洲成人免费观看| 最近中文字幕一区二区| 一区二区三区在线免费看| 亚洲精品自拍第一页| 国产又粗又猛又爽又黄的视频四季 | 亚洲精品wwwww| 人成免费在线视频| 在线国产欧美| 成人美女免费网站视频| 性xxxx搡xxxxx搡欧美| 中文字幕在线不卡视频| 大肉大捧一进一出好爽视频| 国产成人免费视频网站视频社区| 日韩黄色高清视频| 高h视频免费观看| 日本美女一区二区| 精品国产乱码久久久久久丨区2区 精品国产乱码久久久久久蜜柚 | 欧美日韩人妻精品一区二区三区 | 亚洲国产精品精华液网站| 丁香婷婷激情网| 日韩精选在线| 久久久久国产视频| 国产视频手机在线| 国产精品女人毛片| 久久综合久久色| 久久影院资源站| 精品中文字幕在线观看| 亚洲综合精品国产一区二区三区| 91啪亚洲精品| 亚洲国产精品成人天堂| 久久伊人影院| 精品国偷自产在线| 在线免费看91| 国产日韩影视精品| 黄色a级片免费| 欧美成人午夜77777| 欧美老肥婆性猛交视频| 依依成人在线视频| 国产午夜亚洲精品不卡| 久久婷婷国产精品| 欧美午夜寂寞| 国内免费久久久久久久久久久| 性一交一乱一精一晶| 亚洲人被黑人高潮完整版| 天天色天天综合网| 四虎成人av| 成人午夜激情网| 日本美女在线中文版| 欧美日韩精品一区二区三区蜜桃 | 欧美a级一区| 91在线直播亚洲| 国产午夜精品久久久久免费视| 精品婷婷伊人一区三区三| 国产伦精品一区二区三区视频女| 天堂午夜影视日韩欧美一区二区| 欧美激情专区| av成人免费| 精品国产一区二区三区在线观看| 亚洲天堂2021av| 中文字幕亚洲精品在线观看| 中文字幕第66页| 午夜欧美精品| 国产视频一区二区三区四区| av小说在线播放| 日韩av在线免费| 亚洲精品中文字幕乱码三区91| 久久婷婷色综合| 久久九九国产视频| 欧美aaaa视频| 99在线国产| 涩涩视频在线播放| 中文字幕日本欧美| 99精品国产99久久久久久97| 亚洲综合色在线| 黄色片视频免费观看| 久久久成人网| 亚洲午夜精品一区二区三区| 久久影院一区二区三区| 午夜精品三级视频福利| 九色网友自拍视频手机在线| 欧美欧美午夜aⅴ在线观看| 欧美日韩一级大片| av资源网一区| 99re精彩视频| 亚洲五月婷婷| 亚洲国产日韩欧美| 日本精品在线观看| 欧日韩不卡在线视频| av资源在线观看免费高清| 欧美一区二区日韩| 中文字幕超碰在线| 国产精品污污网站在线观看 | 高潮久久久久久久久久久久久久| 青青草原成人在线视频| 欧美性videos| 日韩国产精品亚洲а∨天堂免| 欧美成人一区二区视频| 亚洲一区二区高清| 无码人妻丰满熟妇啪啪欧美| 国产91精品一区二区麻豆网站| 大肉大捧一进一出好爽动态图| 亚洲一级淫片| 欧美日韩电影一区二区| 久久亚洲精精品中文字幕| 国产成人精品久久| 青青在线视频| 色婷婷av一区二区三区在线观看 | 男人天堂1024| 欧美1区视频| 日韩三级电影免费观看| eeuss鲁片一区二区三区| 国产精品丝袜白浆摸在线 | 国产精品九九视频| 精品午夜一区二区三区在线观看| 欧美 日韩 国产在线观看| 伊人色**天天综合婷婷| 日本亚洲欧洲精品| 久久亚州av| yy111111少妇影院日韩夜片| 成人性片免费| 日韩av免费在线看| 日本成人不卡| 久久久国产一区二区| av片在线免费观看| 亚洲欧美成人精品| 天天干在线观看| 精品久久国产97色综合| 国产喷水吹潮视频www| 欧美日韩在线播| 黄色av网站免费观看| 性久久久久久久久| 久久久久免费看| 亚洲视频在线观看三级| 91免费在线看片| 欧美极品美女视频| 91精品国自产在线| 中文字幕欧美日韩一区| 国产精品成人一区二区三区电影毛片| 成人的网站免费观看| 成年人看片网站| 国产电影精品久久禁18| 日韩精品视频网址| 国产精品一区二区久久精品爱涩| 日本高清久久久| 理论电影国产精品| 99国产精品久久久久久| 久久成人免费电影| 日本一二三四区视频| 国产在线麻豆精品观看| 日韩欧美亚洲另类| 精品在线你懂的| 亚洲妇熟xx妇色黄蜜桃| 国产在线播放一区| 九九九久久久久久久| 国产精品一区久久久久| 日本中文字幕在线不卡| 丁香一区二区三区| 亚州av综合色区无码一区| av网站一区二区三区| 88av在线播放| 久久综合色婷婷| 国产精品国产三级国产专业不| 欧美国产1区2区| 999精品在线视频| 亚洲免费在线看| 国产无码精品视频| 日韩欧美一区二区三区久久| 波多野结衣mp4| 欧美日韩的一区二区| 国产男男gay体育生网站| 日韩欧美视频一区| 亚洲av成人无码网天堂| 国产亚洲福利一区| caopen在线视频| 91产国在线观看动作片喷水| 性感美女一区二区在线观看| 国产日韩在线亚洲字幕中文| 一区二区三区高清在线观看| 欧美精品亚洲精品| 色婷婷一区二区三区| 国产毛片久久久久久国产毛片| 另类av一区二区| 蜜桃福利午夜精品一区| hitomi一区二区三区精品| a级在线免费观看| 一区二区三区在线视频免费| 国产情侣自拍av| 欧美日韩高清在线| 秋霞av鲁丝片一区二区| 永久免费看mv网站入口亚洲| 永久免费网站在线| 日韩av电影在线网| 亚洲va欧美va人人爽成人影院| 国产精品一区二区三区免费| 精品国产91乱码一区二区三区四区 | 久久精品盗摄| 一级网站在线观看| 久cao在线| 欧美日韩一区二区免费视频| 国产九色91回来了| 精品国产污网站| jizzjizz在线观看| 97人人爽人人喊人人模波多| 日韩黄色在线| 久久天天狠狠| 欧美在线视屏| www.超碰com| 成人av在线播放网址| 一本一本久久a久久| 日韩欧美亚洲国产一区| 精品国产伦一区二区三区| 亚洲欧美一区二区三区在线| 久久av色综合| 国产在线日韩在线| 免费av一区二区三区四区| 国产精品久久久久7777| 久久99精品久久久| 九九热免费在线| 五月婷婷色综合| 亚洲va天堂va欧美ⅴa在线| 中文亚洲视频在线| 美女100%一区| 精品一区日韩成人| 在线免费高清一区二区三区| 一级片免费在线观看视频| 国产精品国产自产拍高清av| 天天干,天天干| 亚洲欧美日韩精品久久| 鲁鲁在线中文| 国产精品美女黄网| 中文精品久久| 99精品999| 国产精品久久久久久久午夜片| 日韩 国产 欧美| 亚洲欧美激情在线视频| 樱花草涩涩www在线播放| 国产精品麻豆免费版| 国产一区日韩一区| 国产成人精品一区二区三区在线观看 | 国产区日韩欧美| 好看的日韩av电影| 99九九精品视频| 亚洲欧美日韩一区二区| 91成品人影院| 久久久国产在线视频| 97色婷婷成人综合在线观看| 中文字幕成人一区| 精品亚洲成av人在线观看| 一级性生活免费视频| 欧美精品三级在线观看| 成人福利在线观看视频| 亚洲最大的av网站| 欧美一区激情| 中文字幕在线观看91| 亚洲国产毛片aaaaa无费看 | 久久精视频免费在线久久完整在线看 | 欧美91视频| 久久久久亚洲AV成人网人人小说| 亚洲一区二区美女| 色婷婷中文字幕| 91高清视频免费| 国产精品一区二区av日韩在线| 任你操这里只有精品| 亚洲国产成人自拍| 国产精品自拍电影| 欧美激情a∨在线视频播放| 国产精品久久久久久久久久白浆| 免费成人午夜视频| 久久精品男人天堂av| 亚洲一区在线观| 欧美大奶子在线| 免费福利视频一区| 欧在线一二三四区| 亚洲欧美综合网| 手机看片1024国产| 国产激情久久久| 影视一区二区| av网站免费在线播放| 欧美三区在线观看| 青青青国内视频在线观看软件| 久久er99热精品一区二区三区| 日韩中文字幕一区二区三区| 熟女少妇a性色生活片毛片| 欧美成人精品高清在线播放| 亚洲人体影院| 懂色av一区二区三区四区五区| 粉嫩蜜臀av国产精品网站| 黄瓜视频在线免费观看| 久色乳综合思思在线视频| 欧美精品国产白浆久久久久| 一道本视频在线观看| 一区二区免费在线| 成人免费在线观看| 国产精品国产三级国产专区53| 久久久久久黄| 国产精品白嫩白嫩大学美女| 亚洲男人第一网站| 欧美片网站免费| 手机看片福利盒子久久| 亚洲免费色视频| 国产精品一区在线看| 国产伦理一区二区三区| 精品无人码麻豆乱码1区2区| 精品人妻无码一区二区性色| 欧美成人网在线| 第一会所亚洲原创|