久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

springboot接入微信app支付的方法

瀏覽:126日期:2022-06-15 18:17:21
1.前戲

1.1請先完成微信APP支付接入商戶服務中心

1.2詳情請參考微信官方文檔:https://open.weixin.qq.com/

2.application.yml文件的配置如下

#微信支付配置tenpayconfig: #商戶APPID appId: asdfg12345 #商戶號 mchId: 12345678 #商戶的key(API密匙) key: qwertyuiop #API支付請求地址 payUrl: https://api.mch.weixin.qq.com/pay/unifiedorder #API查詢請求地址 queryUrl: https://api.mch.weixin.qq.com/pay/orderquery #package packageValue: Sign=WXPay3.配置文件對應的TenpayConfig,若沒集成lombok請自行生成get/set方法

import org.springframework.boot.context.properties.ConfigurationProperties;import org.springframework.stereotype.Component;import lombok.Data;/** * @Description: 微信支付配置類 * @Param: * @return: * @Author: zengXianKang * @Date: 2019/7/28 */@Data@Component@ConfigurationProperties(prefix = 'tenpayconfig')public class TenpayConfig { //appId private String appId; //商戶號 private String mchId; //商戶的key(API密匙) private String key; //API支付請求地址 private String payUrl; //API查詢請求地址 private String queryUrl; //Sign=WXPay private String packageValue;}

3.1新建一個TenPayVO

import java.math.BigDecimal;import lombok.Data;/** * @description: TenPayVO * @author: zengXianKang * @create: 2019-07-28 **/@Datapublic class TenPayVO { //商戶訂單號 private String outTradeNo; //業務結果 private String resultCode; //簽名方式 private String signType; //簽名 private String sign; //交易類型 private String tradeType; //交易狀態 private String tradeState; //商戶號 private String mchId; //付款銀行 private String bankType; //支付金額 private BigDecimal totalFee; //幣種 private String feeType; //微信支付訂單號 private String transactionId; //支付完成時間 private String timeEnd;}

3.2由于微信支付和回調的報文都是xml,先在maven中添加xstream的jar依賴

<!--xstream--><dependency> <groupId>com.thoughtworks.xstream</groupId> <artifactId>xstream</artifactId> <version>1.4.7</version></dependency>

3.3TenPayUtils工具類,直接拿去用吧,該用到的我基本都寫好了,拿走不謝

import com.github.pagehelper.util.StringUtil;import com.huaku.ecom.common.config.TenpayConfig;import com.thoughtworks.xstream.XStream;import com.thoughtworks.xstream.converters.Converter;import com.thoughtworks.xstream.converters.MarshallingContext;import com.thoughtworks.xstream.converters.UnmarshallingContext;import com.thoughtworks.xstream.io.HierarchicalStreamReader;import com.thoughtworks.xstream.io.HierarchicalStreamWriter;import com.thoughtworks.xstream.io.xml.DomDriver;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Component;import javax.annotation.PostConstruct;import javax.net.ssl.HttpsURLConnection;import java.io.*;import java.net.URL;import java.security.NoSuchAlgorithmException;import java.util.*;import java.util.Map.Entry;/** * TenPayUtils * @author :zengXianKang */@Componentpublic class TenPayUtils { private static TenPayUtils tenPayUtils; @Autowired private TenpayConfig tenpayConfig; @PostConstruct public void init(){tenPayUtils = this;tenPayUtils.tenpayConfig = this.tenpayConfig; } /** * @Description: 微信支付簽名 * * @Param: [paramsMap, charSetName] * @return: java.lang.String * @Author: zengXianKang * @Date: 2019/7/28 */ public String createSign(SortedMap<String, Object> paramsMap, String charSetName) throws UnsupportedEncodingException, NoSuchAlgorithmException {StringBuffer buffer = new StringBuffer();//參數按照ACCSII排序(升序)Set set = paramsMap.entrySet();Iterator iterator = set.iterator();while (iterator.hasNext()){ Map.Entry entry = (Map.Entry) iterator.next(); String key = (String) entry.getKey(); String value = (String) entry.getValue(); if(!key.equals('sign') && StringUtil.isNotEmpty(value)){buffer.append(key + '=' + value + '&'); }}buffer.append('key=' + tenPayUtils.tenpayConfig.getKey());String sign = MDUtils.MD5EncodeForHex(buffer.toString(), charSetName).toUpperCase();return sign; } /** * @Description: 組裝微信支付請求報文 * * @Param: [paramsMap] * @return: java.lang.String * @Author: zengXianKang * @Date: 2019/7/28 */ public static String tenPayXmlInfo(SortedMap<String, Object> paramsMap){StringBuffer buffer = new StringBuffer();if(paramsMap != null){ buffer.append('<xml>'); for(Map.Entry<String, Object> entry : paramsMap.entrySet()){buffer.append('<').append(entry.getKey()).append('><![CDATA[').append(entry.getValue()).append(']]></').append(entry.getKey()).append('>'); } buffer.append('</xml>');}return buffer.toString(); } /** * @Description: 請求調用URL * * @Param: [requestUrl, requestMethod, output] * @return: java.lang.String * @Author: zengXianKang * @Date: 2019/7/28 */ public static String httpsRequest(String requestUrl, String requestMethod, String output) throws Exception {URL url = new URL(requestUrl);HttpsURLConnection connection = (HttpsURLConnection) url.openConnection();connection.setDoOutput(true);connection.setDoInput(true);connection.setUseCaches(false);connection.setRequestMethod(requestMethod);if(StringUtil.isNotEmpty(output)){ OutputStream outputStream = connection.getOutputStream(); outputStream.write(output.getBytes('UTF-8')); outputStream.close();}InputStream inputStream = connection.getInputStream();InputStreamReader inputStreamReader = new InputStreamReader(inputStream, 'utf-8');BufferedReader bufferedReader = new BufferedReader(inputStreamReader);String str = null;StringBuffer buffer = new StringBuffer();while ((str = bufferedReader.readLine()) != null) { buffer.append(str);}bufferedReader.close();inputStreamReader.close();inputStream.close();connection.disconnect();return buffer.toString(); } /** * @Description: 解析xml * * @Param: [xml, rootName, rowName] * @return: java.lang.Object * @Author: zengXianKang * @Date: 2019/7/28 */ public static Object readXml(String xml, String rootName, String rowName){XStream xStream = new XStream(new DomDriver());xStream.alias(rootName, Map.class);xStream.registerConverter(new TenPayUtils.MapEntryConverter(rowName));Object object = xStream.fromXML(xml);return object; } /** * @Description: 內部類,readXml專用 * * @Param: * @return: * @Author: zengXianKang * @Date: 2019/7/28 */ public static class MapEntryConverter implements Converter {private String rowName;public MapEntryConverter(String rowName) { this.rowName = rowName;}public boolean canConvert(Class clazz) { return Map.class.isAssignableFrom(clazz) || LinkedHashMap.class.isAssignableFrom(clazz);}public void marshal(Object value, HierarchicalStreamWriter writer, MarshallingContext context) { this._marshal(value, writer, context);}private void _marshal(Object value, HierarchicalStreamWriter writer, MarshallingContext context) { Iterator i$; Object object; if (value instanceof Map) {Map map = (Map) value;for (i$ = map.entrySet().iterator(); i$.hasNext(); writer.endNode()) { object = i$.next(); Entry entry = (Entry) object; Object _key = entry.getKey(); Object _value = entry.getValue(); writer.startNode(entry.getKey().toString()); if (_value instanceof Map) {this._marshal(_value, writer, context); } else if (_value instanceof List) {this._marshal(_value, writer, context); } else {writer.setValue(entry.getValue().toString()); }} } else if (value instanceof List) {List list = (List) value;for (i$ = list.iterator(); i$.hasNext(); writer.endNode()) { object = i$.next(); writer.startNode(this.rowName); if (!(object instanceof Map) && !(object instanceof List)) {writer.setValue(object.toString()); } else {this._marshal(object, writer, context); }} }}public Object unmarshal(HierarchicalStreamReader reader, UnmarshallingContext context) { return this._unmarshal(reader, context);}public Object _unmarshal(HierarchicalStreamReader reader, UnmarshallingContext context) { Map map = new HashMap(); List list = new ArrayList(); boolean isList; for (isList = false; reader.hasMoreChildren(); reader.moveUp()) {reader.moveDown();String nodeName = reader.getNodeName();if (reader.hasMoreChildren()) { if (isList) {list.add(this._unmarshal(reader, context)); } else if (map.containsKey(nodeName)) {isList = true;list.add(map.remove(nodeName));list.add(this._unmarshal(reader, context)); } else if (this.rowName.equals(nodeName)) {isList = true;list.add(this._unmarshal(reader, context)); } else {map.put(nodeName, this._unmarshal(reader, context)); }} else { String value = reader.getValue(); if (isList) {list.add(value); } else if (map.containsKey(nodeName)) {isList = true;list.add(map.remove(nodeName));list.add(value); } else if (this.rowName.equals(nodeName)) {isList = true;list.add(value); } else {map.put(nodeName, value); }} } return isList ? list : map;} }}4.請求微信支付

在很多電商的項目中都有類似保存訂單,充值等一系列微信支付場景;我們需要發起支付返回給前端支付sdk;該篇博文為微信支付的博文,支付寶支付的博文我也已編寫,若有興趣的話可以去我的博文中看看,希望能幫到你。

4.1發起支付請求

/** * @Description: 支付請求 * @Param: [payType, outTradeNo, totalAmount] * @return: java.util.Map<java.lang.String,java.lang.String> * @Author: zengXianKang * @Date: 2019/7/28 */ @Override public Map<String, String> payRequest(String payType, String outTradeNo, BigDecimal totalAmount) throws Exception {Map<String, String> map = new HashMap<String, String>();switch (PayTypeEnum.valueOf(payType)) { case TENPAY://財付通SortedMap<String, Object> paramsMap = new TreeMap<String, Object>();//公眾賬號IDparamsMap.put('appid', tenpayConfig.getAppId());//商戶號paramsMap.put('mch_id', tenpayConfig.getMchId());//隨機字符串paramsMap.put('nonce_str', Convert.getUUID());//描述paramsMap.put('body', '名繪優家訂單支付');//商戶訂單號(支付編號)paramsMap.put('out_trade_no', outTradeNo);//支付金額,金額單位為 分double price = totalAmount.doubleValue();int totalFee = (int) (price * 100);paramsMap.put('total_fee', String.valueOf(totalFee));//回調地址paramsMap.put('notify_url', ConstantInfo.TENPAY_ORDER_CALLBACK);//交易類型paramsMap.put('trade_type', 'APP');//用戶端ipString spbillCreateIp = '';InetAddress inetAddress = InetAddress.getLocalHost();if (inetAddress != null) { spbillCreateIp = inetAddress.getHostAddress();}paramsMap.put('spbill_create_ip', spbillCreateIp);TenPayUtils tenPayUtils = new TenPayUtils();//sign簽名String sign = tenPayUtils.createSign(paramsMap, 'UTF-8');paramsMap.put('sign', sign);//請求報文String requestXml = TenPayUtils.tenPayXmlInfo(paramsMap);//logger.info('微信支付請求報文: ' + requestXml);//發送微信支付post請求String tenPayPost = TenPayUtils.httpsRequest(tenpayConfig.getPayUrl(), 'POST', requestXml);//獲取返回Map<String, String> tenPayMap = (Map<String, String>) TenPayUtils.readXml(tenPayPost, 'xml', '');//微信返回狀態碼if (!tenPayMap.get('return_code').equals('SUCCESS')) { logger.error('微信支付請求連接失敗: ' + tenPayMap.get('return_msg')); throw new RRException(AppWSConstant.RS_MSG_TENPAY_FALL);}//業務結果if (!tenPayMap.get('result_code').equals('SUCCESS')) { logger.error('err_code: ' + tenPayMap.get('err_code'), 'err_code_des: ' + tenPayMap.get('err_code_des')); throw new RRException(AppWSConstant.RS_MSG_TENPAY_FALL);}//APPIDmap.put('appid', tenPayMap.get('appid'));//商戶號map.put('partnerid', tenPayMap.get('mch_id'));//預支付交易會話IDmap.put('prepayid', tenPayMap.get('prepay_id'));//擴展字段map.put('package', tenpayConfig.getPackageValue());//隨機字符串map.put('noncestr', tenPayMap.get('nonce_str'));//時間戳map.put('timestamp', String.valueOf(new Date().getTime()).substring(0, 10));SortedMap<String, Object> signMap = new TreeMap<>(map);String newSign = tenPayUtils.createSign(signMap, 'UTF-8');//簽名map.put('sign', newSign);break; default:break;}return map; }

4.1.1ConstantInfo中的內容為

/** * 常量 */public class ConstantInfo { //訂單支付財付通回調地址 public static String TENPAY_ORDER_CALLBACK = 'http://mall.gzmhyj.com:8085/huakuEComBuyer/pay/tenPayOrderCallBack';}

4.2訂單微信支付回調

該接口為為微信異步回調提供的接口

/** * @Description: 訂單微信支付回調 * * @Param: [request] * @return: java.util.Map<java.lang.String,java.lang.String> * @Author: zengXianKang * @Date: 2019/7/28 */ @RequestMapping(value = '/tenPayOrderCallBack', method = RequestMethod.POST) @ResponseBody public Map<String, String> tenPayOrderCallBack(HttpServletRequest request){Map<String, String> map = new HashMap<String, String>();try { TenPayVO tenPayVO = payService.tenPayCallBack(request); payService.tenPayOrderCallBack(tenPayVO); map.put('return_code', 'SUCCESS'); map.put('return_msg', 'OK');} catch (Exception e) { e.printStackTrace();}return map; }

4.2.1payService的tenPayCallBack,用于解析回調的信息,拼接TenPayVO

/** * @Description: 財付通回調 * @Param: [request] * @return: TenPayVO * @Author: zengXianKang * @Date: 2019/7/28 */ @Override public TenPayVO tenPayCallBack(HttpServletRequest request) throws Exception {InputStream inputStream = request.getInputStream();StringBuffer resXml = new StringBuffer();BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(inputStream, 'UTF-8'));String str;while ((str = bufferedReader.readLine()) != null) { resXml.append(str);}bufferedReader.close();inputStream.close();//logger.info('微信回調報文: ' + resXml);TenPayVO tenPayVO = this.tenPayCallBackInfo(resXml.toString(), 'xml', '');return tenPayVO; }

4.2.2tenPayCallBackInfo,用于解析微信支付回調返回結果,拼接TenPayVO

/** * @Description: 微信支付回調返回結果 * @Param: [xml, rootName, rowName] * @return: com.huaku.ecom.system.model.vo.TenPayVO * @Author: zengXianKang * @Date: 2019/7/28 */ private TenPayVO tenPayCallBackInfo(String xml, String rootName, String rowName) throws Exception {Map<String, Object> resHashMap = (Map<String, Object>) TenPayUtils.readXml(xml, 'xml', '');SortedMap<String, Object> resMap = new TreeMap<String, Object>(resHashMap);//微信返回狀態碼if (!resMap.get('return_code').equals('SUCCESS')) { logger.error('微信支付回調連接失敗: ' + resMap.get('return_msg')); throw new RRException(AppWSConstant.RS_MSG_TENPAY_FALL);}//業務結果if (!resMap.get('result_code').equals('SUCCESS')) { logger.error('err_code: ' + resMap.get('err_code'), 'err_code_des: ' + resMap.get('err_code_des')); throw new RRException(AppWSConstant.RS_MSG_TENPAY_FALL);}TenPayUtils tenPayUtils = new TenPayUtils();//校驗簽名String sign = tenPayUtils.createSign(resMap, 'UTF-8');if (!sign.equals(resMap.get('sign'))) { logger.error('微信支付回調簽名不正確'); throw new RRException(AppWSConstant.RS_MSG_TENPAY_FALL);}TenPayVO tenPayVO = new TenPayVO();//商戶訂單號tenPayVO.setOutTradeNo((String) resMap.get('out_trade_no'));//業務結果tenPayVO.setResultCode((String) resMap.get('result_code'));//簽名方式tenPayVO.setSignType('ASCII');//簽名tenPayVO.setSign((String) resMap.get('sign'));//交易類型tenPayVO.setTradeType('APP');//交易狀態tenPayVO.setTradeState((String) resMap.get('trade_state'));//商戶號tenPayVO.setMchId((String) resMap.get('mch_id'));//付款銀行tenPayVO.setBankType((String) resMap.get('bank_type'));//交易金額BigDecimal totalFee = new BigDecimal((String) resMap.get('total_fee'));totalFee = totalFee.divide(new BigDecimal(100));tenPayVO.setTotalFee(totalFee);//幣種if (resMap.containsKey('fee_type')) { tenPayVO.setFeeType((String) resMap.get('fee_type'));}//微信支付訂單號tenPayVO.setTransactionId((String) resMap.get('transaction_id'));//支付完成時間tenPayVO.setTimeEnd((String) resMap.get('time_end'));return tenPayVO; }

4.2.3payService的tenPayOrderCallBack,用于自己的回調完成的業務邏輯,如修改訂單狀態,存微信支付交易表等操作

/** * @Description: 微信支付訂單回調 * @Param: [tenPayVO] * @return: void * @Author: zengXianKang * @Date: 2019/7/28 */ @Override public void tenPayOrderCallBack(TenPayVO tenPayVO) throws Exception {if (tenPayVO != null && tenPayVO.getResultCode().equals('SUCCESS') && tenPayVO.getTradeState().equals('SUCCESS')) { //根據交易編號加鎖,處理高并發 synchronized (tenPayVO.getOutTradeNo()) {TOrder order = orderMapper.getOneOrderByPayNo(tenPayVO.getOutTradeNo());if (order.getOrderStatus().equals(OrderStatusEnum.PENDING_PAYMENT.toString())) { //訂單需支付金額總和 BigDecimal payNumSum = this.getPayNumSumByPayNo(tenPayVO.getOutTradeNo()); String orderStatus = ''; //以防萬一,再次校驗金額 if (payNumSum.compareTo(tenPayVO.getTotalFee()) != 0) {logger.error('***訂單號: ' + tenPayVO.getOutTradeNo() + '***微信支付支付金額與訂單需支付金額總和不一致***微信支付金額為:' + tenPayVO.getTotalFee() + ' ***訂單需支付金額總為:' + payNumSum + '***日期:' + new Date());//金額異常,訂單狀態為支付金額異常orderStatus = OrderStatusEnum.ABNORMAL_PAYMENT_AMOUNT.toString(); } else {//金額正常,訂單狀態為已付款(待發貨)orderStatus = OrderStatusEnum.WAIT_FOR_DELIVERY.toString(); } //修改訂單狀態 int orderFlag = orderMapper.updatePayOrderStatusByPayNo(orderStatus, tenPayVO.getOutTradeNo()); //微信支付交易記錄表 TTenpayTradeLog tenpayTradeLog = new TTenpayTradeLog(); tenpayTradeLog.setTradeLogId(Convert.createUniqueId(idWorker)); //簽名方式 tenpayTradeLog.setSignType(tenPayVO.getSignType()); //交易方式 tenpayTradeLog.setTradeMode(tenPayVO.getTradeType()); //交易狀態 tenpayTradeLog.setTradeStatus(tenPayVO.getResultCode()); //商戶號 tenpayTradeLog.setPartner(tenPayVO.getMchId()); //銀行類型 tenpayTradeLog.setBankType(tenPayVO.getBankType()); //交易金額 tenpayTradeLog.setTotalFee(tenPayVO.getTotalFee()); //幣種 tenpayTradeLog.setFeeType(tenPayVO.getFeeType()); //微信支付訂單號 tenpayTradeLog.setTransactionId(tenPayVO.getTransactionId()); //商戶訂單號 tenpayTradeLog.setOutTradeNo(tenPayVO.getOutTradeNo()); //支付完成時間 tenpayTradeLog.setTimeEnd(tenPayVO.getTimeEnd()); int payFlag = tenpayTradeLogMapper.insertSelective(tenpayTradeLog); //若有一個操作出錯,拋錯回滾 if (!(orderFlag > 0 && payFlag == 1)) {logger.error('微信支付訂單回調失敗');throw new RRException(AppWSConstant.RS_MSG_TENPAY_FALL); }} else { logger.info('該訂單已支付處理,交易編號為: ' + tenPayVO.getOutTradeNo()); throw new RRException(AppWSConstant.RS_MSG_ORDER_PAY_ERROR);} }} }

4.3定時任務主動查詢微信支付回調,一般微信發起的異步回調都是無序不定時的,所以一般保險起見都會寫一個自己的定時任務主動查詢微信支付回調

/** * 定時任務:每十五分鐘觸發一次主動調用訂單支付回調 */ @Scheduled(cron = '0 */15 * * * ?') public void initiativeOrderPayCallBack(){//主動調用訂單支付回調try { payService.initiativeOrderPayCallBack();} catch (Exception e) { logger.error('timer initiativeOrderPayCallBack Error.', e); e.printStackTrace();} }

4.3.1payService的initiativeOrderPayCallBack,用于主動查詢微信支付回調與回調業務邏輯處理

/** * 主動調用訂單支付回調 * * @throws Exception */ @Override public void initiativeOrderPayCallBack() throws Exception {//查詢訂單狀態為orderStatus的支付編號List<Map<String, String>> payNoList = orderMapper.getPayNoByStatus(OrderStatusEnum.PENDING_PAYMENT.toString());for (Map<String, String> map : payNoList) { try {switch (PayTypeEnum.valueOf(map.get('payType'))) { case TENPAY://財付通TenPayVO tenPayVO = this.tenPayQueryCallBack(map.get('payNo'));//訂單回調處理this.tenPayOrderCallBack(tenPayVO);break; default:break;} } catch (Exception e) {logger.error(e.getMessage());e.printStackTrace(); }} }

4.3.2payService的tenPayQueryCallBack,用于主動查詢微信支付回調,拼接TenPayVO

/** * @Description: 微信支付主動查詢回調 * @Param: [payNo] * @return: com.huaku.ecom.system.model.vo.TenPayVO * @Author: zengXianKang * @Date: 2019/5/30 */ @Override public TenPayVO tenPayQueryCallBack(String payNo) throws Exception {SortedMap<String, Object> paramsMap = new TreeMap<String, Object>();//應用APPIDparamsMap.put('appid', tenpayConfig.getAppId());//商戶號paramsMap.put('mch_id', tenpayConfig.getMchId());//商戶訂單號paramsMap.put('out_trade_no', payNo);//隨機字符串paramsMap.put('nonce_str', Convert.getUUID());TenPayUtils tenPayUtils = new TenPayUtils();//簽名String sign = tenPayUtils.createSign(paramsMap, 'UTF-8');paramsMap.put('sign', sign);//請求報文String requestXml = TenPayUtils.tenPayXmlInfo(paramsMap);//發送微信查詢post請求String tenQueryPost = TenPayUtils.httpsRequest(tenpayConfig.getQueryUrl(), 'POST', requestXml);TenPayVO tenPayVO = this.tenPayCallBackInfo(tenQueryPost, 'xml', '');return tenPayVO; }

到此這篇關于springboot接入微信app支付的方法的文章就介紹到這了,更多相關springboot App微信支付內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: 微信
相關文章:
主站蜘蛛池模板: 日韩欧美在线观看视频 | 精品久久久久久久人人人人传媒 | 国产精品1区2区3区 中文字幕一区二区三区四区 | 中文字幕在线免费视频 | 特级丰满少妇一级aaaa爱毛片 | 国产综合视频 | 久久久tv| 蜜桃视频麻豆女神沈芯语免费观看 | 久久久日本 | 四虎av成人 | 久久国产日韩 | 成人免费在线观看视频 | 久久四色 | 久久窝| 激情久久久 | 日韩中文字幕av | 国产精品福利在线观看 | 午夜在线 | 玖玖久久 | 久久成人高清 | 精品成人av | 日韩专区在线播放 | 天天操天天干视频 | 亚洲成人av | 欧美日韩一区在线观看 | 涩涩999 | 国产免费av在线 | 日本爱爱 | 国产日韩精品久久 | 视频在线一区 | 国产精品久久精品 | 久久亚洲二区 | 国产在线中文字幕 | 欧美一区二区三区在线观看 | 亚洲成人影院在线观看 | 狠狠色狠狠色合久久伊人 | 女同久久| 亚洲天天操| 亚洲毛片在线观看 | 午夜欧美 | 成人在线观看av | 国产一区二区三区四区视频 | 欧美日韩国产一区二区 | 久久一区二区三区四区 | av网址在线播放 | 国产精品日韩欧美一区二区 | 欧美日韩一区二区在线 | 干干干操操操 | 黄色网在线 | 欧美日韩一区二区中文字幕 | 亚洲精品一区二区三区蜜桃久 | 日韩视频一区二区三区 | 91免费在线播放 | 亚洲免费视频一区 | 久久国产精品影视 | 中国毛片基地 | 日韩综合一区 | 91久久| 亚洲精品在线成人 | 日本亚洲精品一区二区三区 | 久久久久一区 | 蜜桃视频网站在线观看 | 黄色网免费看 | 精品欧美乱码久久久久久1区2区 | 久久久成人精品 | 午夜免费看片 | 久草免费福利 | 亚洲综合视频在线 | 国产3区 | 色视频网站在线观看 | 夜夜草视频 | 91久久久久久久久久久久久久久久 | 国产在线一区二区 | 在线精品观看 | 欧美成人免费观看 | 久久精品2| 99久久婷婷国产综合亚洲 | 国产精品第一区 | 精品一区二区三区三区 | 欧美a在线看| 性xxxxxxxxx18欧美 | 久久综合久久久 | 男人的天堂久久 | 一区二区日韩精品 | 91亚洲精品一区 | 操操操av| 久久久久久毛片免费观看 | 六月丁香av | 欧美亚洲视频在线观看 | 亚洲成人三区 | 91视频网址 | 色综合久久久久 | 四虎永久免费在线 | 国产美女网站视频 | 国产成年免费视频 | 久久久久久国产精品久久 | 亚洲精品中文字幕 | 欧美日韩一 | 亚洲第一福利视频 | 最新黄色网址在线播放 | 日本a视频 | 夜夜av| 日韩艹逼视频 | 91久久久精品视频 | 美女h在线观看 | 91精品久久久久久久久久入口 | 中文字幕在线观看亚洲 | 亚洲精品乱码久久观看网 | 一区二区三区亚洲 | 成人精品久久久 | 午夜成人在线视频 | 亚洲一区二区在线视频 | 久久精品视频网 | 免费xxxxx在线观看网站软件 | 日本中文字幕在线观看 | 欧美综合久久 | 操人网 | 免费看片色 | 中文字幕一区二区三区四区五区 | 欧美精品1区 | 欧美一级欧美三级在线观看 | 韩国三级中文字幕hd久久精品 | 亚洲综合在线一区二区 | 最近的中文字幕在线看视频 | 国产不卡视频在线观看 | 1000部精品久久久久久久久 | 日韩福利在线观看 | 国产精品三级在线 | 国产精品美女久久久久久免费 | 国产1级片 | 精品国产99 | 国产精品久久久久久久免费大片 | 国产精品片aa在线观看 | 亚洲aⅴ| 搡女人真爽免费午夜网站 | 黄色片com| 日中文字幕在线 | 亚洲视频中文字幕 | 亚洲精品国产a久久久久久 国产毛片毛片 | 日韩精品在线观看视频 | www.99久久久| 91在线资源| 免费三片在线观看网站 | 日韩视频一区二区 | 怡红院成人影院 | 亚洲人人艹 | 国产精品日韩一区二区 | 国产精品久久久久国产a级 国产精品欧美一区二区三区不卡 | 亚洲精品久久 | 午夜视频在线观看网站 | 激情自拍偷拍 | 亚洲视频在线观看 | 欧美午夜在线 | 在线免费毛片 | 一区二区三区四区在线 | 日本一区二区不卡 | 综合av第一页 | 免费xxxxx在线观看网站软件 | 欧美成人黄激情免费视频 | 欧洲成人午夜免费大片 | 久久精品国产一区二区三 | 亚洲欧美日韩在线一区二区 | 久久久久一区二区三区 | 粉嫩视频在线观看 | 五月激情综合婷婷 | 在线观看成人高清 | 欧美日韩精品在线一区 | 国产日日夜夜操 | 97av在线| 国产一区久久 | 一级黄色片视频 | 国产九色视频 | 色综合久久天天综合网 | 尤物视频在线观看 | 欧美日韩中 | 91精品麻豆日日躁夜夜躁 | 亚洲不卡视频 | 二区在线视频 | 久久久久久国产精品高清 | 成人免费小视频 | 成人性视频免费网站 | 在线观看免费视频日韩 | 夜夜爽99久久国产综合精品女不卡 | 久久国产成人 | 国产欧美一区二区三区国产幕精品 | av免费观看在线 | 欧美国产日韩在线 | 免费激情网站 | 欧美精品免费在线观看 | 国产精品亚洲一区 | 国产干干干 | 九九热精品视频 | 99热婷婷| 欧美jizzhd精品欧美巨大免费 | 91精品久久久久久综合五月天 | 亚洲毛片 | 精品日本久久 | 伊人网在线 | 91视频大全 | 国产九九精品视频 | 四虎影院观看 | 欧美最猛性xxxxx亚洲精品 | 成人精品一区二区三区 | 亚洲精品一区 | 狠狠综合久久 | 久久久久久网站 | 中文成人在线 | 国产精品久久久久久久久久久久久久 | 欧美自拍视频在线观看 | 亚洲一区电影 | 日韩精品亚洲专区在线观看 | 免费国产视频 | 九九免费视频 | 久久精品一区二区国产 | 精品国产精品 | 国产精品久久久久久一级毛片 | 另类久久 | 中文字幕在线观看av | 亚洲免费视频网址 | 2018国产大陆天天弄 | 日韩精品一区二区三区中文在线 | 中文字幕av网 | 欧美成人影院在线 | 射久久 | 免费视频爱爱太爽了 | 成人免费在线视频观看 | 亚洲一区二区在线免费观看 | 欧美一级特黄aaaaaaa在线观看 | 日韩一区在线视频 | 国产精品二区三区 | 毛片av在线 | 视频一区二区三 | 三级在线观看 | 免费欧美一级 | 天天插天天操 | 国产精品乱码一二三区的特点 | 欧美精品一区二 | 免费黄色在线 | 国产精品视频在线观看 | 国产精品久久久久婷婷二区次 | 国产亚洲精品一区二区 | 黄色精品视频 | 精品国产一区一区二区三亚瑟 | 欧美日韩一区二区在线 | 日本免费三片免费观看 | 99热最新网站 | 久久久噜噜噜www成人网 | 国产老头老太作爱视频 | 欧美日韩精品一区二区三区 | 老司机精品福利视频 | 太子妃好紧皇上好爽h | 国产日韩欧美视频 | 91精品久久久久久久久久 | 四虎影院最新地址 | 亚洲成人精品 | 国产美女视频一区 | 一级在线免费视频 | 欧美激情一区二区三区在线视频 | 国产激情亚洲 | 国产视频第一页 | 一区二区欧美视频 | 精品在线播放 | 久久99精品久久久久久琪琪 | 久久免费电影 | 久久欧美高清二区三区 | 午夜一区二区三区 | www.狠狠干 | 国偷自产av一区二区三区 | 欧美日本一区二区三区 | 欧美国产在线观看 | 亚洲一级毛片 | 九色在线视频 | 国产在线国产 | 亚洲一区二区三区免费在线 | 白浆在线 | 日韩日日夜夜 | 日本久久精品 | 久久久999精品视频 欧美老妇交乱视频 | 在线视频成人永久免费 | 中文字幕在线亚洲 | 国产欧美日韩在线观看 | 午夜影院免费体验区 | 亚洲精品乱码久久久久久久久 | 国产色在线 | 日韩欧美综合 | 天天爽天天干 | 欧美精品在欧美一区二区少妇 | 国产精品女同一区二区久久夜 | 日本久久精品视频 | 91高清视频在线观看 | 久久综合久久综合久久综合 | 久久久久久久一区 | 亚洲一区二区三区免费看 | 日韩不卡一区二区三区 | 国产精品久久久久久久久 | 日本久久精品视频 | 久久美女视频 | 国产在线中文字幕 | 91中文字幕 | 欧美国产精品一区 | 国产欧美精品一区二区三区 | 日韩毛片在线视频 | 国产一区二区精品在线观看 | 欧美精品被 | 国产免费av一区二区三区 | 久久人人网 | 国产一级黄色大片 | av手机电影 | 99精品国产在热久久 | 亚洲国产精品网站 | 亚洲欧洲免费视频 | www.久久精品 | 一级毛片一级毛片一级毛片 | 久久久国产视频 | 日本精品免费 | 色先锋资源 | 国产激情视频 | 一级黄色录像在线观看 | 成年人在线观看 | 国产精品久久久久久亚洲调教 | 最近日韩中文字幕 | 免费午夜电影 | av成人在线观看 | 亚洲香蕉视频 | 精品视频免费观看 | a级性生活片 | 亚洲xx站 | 在线影院av | 国产视频一区二区三区四区 | 亚洲精品在线播放视频 | 精品国产一区二区三区久久久蜜月 | 国产精品久久久久久久久久 | 久久精品福利 | 91在线精品视频 | 亚洲精品色 | 久久久久亚洲视频 | 国产精品久久久久久婷婷天堂 | 日韩中文在线 | 一区二区精品在线观看 | 成人影院在线 | 亚洲国产网站 | 精品亚洲成a人片在线观看 国产高清在线 | 免费精品 | 一级片黄色免费 | 久久久精品一区二区 | 国产精品久久久精品 | 日本在线播放 | 一级黄色录象片 | 欧美日韩综合视频 | 亚洲精品毛片一区二区 | 日韩欧美精品一区二区三区 | 国产伦精品一区二区三区四区视频 | aaaaaa毛片| 91资源在线| 成人欧美 | 香蕉av在线| 日韩在线免费观看视频 | 国产精品成人3p一区二区三区 | 爱爱免费视频网站 | 91福利视频导航 | 日韩一二三区视频 | 国产精品久久久久久一区二区三区 | 国产一区二区视频在线观看 | 国产精品不卡视频 | 在线成人一区 | 欧美日韩精品一区二区 | 国产一级特黄aaa大片 | 国产偷国产偷精品高清尤物 | 久久伦理电影网 | 久久69精品久久久久久久电影好 | 91久久精品国产亚洲a∨麻豆 | 一区二区三区的视频 | 精品第一页 | 日韩中文字幕在线观看 | 国产黄色在线免费看 | 久久视频一区 | 精品日韩一区二区三区 | 99精品一区二区三区 | 麻豆色呦呦 | 日韩在线播放视频 | 国产日产精品一区二区三区四区 | 国产一级视频 | 国产精品九九久久99视频 | 亚洲精品一区二区三区麻豆 | 在线精品国产 | 日本成年人免费网站 | 久热精品在线视频 | 美女黄视频网站 | 黄色地址 | 亚洲视频在线视频 | 亚洲一区二区在线视频 | 91在线中文字幕 | 成人狠狠干| 欧洲亚洲精品久久久久 | 国产在线国产 | 精品国偷自产在线 | 国产精品欧美久久久久一区二区 | 91在线精品秘密一区二区 | 国产精品久久一区性色av图片 | 日韩有码在线播放 | 国产精品久久久久国产a级 国产精品欧美一区二区三区不卡 | 国产成人综合一区二区三区 | 欧美黄色一区 | 国产亚洲成av人片在线观看桃 | 97超碰免费| 日韩欧美在线一区 | 91tv亚洲精品香蕉国产一区 | 久久精品在线 | 日本视频中文字幕 | 亚洲欧美中文日韩在线v日本 | 成人二区 | 成年人精品视频在线观看 | 欧美人体一区二区三区 | 日韩精品免费在线观看 | 免费在线成人 | 久久中文字幕一区 | 国产精品久久久久久久久久久新郎 | 欧美一区二区黄色片 | 综合色九九 | 亚洲精品久久 | 成人免费福利 | 亚洲精品视频在线观看免费 | 97免费在线观看视频 | 欧美三级网 | 欧美精品91| 夫妻午夜影院 | 国产精品久久久久久久久免费 | 91天堂| 婷婷五月色综合香五月 | 欧美日韩不卡在线 | 羞羞视频在线观看免费 | 亚洲日本韩国在线观看 | 日韩专区中文字幕 | 国产一区二区三区久久久 | 日韩综合网 | 无码日韩精品一区二区免费 | 狠狠艹 | 亚洲精品免费视频 | 亚洲午夜精品a | 一级日批片 | 久久综合热 | 成人免费视频播放 | 91在线精品秘密一区二区 | 日韩欧美一区二区视频 | 欧美一二区 | 日韩高清成人 | 综合网av| 狠狠综合| 免费一级毛片 | 国产精品a一区二区三区网址 | 国产欧美精品在线 | 日韩中文字幕在线观看 | 亚洲视频中文字幕 | 国产最好的精华液网站 | 日本久久久影视 | 国产亚洲精品美女久久久久久久久久 | 日韩成年人视频 | 啊v视频 | 免费精品 | 天天插天天干 | 精品国产鲁一鲁一区二区三区 | 青青久久| 欧美一区| 精久久 | 日韩成人免费 | 激情在线观看视频 | 欧美激情国产日韩精品一区18 | 欧美日韩大片在线观看 | 91网站在线看 | 欧美日韩中文字幕在线 | 久久久久久久一区 | 久久福利电影 | 亚洲成人网一区 | 国精日本亚洲欧州国产中文久久 | 国产日韩免费 | 免费国产wwwwwww网站 | 中文日韩在线 | 91精品国产综合久久久蜜臀粉嫩 | 能在线观看的黄色网址 | 日韩欧美在线免费观看 | 最新午夜综合福利视频 | 中文字幕免费在线 | 超碰精品在线观看 | 欧美亚洲激情 | 免费视频久久 | 欧美色综合天天久久综合精品 | 午夜在线电影 | 亚洲视频在线看 | 青青久久北条麻妃 | www.日韩系列 | 日韩一区二区在线观看视频 | 久久免费视频网 | 久久综合伊人77777 | 色综久久 | 亚洲精品一区二区另类图片 | 国产精品毛片 | 久久精品中文 | 国产操片 | 羞羞视频免费在线观看 | 欧美激情一区二区三区蜜桃视频 | 日韩另类 | 日韩欧美在线视频 | 午夜精品亚洲日日做天天做 | 亚洲jizzjizz日本少妇 | 欧美精品成人一区二区三区四区 | 亚洲 欧美日韩 国产 中文 | 亚洲在线视频 | 亚洲激情在线观看 | 亚洲欧美日韩在线一区二区 | 91精品国产自产精品男人的天堂 | 视频一区在线 | 一级片av| 91精品国产综合久久国产大片 | 国产精品久久久久久久久久久久久 | 成人免费在线视频 | 日韩午夜场 | 欧美在线亚洲 | 这里只有精品在线视频观看 | 亚洲国产一区二区在线 | 日本在线视频一区 | 羞羞的视频网站 | 欧美老妇交乱视频 | 日本久久久久 | 一区二区在线播放视频 | 不卡二区| 欧美高潮 | 在线日韩视频 | 免费成人av网 | 欧美一级电影免费观看 | 一级片视频在线观看 | 国产在线不卡视频 | 一区二区三区在线播放 | 精品综合久久 | 亚洲一区久久久 | 国产一区视频在线 | 国产欧美视频在线 | 波多野结衣亚洲 | 日韩一区二区在线观看视频 | 成人av观看 | 欧美日韩黄 | 亚洲精品国产二区 | 精品视频一区二区三区四区 | 青青草免费在线视频 | 国产高清精品在线 | 精品久久网 | 精品一区二区三区三区 | 国产成人精品久久二区二区 | 亚洲欧美激情精品一区二区 | 成人免费一区二区三区视频网站 | 成人av在线网 | 欧美日韩在线成人 | 久久精品久久久 | 成人在线亚洲 | 欧美精品综合在线 | 免费一区二区 | 欧美三级电影在线播放 | 美女视频一区二区三区 | 日韩在线播放一区二区 | 青草青草久热精品视频在线观看 | 中文字字幕一区二区三区四区五区 | 久久69精品久久久久久久电影好 | 永久精品| 福利一区二区 | 亚洲综合二区 | 亚洲一区二区三区在线播放 | 欧美中文字幕在线观看 | 99久久久免费视频 | 影音先锋中文字幕在线 | 午夜精品久久久久久久白皮肤 | 亚洲欧洲精品一区二区三区 | 九九r热| 日韩精品在线一区 | 精品国产一区二区三区在线观看 | 五月婷婷婷婷 | 91在线视频播放 | 欧美精品综合在线 | 久久综合久久久 | 一级毛片免费播放 | 久久亚洲高清 | 国产高清在线观看 | 99国产视频 | 一区二区三区免费在线 | 欧美精品影院 | 一级黄色短片 | 日韩欧美不卡 | 精品成人av | 在线观看中文字幕 | 一级全毛片 | 在线观看欧美一区 | 狠狠操网站 | 日韩极品视频 | aaa级片 | 91精品一区二区 | 欧美日韩国产一区二区三区在线观看 | 久久国产精品免费一区二区三区 | 精品一区二区三区四区视频 | 一区二区av | 成人一级电影在线观看 | 成人在线网站 | 免费大片黄在线观看 | 欧美手机在线 | a∨在线观看 | 91中文字幕在线观看 | 一区三区在线观看 | 污污视频网站 | 精品在线一区二区三区 | 欧美国产在线视频 | 亚洲乱码一区二区 | 欧美另类一区二区 | 精国产品一区二区三区四季综 | 免费久久久 | 日韩精品一区二区在线观看视频 | 1级毛片| 国产精品一区亚洲二区日本三区 | 国产欧美日韩在线观看 |