午夜视频免费看_日韩三级电影网站_国产精品久久一级_亚洲一级在线播放_人妻体内射精一区二区三区_91夜夜揉人人捏人人添红杏_91福利在线导航_国产又粗又猛又黄又爽无遮挡_欧美日韩一区在线播放_中文字幕一区二区三区四区不卡 _日日夜夜精品视频免费观看_欧美韩日一区二区三区

主頁 > 知識庫 > 詳解PHP實現支付寶小程序用戶授權的工具類

詳解PHP實現支付寶小程序用戶授權的工具類

熱門標簽:400 電話 辦理 山東電銷卡外呼系統原理是什么 智能電銷語音機器人資訊 兼職做地圖標注好賺錢嗎 打開百度地圖標注 亳州企業外呼系統 海南外呼系統方案 蘇州外呼系統有效果嗎 地圖標注怎么做商戶驗證

背景

最近項目需要上線支付寶小程序,同時需要走用戶的授權流程完成用戶信息的存儲,以前做過微信小程序的開發,本以為實現授權的過程是很簡單的事情,但是再實現的過程中還是遇到了不少的坑,因此記錄一下實現的過程

學到的知識

  • 支付寶開放接口的調用模式以及實現方式
  • 支付寶小程序授權的流程
  • RSA加密方式

吐槽點

支付寶小程序的入口隱藏的很深,沒有微信小程序那么直接了當
支付寶小程序的開發者工具比較難用,編譯時候比較卡,性能有很大的問題
每提交一次代碼,支付寶小程序的體驗碼都要進行更換,比較繁瑣,而且localStorage的東西不知道要如何刪除

事先準備

  • 到支付寶開放平臺注冊一個開發者賬號,并做好相應的認證等工作
  • 創建一個小程序,并記錄好相關的小程序信息,包括支付寶公鑰,私鑰,app公鑰等,可以借鑒支付寶官方提供的相應的公鑰生成工具來生成公鑰和私鑰,工具的下載地址:傳送門
  • 了解下支付寶小程序的簽名機制,詳細見https://docs.open.alipay.com/291/105974
  • 熟悉下支付寶小程序獲取用戶信息的過程,詳細見支付寶小程序用戶授權指引

授權的步驟

授權時序圖

實現流程

  1. 客戶端通過my.getAuthCode接口獲取code,傳給服務端
  2. 服務端通過code,調用獲取token接口獲取access_token,alipay.system.oauth.token(換取授權訪問令牌)
  3. 通過token接口調用支付寶會員查詢接口獲取會員信息,alipay.user.info.share(支付寶會員授權信息查詢接口)
  4. 將獲取的用戶信息保存到數據庫

AmpHelper工具類

?php
/**
 * Created by PhpStorm.
 * User: My
 * Date: 2018/8/16
 * Time: 17:45
 */

namespace App\Http\Helper;

use App\Http\Helper\Sys\BusinessHelper;
use Illuminate\Support\Facades\Log;

class AmpHelper
{

  const API_DOMAIN = "https://openapi.alipay.com/gateway.do?";
  const API_METHOD_GENERATE_QR = 'alipay.open.app.qrcode.create';
  const API_METHOD_AUTH_TOKEN = 'alipay.system.oauth.token';
  const API_METHOD_GET_USER_INFO = 'alipay.user.info.share';

  const SIGN_TYPE_RSA2 = 'RSA2';
  const VERSION = '1.0';
  const FILE_CHARSET_UTF8 = "UTF-8";
  const FILE_CHARSET_GBK = "GBK";
  const RESPONSE_OUTER_NODE_QR = 'alipay_open_app_qrcode_create_response';
  const RESPONSE_OUTER_NODE_AUTH_TOKEN = 'alipay_system_oauth_token_response';
  const RESPONSE_OUTER_NODE_USER_INFO = 'alipay_user_info_share_response';
  const RESPONSE_OUTER_NODE_ERROR_RESPONSE = 'error_response';

  const STATUS_CODE_SUCCESS = 10000;
  const STATUS_CODE_EXCEPT = 20000;


