亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > PHP > 正文

PHP會員找回密碼功能實現實例介紹

2024-05-04 21:47:31
字體:
來源:轉載
供稿:網友

如果你做的網站有會員系統那必須就自動找回密碼功能了,也就是忘記密碼功能,如果用戶忘記了密碼可以通過郵箱或手機號直接找回密碼,下面我來介紹郵箱找回密碼方法。

設置思路

1、用戶注冊時需要提供一個E-MAIL郵箱,目的就是用該郵箱找回密碼。

2、當用戶忘記密碼或用戶名時,點擊登錄頁面的“找回密碼”超鏈接,打開表單,并輸入注冊用的E-MAIL郵箱,提交。

3、系統通過該郵箱,從數據庫中查找到該用戶信息,并更新該用戶的密碼為一個臨時密碼(比如:12345678)。

4、系統借助Jmail功能把該用戶的信息發送到該用戶的郵箱中(內容包括:用戶名、臨時密碼、提醒用戶及時修改臨時密碼的提示語)。

5、用戶用臨時密碼即可登錄。

HTML,我們在找回密碼的頁面上放置一個要求用戶輸入注冊時所用的郵箱,然后提交前臺js來處理交互,代碼如下:

  1. <p><strong>輸入您注冊的電子郵箱,找回密碼:</strong></p>  
  2. <p><input type="text" class="input" name="email" id="email"><span id="chkmsg"></span></p>  
  3. <p><input type="button" class="btn" id="sub_btn" value="提 交"></p> 

jQuery,當用戶輸入完郵箱并點擊提交后,jQuery先驗證郵箱格式是否正確,如果正確則通過向后臺sendmail.php發送Ajax請求,sendmail.php負責驗證郵箱是否存在和發送郵件,并會返回相應的處理結果給前臺頁面,請看jQuery代碼:

  1. $(function(){  
  2.     $("#sub_btn").click(function(){  
  3.         var email = $("#email").val();  
  4.         var preg = /^w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*/; //匹配Email  
  5.         if(email=='' || !preg.test(email)){  
  6.             $("#chkmsg").html("請填寫正確的郵箱!");  
  7.         }else{  
  8.             $("#sub_btn").attr("disabled","disabled").val('提交中..').css("cursor","default");  
  9.             $.post("sendmail.php",{mail:email},function(msg){  
  10.                 if(msg=="noreg"){  
  11.                     $("#chkmsg").html("該郵箱尚未注冊!");  
  12.                     $("#sub_btn").removeAttr("disabled").val('提 交').css("cursor","pointer");  
  13.                 }else{  
  14.                     $(".demo").html("<h3>"+msg+"</h3>");  
  15.                 }  
  16.             });  
  17.         }  
  18.     });  
  19. }) 

以上使用的jQuery代碼很方便簡潔的完成了前端交互操作,如果您有一定的jQuery基礎,那上面的代碼一目了然,不多解釋。

當然別忘了在頁面中加載jQuery庫文件,有的同學經常問我說從www.49028c.com下載了demo怎么用不了,那80%是jquery或者其他文件加載路徑錯了導致沒加載必要的文件。