  /**
   * 獲取用戶信息接口,根據token
   * @param $code 授權碼
   * 通過授權碼獲取用戶的信息
   */
  public static function getAmpUserInfoByAuthCode($code){
    $aliUserInfo = [];
    $tokenData = AmpHelper::getAmpToken($code);
    //如果token不存在,這種主要是為了處理支付寶的異常記錄
    if(isset($tokenData['code'])){
      return $tokenData;
    }
    $token = formatArrValue($tokenData,'access_token');
    if($token){
      $userBusiParam = self::getAmpUserBaseParam($token);
      $url = self::buildRequestUrl($userBusiParam);
      $resonse = self::getResponse($url,self::RESPONSE_OUTER_NODE_USER_INFO);
      if($resonse['code'] == self::STATUS_CODE_SUCCESS){
        //有效的字段列
        $userInfoColumn = ['user_id','avatar','province','city','nick_name','is_student_certified','user_type','user_status','is_certified','gender'];
        foreach ($userInfoColumn as $column){
          $aliUserInfo[$column] = formatArrValue($resonse,$column,'');
        }

      }else{
        $exceptColumns = ['code','msg','sub_code','sub_msg'];
        foreach ($exceptColumns as $column){
          $aliUserInfo[$column] = formatArrValue($resonse,$column,'');
        }
      }
    }
    return $aliUserInfo;
  }


  /**
   * 獲取小程序token接口
   */
  public static function getAmpToken($code){
    $param = self::getAuthBaseParam($code);
    $url = self::buildRequestUrl($param);
    $response = self::getResponse($url,self::RESPONSE_OUTER_NODE_AUTH_TOKEN);
    $tokenResult = [];
    if(isset($response['code'])  $response['code'] != self::STATUS_CODE_SUCCESS){
      $exceptColumns = ['code','msg','sub_code','sub_msg'];
      foreach ($exceptColumns as $column){
        $tokenResult[$column] = formatArrValue($response,$column,'');
      }
    }else{
      $tokenResult = $response;
    }
    return $tokenResult;
  }

  /**
   * 獲取二維碼鏈接接口
   * 433ac5ea4c044378826afe1532bcVX78
   * https://openapi.alipay.com/gateway.do?timestamp=2013-01-01 08:08:08method=alipay.open.app.qrcode.createapp_id=2893sign_type=RSA2sign=ERITJKEIJKJHKKKKKKKHJEREEEEEEEEEEEversion=1.0biz_content=
  {"url_param":"/index.html?name=aliloc=hz", "query_param":"name=1age=2", "describe":"二維碼描述"}
  */
  public static function generateQrCode($mpPage = 'pages/index',$queryParam = [],$describe){
    $param = self::getQrcodeBaseParam($mpPage,$queryParam,$describe );
    $url = self::buildRequestUrl($param);
    $response = self::getResponse($url,self::RESPONSE_OUTER_NODE_QR);
    return $response;
  }


  /**
   * 獲取返回的數據,對返回的結果做進一步的封裝和解析,因為支付寶的每個接口的返回都是由一個特定的  
   * key組成的,因此這里直接封裝了而一個通用的方法,對于不同的接口只需要更改相應的node節點就可以了
   */
  public static function getResponse($url,$responseNode){
    $json = curlRequest($url);
    $response = json_decode($json,true);
    $responseContent = formatArrValue($response,$responseNode,[]);
    $errResponse = formatArrValue($response,self::RESPONSE_OUTER_NODE_ERROR_RESPONSE,[]);
    if($errResponse){
      return $errResponse;
    }
    return $responseContent;
  }

  /**
   * 獲取請求的鏈接
   */
  public static function buildQrRequestUrl($mpPage = 'pages/index',$queryParam = []){
    $paramStr = http_build_query(self::getQrBaseParam($mpPage,$queryParam));
    return self::API_DOMAIN . $paramStr;
  }



  /**
   * 構建請求鏈接
   */
  public static function buildRequestUrl($param){
    $paramStr = http_build_query($param);
    return self::API_DOMAIN . $paramStr;
  }


  /**
   * 獲取用戶的基礎信息接口
   */
  public static function getAmpUserBaseParam($token){
    $busiParam = [
      'auth_token' => $token,
    ];
    $param = self::buildApiBuisinessParam($busiParam,self::API_METHOD_GET_USER_INFO);
    return $param;

  }

  /**
   *獲取二維碼的基礎參數
   */
  public static function getQrcodeBaseParam($page= 'pages/index/index',$queryParam = [],$describe = ''){
    $busiParam = [
      'biz_content' => self::getQrBizContent($page,$queryParam,$describe)
    ];
    $param = self::buildApiBuisinessParam($busiParam,self::API_METHOD_GENERATE_QR);
    return $param;

  }

  /**
   *獲取授權的基礎參數
   */
  public static function getAuthBaseParam($code,$refreshToken = ''){
    $busiParam = [
      'grant_type' => 'authorization_code',
      'code' => $code,
      'refresh_token' => $refreshToken,
    ];
    $param = self::buildApiBuisinessParam($busiParam,self::API_METHOD_AUTH_TOKEN);
    return $param;
  }


  /**
   * 構建業務參數
   */
  public static function buildApiBuisinessParam($businessParam,$apiMethod){
    $pubParam = self::getApiPubParam($apiMethod);
    $businessParam = array_merge($pubParam,$businessParam);
    $signContent = self::getSignContent($businessParam);
    error_log('sign_content ===========>'.$signContent);
    $rsaHelper = new RsaHelper();
    $sign = $rsaHelper->createSign($signContent);
    error_log('sign ===========>'.$sign);
    $businessParam['sign'] = $sign;
    return $businessParam;
  }


  /**
   * 公共參數
   *
   */
  public static function getApiPubParam($apiMethod){
    $ampBaseInfo = BusinessHelper::getAmpBaseInfo();
    $param = [
      'timestamp' => date('Y-m-d H:i:s') ,
      'method' => $apiMethod,
      'app_id' => formatArrValue($ampBaseInfo,'appid',config('param.amp.appid')),
      'sign_type' =>self::SIGN_TYPE_RSA2,
      'charset' =>self::FILE_CHARSET_UTF8,
      'version' =>self::VERSION,
    ];
    return $param;
  }


  /**
   * 獲取簽名的內容
   */
  public static function getSignContent($params) {
    ksort($params);
    $stringToBeSigned = "";
    $i = 0;
    foreach ($params as $k => $v) {
      if (!empty($v)  "@" != substr($v, 0, 1)) {
        if ($i == 0) {
          $stringToBeSigned .= "$k" . "=" . "$v";
        } else {
          $stringToBeSigned .= "" . "$k" . "=" . "$v";
        }
        $i++;
      }
    }
    unset ($k, $v);
    return $stringToBeSigned;
  }


  public static function convertArrToQueryParam($param){
    $queryParam = [];
    foreach ($param as $key => $val){
      $obj = $key.'='.$val;
      array_push($queryParam,$obj);
    }
    $queryStr = implode('',$queryParam);
    return $queryStr;
  }

  /**
   * 轉換字符集編碼
   * @param $data
   * @param $targetCharset
   * @return string
   */
  public static function characet($data, $targetCharset) {
    if (!empty($data)) {
      $fileType = self::FILE_CHARSET_UTF8;
      if (strcasecmp($fileType, $targetCharset) != 0) {
        $data = mb_convert_encoding($data, $targetCharset, $fileType);
      }
    }
    return $data;
  }

  /**
   * 獲取業務參數內容
   */
  public static function getQrBizContent($page, $queryParam = [],$describe = ''){
    if(is_array($queryParam)){
      $queryParam = http_build_query($queryParam);
    }
    $obj = [
      'url_param' => $page,
      'query_param' => $queryParam,
      'describe' => $describe
    ];
    $bizContent = json_encode($obj,JSON_UNESCAPED_UNICODE);
    return $bizContent;
  }

}

AmpHeler工具類關鍵代碼解析相關常量