PHP:sendmail.php需要驗證Email是否存在系統用戶表中,如果有,則讀取用戶信息,將用戶id、用戶名和密碼驚醒md5加密生成一個特別的字符串作為找回密碼的驗證碼,然后構造URL,同時我們為了控制URL鏈接的時效性,將記錄用戶提交找回密碼動作的操作時間,最后調用郵件發送類發送郵件到用戶郵箱,發送郵件類smtp.class.php已經打包好,請下載,代碼如下:

  1. include_once("connect.php");//連接數據庫  
  2.  
  3. $email = stripslashes(trim($_POST['mail']));  
  4.       
  5. $sql = "select id,username,password from `t_user` where `email`='$email'";  
  6. $query = mysql_query($sql);  
  7. $num = mysql_num_rows($query);  
  8. if($num==0){//該郵箱尚未注冊!  
  9.     echo 'noreg';  
  10.     exit;      
  11. }else{  
  12.     $row = mysql_fetch_array($query);  
  13.     $getpasstime = time();  
  14.     $uid = $row['id'];  
  15.     $token = md5($uid.$row['username'].$row['password']);//組合驗證碼  
  16.     $url = "/demo/resetpass/reset.php?email=".$email."  
  17. &token=".$token;//構造URL  
  18.     $time = date('Y-m-d H:i');  
  19.     $result = sendmail($time,$email,$url);  
  20.     if($result==1){//郵件發送成功  
  21.         $msg = '系統已向您的郵箱發送了一封郵件<br/>請登錄到您的郵箱及時重置您的密碼!';  
  22.         //更新數據發送時間  
  23.         mysql_query("update `t_user` set `getpasstime`='$getpasstime' where id='$uid '");  
  24.     }else{  
  25.         $msg = $result;  
  26.     }  
  27.     echo $msg;  
  28. }  
  29.  
  30. //發送郵件  
  31. function sendmail($time,$email,$url){  
  32.     include_once("smtp.class.php");  
  33.     $smtpserver = ""//SMTP服務器,如smtp.163.com  
  34.     $smtpserverport = 25; //SMTP服務器端口  
  35.     $smtpusermail = ""//SMTP服務器的用戶郵箱  
  36.     $smtpuser = ""//SMTP服務器的用戶帳號  
  37.     $smtppass = ""//SMTP服務器的用戶密碼  
  38.     $smtp = new Smtp($smtpserver$smtpserverport, true, $smtpuser$smtppass);   
  39.     //這里面的一個true是表示使用身份驗證,否則不使用身份驗證.  
  40.     $emailtype = "HTML"//信件類型,文本:text;網頁:HTML  
  41.     $smtpemailto = $email;  
  42.     $smtpemailfrom = $smtpusermail;  
  43.     $emailsubject = "www.111cn.net - 找回密碼";  
  44.     $emailbody = "親愛的".$email.":<br/>您在".$time."提交了找回密碼請求。請點擊下面的鏈接重置密碼  
  45. (按鈕24小時內有效)。<br/><a href='".$url."'target='_blank'>".$url."</a>";  
  46.     $rs = $smtp->sendmail($smtpemailto$smtpemailfrom$emailsubject$emailbody$emailtype);  
  47.  
  48.     return $rs;  

好了,這個時候你的郵箱將會收到一封來自helloweba的密碼找回郵件,郵件內容中有一個URL鏈接,點擊該鏈接到www.49028c.com的reset.php來驗證郵箱,代碼如下:

  1. include_once("connect.php");//連接數據庫  
  2. $token = stripslashes(trim($_GET['token']));  
  3. $email = stripslashes(trim($_GET['email']));  
  4. $sql = "select * from `t_user` where email='$email'";  
  5. $query = mysql_query($sql);  
  6. $row = mysql_fetch_array($query);  
  7. if($row){  
  8.     $mt = md5($row['id'].$row['username'].$row['password']);  
  9.     if($mt==$token){  
  10.         if(time()-$row['getpasstime']>24*60*60){  
  11.             $msg = '該鏈接已過期!';  
  12.         }else{  
  13.             //重置密碼...  
  14.             $msg = '請重新設置密碼,顯示重置密碼表單,<br/>這里只是演示,略過。';  
  15.         }  
  16.     }else{  
  17.         $msg =  '無效的鏈接';  
  18.     }  
  19. }else{  
  20.     $msg =  '錯誤的鏈接!';      
  21. }  
  22. echo $msg

reset.php首先接受參數email和token,然后根據email查詢數據表t_user中是否存在該Email,如果存在則獲取該用戶的信息,并且和sendmail.php中的token組合方式一樣構建token值,然后與url傳過來的token進行對比,如果當前時間與發送郵件時的時間相差超過24小時的,則提示“該鏈接已過期!”,反之,則說明鏈接有效,并且調轉到重置密碼頁面,最后就是用戶自己設置新密碼了。

小結:通過注冊郵箱驗證與本文郵件找回密碼,我們知道發送郵件在網站開發中的應用以及它的重要性,當然,現在也流行短信驗證應用,這個需要相關的短信接口對接就可以了。

最后,附上數據表t_user結構,代碼如下:

  1. CREATE TABLE `t_user` (  
  2.   `id` int(11) NOT NULL auto_increment,  
  3.   `username` varchar(30) NOT NULL,  
  4.   `passwordvarchar(32) NOT NULL,  
  5.   `email` varchar(50) NOT NULL,  
  6.   `getpasstime` int(10) NOT NULL,  
  7.   PRIMARY KEY  (`id`)  
  8. ) ENGINE=MyISAM  DEFAULT CHARSET=utf8; 

smtp.class.php類文件,代碼如下:

  1. <?php 
  2. class Smtp{ 
  3.     /* Public Variables */ 
  4.  var $smtp_port
  5.  var $time_out
  6.  var $host_name
  7.  var $log_file
  8.  var $relay_host
  9.  var $debug
  10.  var $auth
  11.  var $user
  12.  var $pass
  13.  /* Private Variables */ 
  14.  var $sock
  15.  /* Constractor */ 
  16.  function smtp($relay_host = ""$smtp_port = 25, $auth = false, $user$pass) { 
  17.   $this->debug = false; 
  18.   $this->smtp_port = $smtp_port
  19.   $this->relay_host = $relay_host
  20.   $this->time_out = 30; //is used in fsockopen() 
  21.   $this->auth = $auth//auth 
  22.   $this->user = $user
  23.   $this->pass = $pass
  24.   $this->host_name = "localhost"//is used in HELO command 
  25.   $this->log_file = ""
  26.   $this->sock = false; 
  27.  } 
  28.  /* Main Function */ 
  29.  function sendmail($to$from$subject = ""$body = ""$mailtype$cc = ""$bcc = ""$additional_headers = "") { 
  30.   $mail_from = $this->get_address($this->strip_comment($from)); 
  31.   $body = ereg_replace("(^|(rn))(.)""1.3"$body); 
  32.   $header .= "MIME-Version:1.0rn"
  33.   if ($mailtype == "HTML") { 
  34.    $header .= "Content-Type:text/htmlrn"
  35.   } 
  36.   $header .= "To: " . $to . "rn"
  37.   if ($cc != "") { 
  38.    $header .= "Cc: " . $cc . "rn"
  39.   } 
  40.   $header .= "From: $from<" . $from . ">rn"
  41.   $header .= "Subject: " . $subject . "rn"
  42.   $header .= $additional_headers
  43.   $header .= "Date: " . date("r") . "rn"
  44.   $header .= "X-Mailer:By Redhat (PHP/" . phpversion() . ")rn"
  45.   list ($msec$sec) = explode(" ", microtime()); 
  46.   $header .= "Message-ID: <" . date("YmdHis"$sec) . "." . ($msec * 1000000) . "." . $mail_from . ">rn"
  47.   $TO = explode(","$this->strip_comment($to)); 
  48.   if ($cc != "") { 
  49.    $TO = array_merge($TOexplode(","$this->strip_comment($cc))); 
  50.   } 
  51.   if ($bcc != "") { 
  52.    $TO = array_merge($TOexplode(","$this->strip_comment($bcc))); 
  53.   } 
  54.   $sent = true; 
  55.   foreach ($TO as $rcpt_to) { 
  56.    $rcpt_to = $this->get_address($rcpt_to); 
  57.    if (!$this->smtp_sockopen($rcpt_to)) { 
  58.     $this->log_write("Error: Cannot send email to " . $rcpt_to . "n"); 
  59.     $sent = false; 
  60.     continue
  61.    } 
  62.    if ($this->smtp_send($this->host_name, $mail_from$rcpt_to$header$body)) { 
  63.     $this->log_write("E-mail has been sent to <" . $rcpt_to . ">n"); 
  64.    } else { 
  65.     $this->log_write("Error: Cannot send email to <" . $rcpt_to . ">n"); 
  66.     $sent = false; 
  67.    } 
  68.    fclose($this->sock); 
  69.    $this->log_write("Disconnected from remote hostn"); 
  70.   } 
  71.   return $sent
  72.  } 
  73.  /* Private Functions */ 
  74.  function smtp_send($helo$from$to$header$body = "") { 
  75.   if (!$this->smtp_putcmd("HELO"$helo)) { 
  76.    return $this->smtp_error("sending HELO command"); 
  77.   } 
  78.   // auth 
  79.   if ($this->auth) { 
  80.    if (!$this->smtp_putcmd("AUTH LOGIN"base64_encode($this->user))) { 
  81.     return $this->smtp_error("sending HELO command"); 
  82.    } 
  83.    if (!$this->smtp_putcmd(""base64_encode($this->pass))) { 
  84.     return $this->smtp_error("sending HELO command"); 
  85.    } 
  86.   } 
  87.   if (!$this->smtp_putcmd("MAIL""FROM:<" . $from . ">")) { 
  88.    return $this->smtp_error("sending MAIL FROM command"); 
  89.   } 
  90.   if (!$this->smtp_putcmd("RCPT""TO:<" . $to . ">")) { 
  91.    return $this->smtp_error("sending RCPT TO command"); 
  92.   } 
  93.   if (!$this->smtp_putcmd("DATA")) { 
  94.    return $this->smtp_error("sending DATA command"); 
  95.   } 
  96.   if (!$this->smtp_message($header$body)) { 
  97.    return $this->smtp_error("sending message"); 
  98.   } 
  99.   if (!$this->smtp_eom()) { 
  100.    return $this->smtp_error("sending <CR><LF>.<CR><LF> [EOM]"); 
  101.   } 
  102.   if (!$this->smtp_putcmd("QUIT")) { 
  103.    return $this->smtp_error("sending QUIT command"); 
  104.   } 
  105.   return true; 
  106.  } 
  107.  function smtp_sockopen($address) { 
  108.   if ($this->relay_host == "") { 
  109.    return $this->smtp_sockopen_mx($address); 
  110.   } else { 
  111.    return $this->smtp_sockopen_relay(); 
  112.   } 
  113.  } 
  114.  function smtp_sockopen_relay() { 
  115.   $this->log_write("Trying to " . $this->relay_host . ":" . $this->smtp_port . "n"); 
  116.   $this->sock = @ fsockopen($this->relay_host, $this->smtp_port, $errno$errstr$this->time_out); 
  117.   if (!($this->sock && $this->smtp_ok())) { 
  118.    $this->log_write("Error: Cannot connenct to relay host " . $this->relay_host . "n"); 
  119.    $this->log_write("Error: " . $errstr . " (" . $errno . ")n"); 
  120.    return false; 
  121.   } 
  122.   $this->log_write("Connected to relay host " . $this->relay_host . "n"); 
  123.   return true; 
  124.   ; 
  125.  } 
  126.  function smtp_sockopen_mx($address) { 
  127.   $domain = ereg_replace("^.+@([^@]+)$""1"$address); 
  128.   if (!@ getmxrr($domain$MXHOSTS)) { 
  129.    $this->log_write("Error: Cannot resolve MX "" . $domain . ""n"); 
  130.    return false; 
  131.   } 
  132.   foreach ($MXHOSTS as $host) { 
  133.    $this->log_write("Trying to " . $host . ":" . $this->smtp_port . "n"); 
  134.    $this->sock = @ fsockopen($host$this->smtp_port, $errno$errstr$this->time_out); 
  135.    if (!($this->sock && $this->smtp_ok())) { 
  136.     $this->log_write("Warning: Cannot connect to mx host " . $host . "n"); 
  137.     $this->log_write("Error: " . $errstr . " (" . $errno . ")n"); 
  138.     continue
  139.    } 
  140.    $this->log_write("Connected to mx host " . $host . "n"); 
  141.    return true; 
  142.   } 
  143.   $this->log_write("Error: Cannot connect to any mx hosts (" . implode(", "$MXHOSTS) . ")n"); 
  144.   return false; 
  145.  } 
  146.  function smtp_message($header$body) { 
  147.   fputs($this->sock, $header . "rn" . $body); 
  148.   $this->smtp_debug("> " . str_replace("rn""n" . "> "$header . "n> " . $body . "n> ")); 
  149.   return true; 
  150.  } 
  151.  function smtp_eom() { 
  152.   fputs($this->sock, "rn.rn"); 
  153.   $this->smtp_debug(". [EOM]n"); 
  154.   return $this->smtp_ok(); 
  155.  } 
  156.  function smtp_ok() { 
  157.   $response = str_replace("rn"""fgets($this->sock, 512)); 
  158.   $this->smtp_debug($response . "n"); 
  159.   if (!ereg("^[23]"$response)) { 
  160.    fputs($this->sock, "QUITrn"); 
  161.    fgets($this->sock, 512); 
  162.    $this->log_write("Error: Remote host returned "" . $response . ""n"); 
  163.    return false; 
  164.   } 
  165.   return true; 
  166.  } 
  167.  function smtp_putcmd($cmd$arg = "") { 
  168.   if ($arg != "") { 
  169.    if ($cmd == ""
  170.     $cmd = $arg
  171.    else 
  172.     $cmd = $cmd . " " . $arg
  173.   } 
  174.   fputs($this->sock, $cmd . "rn"); 
  175.   $this->smtp_debug("> " . $cmd . "n"); 
  176.   return $this->smtp_ok(); 
  177.  } 
  178.  function smtp_error($string) { 
  179.   $this->log_write("Error: Error occurred while " . $string . ".n"); 
  180.   return false; 
  181.  } 
  182.  function log_write($message) { 
  183.   $this->smtp_debug($message); 
  184.   if ($this->log_file == "") { 
  185.    return true; 
  186.   } 
  187.   $message = date("M d H:i:s ") . get_current_user() . "[" . getmypid() . "]: " . $message
  188.   if (!@ file_exists($this->log_file) || !($fp = @ fopen($this->log_file, "a"))) { 
  189.    $this->smtp_debug("Warning: Cannot open log file "" . $this->log_file . ""n"); 
  190.    return false; 
  191.    ; 
  192.   } 
  193.   flock($fp, LOCK_EX); 
  194.   fputs($fp$message); 
  195.   fclose($fp); 
  196.   return true; 
  197.  } 
  198.  function strip_comment($address) { 
  199.   $comment = "([^()]*)"
  200.   while (ereg($comment$address)) { 
  201.    $address = ereg_replace($comment""$address); 
  202.   } 
  203.   return $address
  204.  } 
  205.  function get_address($address) { 
  206.   $address = ereg_replace("([ trn])+"""$address); 
  207.   $address = ereg_replace("^.*<(.+)>.*$""1"$address); 
  208.   return $address
  209.  } 
  210.  function smtp_debug($message) { 
  211.   if ($this->debug) { 
  212.    echo $message . " 
  213.    ;"; 
  214.   } 
  215.  } 
  216. ?> 

最后面有個數據庫連接類,這里就不介紹了大大家可以百本站找相關的數據庫連接mysql類哦。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩欧美成人区| 日韩视频精品在线| 国模gogo一区二区大胆私拍| 亚洲专区中文字幕| 日韩在线视频观看| 精品女同一区二区三区在线播放| 国内免费久久久久久久久久久| 91美女片黄在线观看游戏| 在线播放精品一区二区三区| 日韩精品高清在线观看| 91亚洲精品一区二区| 亚洲美腿欧美激情另类| 欧美高清电影在线看| 久久精品国产亚洲精品2020| 91精品国产色综合久久不卡98| 亚洲免费视频在线观看| 91国产精品91| 久久久久久91| 69精品小视频| 亚洲美女性视频| 亚洲国产一区自拍| 日韩av理论片| 日韩电影免费在线观看中文字幕| 美女999久久久精品视频| 国产日产欧美a一级在线| 国产亚洲美女久久| 国产视频精品xxxx| 91久久国产精品91久久性色| 伊人成人开心激情综合网| 国产亚洲精品激情久久| 国产精品一区二区久久精品| 欧美午夜丰满在线18影院| 亚洲影院色无极综合| 欧美高清自拍一区| 欧美电影在线观看高清| 久久久久久香蕉网| 欧美天堂在线观看| 国产亚洲视频中文字幕视频| 国产精品久久久久7777婷婷| 97久久精品人人澡人人爽缅北| 亚洲小视频在线观看| 日韩在线小视频| 欧美人交a欧美精品| 91精品国产乱码久久久久久久久| 国产精品电影久久久久电影网| 国产精品男人爽免费视频1| 日韩人在线观看| 欧洲日本亚洲国产区| 欧美成人免费全部| 亚洲一区美女视频在线观看免费| 国产精国产精品| 亚洲国产精品福利| 欧美日韩国产成人| 色综合天天综合网国产成人网| 久久久亚洲欧洲日产国码aⅴ| 高跟丝袜一区二区三区| 永久免费毛片在线播放不卡| 狠狠久久亚洲欧美专区| 91精品视频网站| 日本19禁啪啪免费观看www| 一区二区三区视频免费| 午夜精品在线观看| 欧美中文在线免费| 欧美午夜电影在线| 91精品久久久久久久久久久久久久| 日本成人激情视频| 欧美亚洲成人精品| 久久99视频精品| 国产美女久久精品| 欧美大片va欧美在线播放| 一区二区三区精品99久久| 日韩av有码在线| 欧美成人激情视频免费观看| 亚洲一区二区三区视频| 精品一区二区三区四区在线| 中文字幕欧美视频在线| 精品久久久久久中文字幕| 国产成人精品电影久久久| 97超级碰碰碰久久久| 91亚洲人电影| 久久在精品线影院精品国产| 国产suv精品一区二区三区88区| 日韩视频免费观看| 精品一区二区三区四区| 91干在线观看| 社区色欧美激情 | 欧美在线免费看| 欧美在线xxx| 久久久999精品免费| 亚洲白拍色综合图区| 欧美日韩福利电影| 亚洲国产欧美精品| 欧美性高潮床叫视频| 国产福利视频一区二区| 久久久国产一区二区| 在线视频日韩精品| 中文字幕欧美日韩| 亚洲2020天天堂在线观看| 亚洲欧美三级伦理| 97人人爽人人喊人人模波多| 亚洲欧美日韩成人| 国产在线98福利播放视频| 国产欧美日韩丝袜精品一区| 国产91精品久久久| 欧美日韩加勒比精品一区| 中文字幕不卡在线视频极品| 国产精品91久久| 亚洲精品网址在线观看| 色播久久人人爽人人爽人人片视av| 亚洲欧美中文在线视频| 亚洲欧美日韩区| 中文字幕亚洲第一| 精品久久久久久久久中文字幕| 插插插亚洲综合网| 欧美激情精品在线| 久久久久久久久久久网站| 久久99久久亚洲国产| 日韩中文第一页| 91精品国产高清久久久久久久久| 日韩禁在线播放| 中文字幕国产精品| 欧美激情视频在线观看| 欧美中文字幕在线视频| 欧美高清在线播放| 91色视频在线观看| 视频直播国产精品| 国产日韩在线一区| 91天堂在线观看| 国产成人久久久精品一区| 国产精品成久久久久三级| 久久久久久久久中文字幕| 国产精品久久久久久久av电影| 国产精品一区二区三| 亚洲综合中文字幕在线| 国产精品爽爽ⅴa在线观看| 日韩精品免费在线观看| 久久久久久久久久亚洲| 国产欧美日韩精品丝袜高跟鞋| 国产精品电影观看| 欧美丝袜一区二区三区| 欧美日韩中文字幕在线视频| 亚洲香蕉成人av网站在线观看| 欧美孕妇孕交黑巨大网站| 国产精品久久久久久av福利软件| 久久夜色精品国产欧美乱| 国产精品久久999| 国产一区二区三区日韩欧美| 亚洲一级黄色片| 精品久久久久久久久久久久久| www.久久色.com| www.美女亚洲精品| 色妞一区二区三区| 日本精品久久中文字幕佐佐木| 亚洲精品资源在线| 日韩电影网在线| 久久亚洲春色中文字幕| 亚洲精品国产欧美| 国产欧美一区二区三区在线看| 欧美激情乱人伦| 国产三级精品网站| 欧美激情在线播放| 岛国av一区二区在线在线观看| 国产成人亚洲综合91| 精品国产成人av|