//支付寶的api接口地址
const API_DOMAIN = "https://openapi.alipay.com/gateway.do?";
//獲取支付寶二維碼的接口方法
const API_METHOD_GENERATE_QR = 'alipay.open.app.qrcode.create';
//獲取token的接口方法
const API_METHOD_AUTH_TOKEN = 'alipay.system.oauth.token';
//獲取用戶信息的接口方法
const API_METHOD_GET_USER_INFO = 'alipay.user.info.share';
//支付寶的簽名方式,由RSA2和RSA兩種
const SIGN_TYPE_RSA2 = 'RSA2';
//版本號,此處固定挑那些就可以了
const VERSION = '1.0';
//UTF8編碼
const FILE_CHARSET_UTF8 = "UTF-8";
//GBK編碼
const FILE_CHARSET_GBK = "GBK";
//二維碼接口調用成功的 返回節點
const RESPONSE_OUTER_NODE_QR = 'alipay_open_app_qrcode_create_response';
//token接口調用成功的 返回節點
const RESPONSE_OUTER_NODE_AUTH_TOKEN = 'alipay_system_oauth_token_response';
//用戶信息接口調用成功的 返回節點
const RESPONSE_OUTER_NODE_USER_INFO = 'alipay_user_info_share_response';
//錯誤的返回的時候的節點
const RESPONSE_OUTER_NODE_ERROR_RESPONSE = 'error_response';

const STATUS_CODE_SUCCESS = 10000;
const STATUS_CODE_EXCEPT = 20000;

getAmpUserInfoByAuthCode方法

這個方法是獲取用戶信息的接口方法,只需要傳入客戶端傳遞的code,就可以獲取到用戶的完整信息

getAmpToken方法

這個方法是獲取支付寶接口的token的方法,是一個公用方法,后面所有的支付寶的口調用,都可以使用這個方法先獲取token

getResponse方法

考慮到會調用各個支付寶的接口,因此這里封裝這個方法是為了方便截取接口返回成功之后的信息,提高代碼的閱讀性

getApiPubParam方法

這個方法是為了獲取公共的參數,包括版本號,編碼,appid,簽名類型等基礎業務參數

getSignContent方法

這個方法是獲取簽名的內容,入參是一個數組,最后輸出的是參數的拼接字符串

buildApiBuisinessParam($businessParam,$apiMethod)

這個是構建api獨立的業務參數部分方法,businessParam參數是支付寶各個接口的業務參數部分(出去公共參數),$apiMethod是對應的接口的方法名稱,如獲取token的方法名為alipay.system.oauth.token

簽名幫助類

?php
/**
 * Created by PhpStorm.
 * User: Auser
 * Date: 2018/12/4
 * Time: 15:37
 */

namespace App\Http\Helper;

/**
 *$rsa2 = new Rsa2();
 *$data = 'mydata'; //待簽名字符串
 *$strSign = $rsa2->createSign($data);   //生成簽名
 *$is_ok = $rsa2->verifySign($data, $strSign); //驗證簽名
 */
class RsaHelper
{

  private static $PRIVATE_KEY;
  private static $PUBLIC_KEY;


  function __construct(){
    self::$PRIVATE_KEY = config('param.amp.private_key');
    self::$PUBLIC_KEY = config('param.amp.public_key');
  }

  /**
   * 獲取私鑰
   * @return bool|resource
   */
  private static function getPrivateKey()
  {
    $privKey = self::$PRIVATE_KEY;
    $privKey = "-----BEGIN RSA PRIVATE KEY-----".PHP_EOL.wordwrap($privKey, 64, PHP_EOL, true).PHP_EOL."-----END RSA PRIVATE KEY-----";
    ($privKey) or die('您使用的私鑰格式錯誤,請檢查RSA私鑰配置');
    error_log('private_key is ===========>: '.$privKey);
    return openssl_pkey_get_private($privKey);
  }
  /**
   * 獲取公鑰
   * @return bool|resource
   */
  private static function getPublicKey()
  {
    $publicKey = self::$PUBLIC_KEY;
    $publicKey = "-----BEGIN RSA PRIVATE KEY-----".PHP_EOL.wordwrap($publicKey, 64, PHP_EOL, true).PHP_EOL."-----END RSA PRIVATE KEY-----";
    error_log('public key is : ===========>'.$publicKey);
    return openssl_pkey_get_public($publicKey);
  }
  /**
   * 創建簽名
   * @param string $data 數據
   * @return null|string
   */
  public function createSign($data = '')
  {
    // var_dump(self::getPrivateKey());die;
    if (!is_string($data)) {
      return null;
    }
    return openssl_sign($data, $sign, self::getPrivateKey(),OPENSSL_ALGO_SHA256 ) ? base64_encode($sign) : null;
  }
  /**
   * 驗證簽名
   * @param string $data 數據
   * @param string $sign 簽名
   * @return bool
   */
  public function verifySign($data = '', $sign = '')
  {
    if (!is_string($sign) || !is_string($sign)) {
      return false;
    }
    return (bool)openssl_verify(
      $data,
      base64_decode($sign),
      self::getPublicKey(),
      OPENSSL_ALGO_SHA256
    );
  }
}

調用

$originUserData = AmpHelper::getAmpUserInfoByAuthCode($code);
echo $originUserData;

注意getAmpUserInfoByAuthCode方法,調用接口成功,會返回支付寶用戶的正確信息,示例如下

{
  "alipay_user_info_share_response": {
    "code": "10000",
    "msg": "Success",
    "user_id": "2088102104794936",
    "avatar": "http://tfsimg.alipay.com/images/partner/T1uIxXXbpXXXXXXXX",
    "province": "安徽省",
    "city": "安慶",
    "nick_name": "支付寶小二",
    "is_student_certified": "T",
    "user_type": "1",
    "user_status": "T",
    "is_certified": "T",
    "gender": "F"
  },
  "sign": "ERITJKEIJKJHKKKKKKKHJEREEEEEEEEEEE"
}

踩坑點

  1. 在開發之前一定要仔細閱讀用戶的授權流程指引文檔,否則很容出錯
  2. 對于用戶信息接口,在獲取授權信息接口并沒有做明確的說明,所以需要先梳理清楚
  3. 支付寶的簽名機制和微信的有很大不同,對于習慣了微信小程序開發的人來說,剛開始可能有點不適應,所以需要多看看sdk里面的實現

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • PHP:微信小程序 微信支付服務端集成實例詳解及源碼下載
  • 微信小程序 支付功能實現PHP實例詳解
  • 微信小程序與php 實現微信支付的簡單實例
  • php實現小程序支付完整版
  • 微信小程序支付功能 php后臺對接完整代碼分享
  • 微信小程序支付PHP代碼
  • 微信小程序 PHP后端form表單提交實例詳解
  • 微信小程序調用PHP后臺接口 解析純html文本
  • 微信小程序request請求后臺接口php的實例詳解
  • PHP小程序支付功能完整版【基于thinkPHP】

標簽:萊蕪 清遠 金華 綏化 安康 呼倫貝爾 溫州 紹興

巨人網絡通訊聲明:本文標題《詳解PHP實現支付寶小程序用戶授權的工具類》,本文關鍵詞  詳解,PHP,實現,支付,寶小,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《詳解PHP實現支付寶小程序用戶授權的工具類》相關的同類信息!
  • 本頁收集關于詳解PHP實現支付寶小程序用戶授權的工具類的相關信息資訊供網民參考!
  • 推薦文章
    国产激情久久久久| 久久全国免费视频| 欧美情侣在线播放| 亚洲综合色噜噜狠狠| 99精品国产99久久久久久白柏| 久久丫精品久久丫| 91国在线高清视频| 青娱乐一区二区| 国产精品久久国产精品| 国产精品久久久久久亚洲调教| 国内精品一区二区三区四区| 国产成人av网| 高清不卡一区二区三区| 国产精品白嫩初高中害羞小美女| 91精品国产高清| 欧美国产第二页| 日韩一级黄色av| 亚洲视频视频在线| 精品视频久久久| 精品88久久久久88久久久| 日韩一区二区精品| 欧美在线看片a免费观看| 岛国av一区二区| 亚洲在线视频免费观看| 欧美亚洲国产怡红院影院| 欧美在线观看一二区| 精品日韩在线一区| 亚洲电影免费观看高清完整版在线观看| 欧美亚洲高清一区| 亚洲国产91色在线| 精品自拍视频在线观看| 久久99亚洲热视| 国产精品美女免费视频| 久久久久久久免费| 欧美xxxx黑人又粗又长精品| 日韩欧美亚洲在线| 欧美日韩一区在线播放| 婷婷精品国产一区二区三区日韩| 欧美一区1区三区3区公司| 成人黄色片免费| 中文字幕亚洲影院| 91精品人妻一区二区三区四区| 超碰91在线播放| www.四虎精品| 国产精品无码电影| 亚洲狠狠婷婷综合久久久久图片| 国产熟妇搡bbbb搡bbbb| 亚洲一二三四视频| 视频国产一区二区| 国产亚洲欧美精品久久久www| 一区二区www| 亚洲第一精品网站| 四季av日韩精品一区| 午夜视频在线播放| 极品少妇xxxx精品少妇| 国产高清久久久| 大胆亚洲人体视频| 久久综合999| 国产精品欧美经典| 亚洲欧美韩国综合色| 亚洲动漫第一页| 色先锋资源久久综合| 欧美人体做爰大胆视频| xxxx性欧美| 成人免费福利视频| 久久久久久久有限公司| 妺妺窝人体色www在线小说| wwwxxx黄色片| 免费欧美一级片| 波多野吉衣中文字幕| 国产精品成人69xxx免费视频| 久久久无码一区二区三区| 性一交一乱一精一晶| av欧美精品.com| 国产精品国产三级国产a| 亚洲成a人片在线不卡一二三区 | 午夜精品久久久久久不卡8050| 欧美成人a在线| 2020欧美日韩在线视频| 国产日韩精品在线| 精品无码久久久久国产| 久久免费看毛片| 又粗又黑又大的吊av| 在线观看免费不卡av| 国产精品毛片一区二区| 亚洲熟妇av乱码在线观看| 无码国产精品一区二区免费16| 国产亚洲成av人在线观看导航| 亚洲线精品一区二区三区八戒| 欧美日韩综合色| 国产丝袜高跟一区| 国产精品视频成人| 白白操在线视频| 精品夜夜澡人妻无码av| 中文字幕在线观看1| 老司机免费视频久久| 国产精品一级在线| 日韩一区在线看| 欧美色精品天天在线观看视频| 久久中文字幕一区| 国产精品永久免费| 手机成人在线| 丰满熟女人妻一区二区三区| 久久久久亚洲av成人毛片韩| 欧美 日韩 国产 成人 在线 91| 国产精品一区二区在线播放 | 国内免费精品视频| 中文字幕一区二区三区波野结| 国产成人亚洲精品狼色在线| 在线视频国产一区| 欧美激情在线视频二区| 动漫3d精品一区二区三区 | 中文字幕欧美日韩va免费视频| 4388成人网| 中文字幕久久综合| 日韩av一二区| 黄色a在线观看| 成人av资源在线观看| 亚洲欧美成人一区二区三区| 亚洲精品一区中文字幕乱码| 97人人模人人爽人人少妇| 黄色网络在线观看| 人人干人人干人人| 无码人妻精品一区二区三区温州| 国产巨乳在线观看| 国产91在线|亚洲| 亚洲一区二区三区中文字幕| 中文字幕在线亚洲| 日韩国产美国| 中文字幕在线观看的网站| www天堂在线| 91在线云播放| 日韩美女视频在线| 性欧美视频videos6一9| 久久国产精品久久| 中文字幕人妻熟女在线| 国产aⅴ爽av久久久久成人| 成人免费视频免费观看| 欧美一区二区三区白人| 欧美激情一二区| 久久免费视频2| 成年女人免费视频| 精品人妻一区二区三区四区不卡 | dy888午夜| 污污视频网站在线免费观看| 国产免费无遮挡| www.日韩av| 精品福利一二区| 国产精品yjizz| 色男人天堂av| 不卡的日韩av| 午夜精品久久久久久久蜜桃app| 欧美极品在线播放| 精品无码国产一区二区三区av| aaaaa级少妇高潮大片免费看| 少妇高潮一区二区三区99小说| 偷拍日韩校园综合在线| 久久视频国产精品免费视频在线| 一区二区三区偷拍| 国模无码视频一区| 怡春院在线视频| 亚洲色图丝袜美腿| 亚洲欧美成人网| 91影视免费在线观看| 91国视频在线| 韩国av中文字幕| 国产99久久久久久免费看农村| 日韩欧美国产午夜精品| 国产精品一区二区三区在线观| 一级黄色片毛片| 天堂午夜影视日韩欧美一区二区| 在线观看免费成人| 成人在线精品视频| 黄色激情在线观看| 日韩综合一区二区| 亚洲h在线观看| 国产91精品久久久久久| 亚洲免费看av| www.好吊色| 在线影视一区二区三区| 国产视频观看一区| 亚洲午夜久久久久久久久| 日韩**一区毛片| 大伊人狠狠躁夜夜躁av一区| 国产ts人妖一区二区三区| 天堂8在线天堂资源bt| 欧美视频一区二区在线| 日韩电影在线观看网站| 欧美精品123区| 国产精品美女免费视频| 麻豆网站免费观看| 久久久久久穴| 欧美日韩一区二区三区| 国产美女精彩久久| 大尺度做爰床戏呻吟舒畅| 成 人片 黄 色 大 片| 色综合天天综合网天天狠天天| 国产一区香蕉久久| 国产老熟女伦老熟妇露脸| 精品一区二区三区蜜桃| 欧美亚洲高清一区| 国产精品有限公司| 国产视频精品免费| 国产午夜三级一区二区三| 九色91av视频| 欧美黄色性生活| 熟妇人妻系列aⅴ无码专区友真希| 欧美久久久一区| 免费久久一级欧美特大黄| 澳门黄色一级片| 粉嫩av一区二区三区在线播放| 日韩成人高清在线| 久久久免费看| 清纯粉嫩极品夜夜嗨av| 国产69精品久久777的优势| 中文日韩在线视频| 亚洲中文字幕无码中文字| 亚洲av无码乱码国产精品| 在线播放91灌醉迷j高跟美女 | 欧美夫妻性生活视频| 亚洲激情在线观看视频| 18国产免费视频| 国产性色一区二区| 午夜精品一区二区三区在线视| 亚洲欧美国产中文| 99久久精品国产一区色| 欧美亚洲日本国产| 日韩av大全| 国产精品第5页| 国产精品青草综合久久久久99| 欧美在线欧美在线| 美女一区二区三区视频| 久久精品网址| 亚洲毛片在线免费观看| 久久久久久久中文| 老司机午夜福利视频| 日韩欧美一级二级三级| 400部精品国偷自产在线观看| 国产裸体美女永久免费无遮挡| 色婷婷激情综合| 日韩不卡av| 中文字幕乱伦视频| 欧美精品日韩一本| 做爰高潮hd色即是空| 国产精品视频一二区| 欧美一级艳片视频免费观看| mm131午夜| 亚洲第一页在线观看| 精品动漫一区二区三区在线观看| 久久99国产精品一区| 又骚又黄的视频| 欧美高清dvd| 色婷婷777777仙踪林| 久久精品视频5| 欧美性一区二区| 一区二区三区欧美成人| 国产精品视频在线观看免费| 欧美xxxxxxxx| 精品无码一区二区三区在线| 亚洲在线精品视频| 日韩一区二区三区四区 | 极品少妇一区二区三区精品视频 | 青青草成人激情在线| 黄色一区二区视频| 91精品国产乱码久久蜜臀| 国产黄色激情视频| 蜜桃视频一区| 日韩在线www| 又黄又色的网站| 国产日产欧美精品一区二区三区| 国产精品自拍小视频| 中文国语毛片高清视频| 亚洲国产乱码最新视频 | 91九色极品视频| 亚洲欧美在线观看视频| 欧美性xxxxxxxx| 2021国产视频| 久久一日本道色综合久久| www国产亚洲精品久久网站| 潘金莲一级淫片aaaaaaa| 久久老女人爱爱| 91久久中文字幕| 国产污污视频在线观看| 欧美老肥妇做.爰bbww| 日韩 欧美 视频| 美女视频免费一区| 亚洲大胆人体在线| 国产三级三级三级看三级| 婷婷丁香花五月天| 三级精品视频久久久久| 91蝌蚪视频在线观看| 国产高清亚洲一区| 国产精品嫩草影院一区二区| 午夜69成人做爰视频| 色av成人天堂桃色av| 久精品国产欧美| 中文在线字幕免费观| 亚洲精品久久久久中文字幕欢迎你 | 777午夜精品免费视频| 日韩欧美不卡在线| www.久久伊人| 中文字幕久热精品视频在线| 男人网站在线观看| 亚洲免费观看在线观看| 色噜噜一区二区| 午夜视频1000| 久久久久久国产| 久久久久久久久久97| 欧美性一区二区| 精品国产成人av在线免| 日本91福利区| 777精品视频| 久久久国产精品黄毛片| 欧美一区二区三区系列电影| 免费激情视频在线观看| 久久综合狠狠综合久久激情 | 日本欧美国产在线| 国产一级特黄a高潮片| 性做久久久久久免费观看| 中文字幕欧美日韩一区二区三区 | 精品久久久99| 欧美国产日韩精品免费观看| 国产欧美一区二区三区久久| 中文字幕第15页| 亚洲国产三级网| 影音先锋资源av| 亚洲一区在线视频观看| 日日噜噜夜夜狠狠久久丁香五月| 奇米综合一区二区三区精品视频| 538国产精品视频一区二区| 久久精品国产亚洲av无码娇色| 日韩视频免费观看高清完整版在线观看| 国产一级特黄a大片免费| 国产日韩欧美精品一区| 免费日韩电影在线观看| 深爱激情五月婷婷| 91精品国产乱码久久久久久蜜臀 | 五月婷婷综合色| 美国一区二区三区在线播放 | 99久久精品免费视频| 综合av第一页| 影音先锋在线亚洲| 国产一级精品在线| 55夜色66夜色国产精品视频| 国产一级在线观看视频| 亚洲精品第一国产综合精品| 国产精品无码一区二区三| 色一情一伦一子一伦一区| 99草草国产熟女视频在线| 欧美国产欧美综合| 99久久国产免费免费| 99热只有这里有精品| 亚洲乱码一区av黑人高潮| 波多野吉衣中文字幕| 欧美另类久久久品| 国内自拍偷拍视频| 欧美性猛xxx| 免费成人深夜夜行网站视频| 国产精品一区二区在线观看不卡| 99re国产视频| 久久精品二区三区| 国产精品视频在线观看| 96日本xxxxxⅹxxx17| 久久久久久69| 日韩精品一区二区亚洲av| 最近中文字幕mv在线一区二区三区四区 | 在线观看高清免费视频| 亚洲欧美日韩人成在线播放| 欧美狂野激情性xxxx在线观| 91色porny在线视频| 亚洲综合色激情五月| 99超碰在线观看| 深夜福利一区二区| 欧美人妻一区二区| 亚洲老司机av| 中文字幕无码日韩专区免费| 亚洲国内高清视频| 欧美激情 一区| 欧美成人bangbros| 一级肉体全黄裸片| 色综合久久久久综合99| 色综合天天色综合| 亚洲成av人影院在线观看网| 久草在在线视频| 亚洲一级片在线观看| 99视频精品免费| 亚洲综合在线观看视频| 密臀av一区二区三区| 亚洲国产精品自拍| 日韩一区二区三区不卡视频| 亚洲成a人片在线不卡一二三区| 亚洲第一狼人区| 精品久久久久久久大神国产| 岛国av免费在线| 图片区小说区区亚洲影院| 一起操在线视频| 一本色道久久综合亚洲精品按摩| 91在线第一页| 亚洲一级二级三级| 丰满少妇在线观看| 一区二区三区视频在线观看 | 久久99久久精品| 久草热久草热线频97精品| 国产精品一二三在| 神马欧美一区二区| 久久天堂av综合合色蜜桃网| 日韩在线观看a| 亚洲乱码一区二区三区在线观看| 亚洲黄色a v| 91精品1区2区|