日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > php >内容正文

php

h5通过php微信支付宝支付,用H5调用支付微信公众号支付的解析

發布時間:2023/12/4 php 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 h5通过php微信支付宝支付,用H5调用支付微信公众号支付的解析 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

這篇文章主要為大家詳細介紹了微信公眾號支付H5調用支付,具有一定的參考價值,感興趣的小伙伴們可以參考一下

最近項目需要微信支付,然后看了下微信公眾號支付,雖然不難,但是細節還是需要注意的,用了大半天時間寫了個demo,并且完整的測試了一下支付流程,下面分享一下微信公眾號支付的經驗。

一、配置公眾號微信支付

需要我們配置微信公眾號支付地址和測試白名單。

比如:支付JS頁面的地址為 http://www.xxx.com/shop/pay/

那此處配置www.xxx.com/shop/pay/

二、開發流程

借用微信公眾號支付api(地址 http://pay.weixin.qq.com/wiki/doc/api/index.php?chapter=7_4),我們需要開發的為紅色標記出的。如下:

三、向微信服務器端下訂單

調用統一下單接口,這樣就能獲取微信支付的prepay_id(http://pay.weixin.qq.com/wiki/doc/api/index.php?chapter=9_1)。

在調用該接口前有幾個字段是H5支付必須填寫的openid

3.1 獲取openid

可以通過網頁授權形式(http://mp.weixin.qq.com/wiki/17/c0f37d5704f0b64713d5d2c37b468d75.html)

在微信中發送如下鏈接

https://open.weixin.qq.com/connect/oauth2/authorize?appid=wx520c15f417810387&redirect_uri=要跳轉的下訂單的url&response_type=code&scope=snsapi_base&state=123#wechat_redirect

3.2 后臺支付

代碼如下,包含預處理訂單,支付訂單等接口。package org.andy.controller;

import java.io.ByteArrayInputStream;

import java.io.IOException;

import java.io.InputStream;

import java.io.UnsupportedEncodingException;

import java.util.Date;

import java.util.HashMap;

import java.util.Iterator;

import java.util.Map;

import java.util.Map.Entry;

import java.util.Random;

import javax.servlet.ServletInputStream;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import org.apache.commons.codec.digest.DigestUtils;

import org.springframework.stereotype.Controller;

import org.springframework.web.bind.annotation.RequestMapping;

import org.xmlpull.v1.XmlPullParser;

import org.xmlpull.v1.XmlPullParserException;

import org.xmlpull.v1.XmlPullParserFactory;

import com.fasterxml.jackson.databind.JsonNode;

import com.gson.oauth.Oauth;

import com.gson.oauth.Pay;

import com.gson.util.HttpKit;

import com.gson.util.Tools;

import org.andy.util.DatetimeUtil;

import org.andy.util.JsonUtil;

import org.andy.util.SessionUtil;

import org.andy.util.WebUtil;

@Controller

@RequestMapping("/pay")

public class WXPayController {

@RequestMapping(value = "wxprepay")

public void jspay(HttpServletRequest request, HttpServletResponse response, String callback) throws Exception {

// 獲取openid

String openId = SessionUtil.getAtt(request, "openId");

if (openId == null) {

openId = getUserOpenId(request);

}

String appid = "wx16691fcb0523c1a4";

String partnerid = "22223670";

String paternerKey = "fjfjfjfjf1234567FFFFFFFFF1234567";

String out_trade_no = getTradeNo();

Map paraMap = new HashMap();

paraMap.put("appid", appid);

paraMap.put("attach", "測試支付");

paraMap.put("body", "測試購買Beacon支付");

paraMap.put("mch_id", partnerid);

paraMap.put("nonce_str", create_nonce_str());

paraMap.put("openid", openId);

paraMap.put("out_trade_no", out_trade_no);

paraMap.put("spbill_create_ip", getAddrIp(request));

paraMap.put("total_fee", "1");

paraMap.put("trade_type", "JSAPI");

paraMap.put("notify_url", "http://www.xxx.co/wxpay/pay/appPay_notify.shtml");

String sign = getSign(paraMap, paternerKey);

paraMap.put("sign", sign);

// 統一下單 https://api.mch.weixin.qq.com/pay/unifiedorder

String url = "https://api.mch.weixin.qq.com/pay/unifiedorder";

String xml = ArrayToXml(paraMap, false);

String xmlStr = HttpKit.post(url, xml);

// 預付商品id

String prepay_id = "";

if (xmlStr.indexOf("SUCCESS") != -1) {

Map map = doXMLParse(xmlStr);

prepay_id = (String) map.get("prepay_id");

}

Map payMap = new HashMap();

payMap.put("appId", appid);

payMap.put("timeStamp", create_timestamp());

payMap.put("nonceStr", create_nonce_str());

payMap.put("signType", "MD5");

payMap.put("package", "prepay_id=" + prepay_id);

String paySign = getSign(payMap, paternerKey);

payMap.put("pg", prepay_id);

payMap.put("paySign", paySign);

WebUtil.response(response, WebUtil.packJsonp(callback, JsonUtil.warpJsonNodeResponse(JsonUtil.objectToJsonNode(payMap)).toString()));

}

@RequestMapping(value = "appPay")

public void appPay(HttpServletRequest request, HttpServletResponse response, String body, String detail, String total_fee, String spbill_create_ip,

String notify_url, String trade_type, String callback) throws Exception {

String appid = "wx16691fcb0523c1a4";

String partnerid = "22223670";

String paternerKey = "fjfjfjfjf1234567FFFFFFFFF1234567";

String out_trade_no = getTradeNo();

Map paraMap = new HashMap();

paraMap.put("appid", appid);

paraMap.put("body", body);

paraMap.put("mch_id", partnerid);

paraMap.put("nonce_str", create_nonce_str());

paraMap.put("out_trade_no", out_trade_no);

paraMap.put("spbill_create_ip", spbill_create_ip);

paraMap.put("total_fee", total_fee);

paraMap.put("trade_type", trade_type);

paraMap.put("notify_url", notify_url);

String sign = getSign(paraMap, paternerKey);

paraMap.put("sign", sign);

// 統一下單 https://api.mch.weixin.qq.com/pay/unifiedorder

String url = "https://api.mch.weixin.qq.com/pay/unifiedorder";

String xml = ArrayToXml(paraMap, false);

String xmlStr = HttpKit.post(url, xml);

// 預付商品id

String prepay_id = "";

Map map = doXMLParse(xmlStr);

if (xmlStr.indexOf("SUCCESS") != -1) {

prepay_id = (String) map.get("prepay_id");

}

String result_code = map.get("result_code");

String err_code_des = map.get("err_code_des");

Map payMap = new HashMap();

payMap.put("appid", appid);

payMap.put("partnerid", partnerid);

payMap.put("prepayid", prepay_id);

payMap.put("package", "Sign=WXPay");

payMap.put("noncestr", create_nonce_str());

payMap.put("timestamp", create_timestamp());

String paySign = getSign(payMap, paternerKey);

payMap.put("sign", paySign);

payMap.put("result_code", result_code);

payMap.put("err_code_des", err_code_des);

WebUtil.response(response, WebUtil.packJsonp(callback, JsonUtil.warpJsonNodeResponse(JsonUtil.objectToJsonNode(payMap)).toString()));

}

@RequestMapping("/appPay_notify")

public void appPayNotify(HttpServletRequest request, HttpServletResponse response) throws Exception{

//String xml = "1";

response.setCharacterEncoding("UTF-8");

response.setContentType("text/xml");

ServletInputStream in = request.getInputStream();

String xmlMsg = Tools.inputStream2String(in);

Map map = doXMLParse(xmlMsg);

String return_code = map.get("return_code");

String return_msg = map.get("return_msg");

map = new HashMap();

map.put("return_code", return_code);

map.put("return_msg", return_msg);

//響應xml

String resXml = ArrayToXml(map, true);

response.getWriter().write(resXml);

}

@RequestMapping("/orderquery.do")

public void orderquery(HttpServletRequest request, HttpServletResponse response, String transaction_id, String out_trade_no, String callback) throws Exception{

String url = "https://api.mch.weixin.qq.com/pay/orderquery";

String appid = "wx16691fcb0523c1a4";

String partnerid = "22223670";

String paternerKey = "fjfjfjfjf1234567FFFFFFFFF1234567";

Map map = new HashMap();

map.put("appid", appid);

map.put("mch_id", partnerid);

if(transaction_id != null && !transaction_id.equals("")){

map.put("transaction_id", transaction_id);

}else {

map.put("out_trade_no", out_trade_no);

}

map.put("nonce_str", create_nonce_str());

String paySign = getSign(map, paternerKey);

map.put("sign", paySign);

String xml = ArrayToXml(map, false);

String xmlStr = HttpKit.post(url, xml);

Map orderMap = doXMLParse(xmlStr);

WebUtil.response(response, WebUtil.packJsonp(callback, JsonUtil.warpJsonNodeResponse(JsonUtil.objectToJsonNode(orderMap)).toString()));

}

/**

* map轉成xml

*

* @param arr

* @return

*/

public String ArrayToXml(Map parm, boolean isAddCDATA) {

StringBuffer strbuff = new StringBuffer();

if (parm != null ) {

for (Entry entry : parm.entrySet()) {

strbuff.append("");

if (isAddCDATA) {

strbuff.append();

}else {

strbuff.append(entry.getValue());

}

strbuff.append("");

}

}

return strbuff.append().toString();

}

// 獲取openId

private String getUserOpenId(HttpServletRequest request) throws Exception {

String code = request.getParameter("code");

if (code == null) {

String openId = request.getParameter("openId");

return openId;

}

Oauth o = new Oauth();

String token = o.getToken(code);

JsonNode node = JsonUtil.StringToJsonNode(token);

String openId = node.get("openid").asText();

return openId;

}

private String create_nonce_str() {

String chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";

String res = "";

for (int i = 0; i < 16; i++) {

Random rd = new Random();

res += chars.charAt(rd.nextInt(chars.length() - 1));

}

return res;

}

private String getAddrIp(HttpServletRequest request){

return request.getRemoteAddr();

}

private String create_timestamp() {

return Long.toString(System.currentTimeMillis() / 1000);

}

private String getTradeNo(){

String timestamp = DatetimeUtil.formatDate(new Date(), DatetimeUtil.DATETIME_PATTERN);

return "HZNO" + timestamp;

}

private String getSign(Map params, String paternerKey )

throws UnsupportedEncodingException {

String string1 = Pay.createSign(params, false);

String stringSignTemp = string1 + "&key=" + paternerKey;

String signValue = DigestUtils.md5Hex(stringSignTemp).toUpperCase();

return signValue;

}

private Map doXMLParse(String xml)

throws XmlPullParserException, IOException {

InputStream inputStream = new ByteArrayInputStream(xml.getBytes());

Map map = null;

XmlPullParser pullParser = XmlPullParserFactory.newInstance()

.newPullParser();

pullParser.setInput(inputStream, "UTF-8"); // 為xml設置要解析的xml數據

int eventType = pullParser.getEventType();

while (eventType != XmlPullParser.END_DOCUMENT) {

switch (eventType) {

case XmlPullParser.START_DOCUMENT:

map = new HashMap();

break;

case XmlPullParser.START_TAG:

String key = pullParser.getName();

if (key.equals("xml"))

break;

String value = pullParser.nextText();

map.put(key, value);

break;

case XmlPullParser.END_TAG:

break;

}

eventType = pullParser.next();

}

return map;

}

}

wxprepay.shtm接口是預處理訂單接口向微信服務器下訂單。

appPay.shtml接口是支付接口。

appPay_notify.shtml接口是微信支付后異步通知結果接口。

orderquery.shtml接口是訂單查詢接口

3.3、涉及到的工具類SessionUtil.java工具類package org.andy.util;

import javax.servlet.http.HttpServletRequest;

public class SessionUtil {

public static void addAtt(HttpServletRequest request, String key, Object value){

request.getSession().setAttribute(key, value);

}

public static void removeAtt(HttpServletRequest request, String key){

request.getSession().removeAttribute(key);

}

public static String getAtt(HttpServletRequest request, String key){

return (String)request.getSession().getAttribute(key);

}

public static Object getAttObj(HttpServletRequest request, String key){

return request.getSession().getAttribute(key);

}

public static String optAtt(HttpServletRequest request, String key, String value){

String r = (String)request.getSession().getAttribute(key);

if (r == null){

r = value;

}

return r;

}

}

HttpKit 網絡請求工具類/**

* https 請求 微信為https的請求

*

* @author andy

* @date 2015-10-9 下午2:40:19

*/

public class HttpKit {

private static final String DEFAULT_CHARSET = "UTF-8";

/**

* @return 返回類型:

* @throws IOException

* @throws UnsupportedEncodingException

* @throws NoSuchProviderException

* @throws NoSuchAlgorithmException

* @throws KeyManagementException

* @description 功能描述: get 請求

*/

public static String get(String url, Map params, Map headers) throws IOException, ExecutionException, InterruptedException {

AsyncHttpClient http = new AsyncHttpClient();

AsyncHttpClient.BoundRequestBuilder builder = http.prepareGet(url);

builder.setBodyEncoding(DEFAULT_CHARSET);

if (params != null && !params.isEmpty()) {

Set keys = params.keySet();

for (String key : keys) {

builder.addQueryParameter(key, params.get(key));

}

}

if (headers != null && !headers.isEmpty()) {

Set keys = headers.keySet();

for (String key : keys) {

builder.addHeader(key, params.get(key));

}

}

Future f = builder.execute();

String body = f.get().getResponseBody(DEFAULT_CHARSET);

http.close();

return body;

}

/**

* @return 返回類型:

* @throws IOException

* @throws UnsupportedEncodingException

* @throws NoSuchProviderException

* @throws NoSuchAlgorithmException

* @throws KeyManagementException

* @description 功能描述: get 請求

*/

public static String get(String url) throws KeyManagementException, NoSuchAlgorithmException, NoSuchProviderException, UnsupportedEncodingException, IOException, ExecutionException, InterruptedException {

return get(url, null);

}

/**

* @return 返回類型:

* @throws IOException

* @throws NoSuchProviderException

* @throws NoSuchAlgorithmException

* @throws KeyManagementException

* @throws UnsupportedEncodingException

* @description 功能描述: get 請求

*/

public static String get(String url, Map params) throws KeyManagementException, NoSuchAlgorithmException, NoSuchProviderException, UnsupportedEncodingException, IOException, ExecutionException, InterruptedException {

return get(url, params, null);

}

/**

* @return 返回類型:

* @throws IOException

* @throws NoSuchProviderException

* @throws NoSuchAlgorithmException

* @throws KeyManagementException

* @description 功能描述: POST 請求

*/

public static String post(String url, Map params) throws IOException, ExecutionException, InterruptedException {

AsyncHttpClient http = new AsyncHttpClient();

AsyncHttpClient.BoundRequestBuilder builder = http.preparePost(url);

builder.setBodyEncoding(DEFAULT_CHARSET);

if (params != null && !params.isEmpty()) {

Set keys = params.keySet();

for (String key : keys) {

builder.addParameter(key, params.get(key));

}

}

Future f = builder.execute();

String body = f.get().getResponseBody(DEFAULT_CHARSET);

http.close();

return body;

}

public static String post(String url, String s) throws IOException, ExecutionException, InterruptedException {

AsyncHttpClient http = new AsyncHttpClient();

AsyncHttpClient.BoundRequestBuilder builder = http.preparePost(url);

builder.setBodyEncoding(DEFAULT_CHARSET);

builder.setBody(s);

Future f = builder.execute();

String body = f.get().getResponseBody(DEFAULT_CHARSET);

http.close();

return body;

}

}

支付工具類pay.java/**

* 支付相關方法

* @author andy

*

*/

public class Pay {

// 發貨通知接口

private static final String DELIVERNOTIFY_URL = "https://api.weixin.qq.com/pay/delivernotify?access_token=";

/**

* 參與 paySign 簽名的字段包括:appid、timestamp、noncestr、package 以及 appkey。

* 這里 signType 并不參與簽名微信的Package參數

* @param params

* @return

* @throws UnsupportedEncodingException

*/

public static String getPackage(Map params) throws UnsupportedEncodingException {

String partnerKey = ConfKit.get("partnerKey");

String partnerId = ConfKit.get("partnerId");

String notifyUrl = ConfKit.get("notify_url");

// 公共參數

params.put("bank_type", "WX");

params.put("attach", "yongle");

params.put("partner", partnerId);

params.put("notify_url", notifyUrl);

params.put("input_charset", "UTF-8");

return packageSign(params, partnerKey);

}

/**

* 構造簽名

* @param params

* @param encode

* @return

* @throws UnsupportedEncodingException

*/

public static String createSign(Map params, boolean encode) throws UnsupportedEncodingException {

Set keysSet = params.keySet();

Object[] keys = keysSet.toArray();

Arrays.sort(keys);

StringBuffer temp = new StringBuffer();

boolean first = true;

for (Object key : keys) {

if (first) {

first = false;

} else {

temp.append("&");

}

temp.append(key).append("=");

Object value = params.get(key);

String valueString = "";

if (null != value) {

valueString = value.toString();

}

if (encode) {

temp.append(URLEncoder.encode(valueString, "UTF-8"));

} else {

temp.append(valueString);

}

}

return temp.toString();

}

/**

* @param params

* @param paternerKey

* @return

* @throws UnsupportedEncodingException

*/

private static String packageSign(Map params, String paternerKey) throws UnsupportedEncodingException {

String string1 = createSign(params, false);

String stringSignTemp = string1 + "&key=" + paternerKey;

String signValue = DigestUtils.md5Hex(stringSignTemp).toUpperCase();

String string2 = createSign(params, true);

return string2 + "&sign=" + signValue;

}

/**

* 支付簽名

* @param timestamp

* @param noncestr

* @param packages

* @return

* @throws UnsupportedEncodingException

*/

public static String paySign(String timestamp, String noncestr,String packages) throws UnsupportedEncodingException {

Map paras = new HashMap();

paras.put("appid", ConfKit.get("AppId"));

paras.put("timestamp", timestamp);

paras.put("noncestr", noncestr);

paras.put("package", packages);

paras.put("appkey", ConfKit.get("paySignKey"));

// appid、timestamp、noncestr、package 以及 appkey。

String string1 = createSign(paras, false);

String paySign = DigestUtils.shaHex(string1);

return paySign;

}

/**

* 支付回調校驗簽名

* @param timestamp

* @param noncestr

* @param openid

* @param issubscribe

* @param appsignature

* @return

* @throws UnsupportedEncodingException

*/

public static boolean verifySign(long timestamp,

String noncestr, String openid, int issubscribe, String appsignature) throws UnsupportedEncodingException {

Map paras = new HashMap();

paras.put("appid", ConfKit.get("AppId"));

paras.put("appkey", ConfKit.get("paySignKey"));

paras.put("timestamp", String.valueOf(timestamp));

paras.put("noncestr", noncestr);

paras.put("openid", openid);

paras.put("issubscribe", String.valueOf(issubscribe));

// appid、appkey、productid、timestamp、noncestr、openid、issubscribe

String string1 = createSign(paras, false);

String paySign = DigestUtils.shaHex(string1);

return paySign.equalsIgnoreCase(appsignature);

}

/**

* 發貨通知簽名

* @param paras

* @return

* @throws UnsupportedEncodingException

*

* @參數 appid、appkey、openid、transid、out_trade_no、deliver_timestamp、deliver_status、deliver_msg;

*/

private static String deliverSign(Map paras) throws UnsupportedEncodingException {

paras.put("appkey", ConfKit.get("paySignKey"));

String string1 = createSign(paras, false);

String paySign = DigestUtils.shaHex(string1);

return paySign;

}

/**

* 發貨通知

* @param access_token

* @param openid

* @param transid

* @param out_trade_no

* @return

* @throws IOException

* @throws NoSuchProviderException

* @throws NoSuchAlgorithmException

* @throws KeyManagementException

* @throws InterruptedException

* @throws ExecutionException

*/

public static boolean delivernotify(String access_token, String openid, String transid, String out_trade_no) throws IOException, ExecutionException, InterruptedException {

Map paras = new HashMap();

paras.put("appid", ConfKit.get("AppId"));

paras.put("openid", openid);

paras.put("transid", transid);

paras.put("out_trade_no", out_trade_no);

paras.put("deliver_timestamp", (System.currentTimeMillis() / 1000) + "");

paras.put("deliver_status", "1");

paras.put("deliver_msg", "ok");

// 簽名

String app_signature = deliverSign(paras);

paras.put("app_signature", app_signature);

paras.put("sign_method", "sha1");

String json = HttpKit.post(DELIVERNOTIFY_URL.concat(access_token), JSONObject.toJSONString(paras));

if (StringUtils.isNotBlank(json)) {

JSONObject object = JSONObject.parseObject(json);

if (object.containsKey("errcode")) {

int errcode = object.getIntValue("errcode");

return errcode == 0;

}

}

return false;

}

}

流轉化Tools.java工具類public final class Tools {

public static final String inputStream2String(InputStream in) throws UnsupportedEncodingException, IOException{

if(in == null)

return "";

StringBuffer out = new StringBuffer();

byte[] b = new byte[4096];

for (int n; (n = in.read(b)) != -1;) {

out.append(new String(b, 0, n, "UTF-8"));

}

return out.toString();

}

public static final boolean checkSignature(String token,String signature,String timestamp,String nonce){

List params = new ArrayList();

params.add(token);

params.add(timestamp);

params.add(nonce);

Collections.sort(params,new Comparator() {

@Override

public int compare(String o1, String o2) {

return o1.compareTo(o2);

}

});

String temp = params.get(0)+params.get(1)+params.get(2);

return SHA1.encode(temp).equals(signature);

}

}

相應前端數據工具WebUtil.java工具類public class WebUtil {

public static Object getSessionAttribute(HttpServletRequest req, String key) {

Object ret = null;

try {

ret = req.getSession(false).getAttribute(key);

} catch (Exception e) {

}

return ret;

}

public static void response(HttpServletResponse response, String result) {

try {

response.setContentType("application/json;charset=utf-8");

response.getWriter().write(result);

} catch (IOException e) {

e.printStackTrace();

}

}

public static void response(HttpServletResponse response, ResponseMessage result) {

try {

response.setContentType("application/json;charset=utf-8");

response.getWriter().write(JsonUtil.objectToJsonNode(result).toString());

} catch (Exception e) {

e.printStackTrace();

}

}

public static String packJsonp(String callback, String json) {

if (json == null) {

json = "";

}

if (callback == null || callback.isEmpty()) {

return json;

}

return callback + "&&" + callback + '(' + json + ')';

}

public static String packJsonp(String callback, ResponseMessage response) {

String json = null;

if (response == null) {

json = "";

} else {

json = JsonUtil.objectToJsonNode(response).toString();

}

if (callback == null || callback.isEmpty()) {

return json;

}

return callback + "&&" + callback + '(' + json + ')';

}

}

Json轉換工具JsonUtil.javapublic class JsonUtil {

public static ObjectNode warpJsonNodeResponse(JsonNode obj){

ObjectNode objectNode=createObjectNode();

objectNode.put("code", 1);

objectNode.put("response", obj);

return objectNode;

}

public static JsonNode objectToJsonNode(Object obj){

try {

ObjectMapper objectMapper = new ObjectMapper();

String objJson=objectMapper.writeValueAsString(obj);

JsonNode jsonNode = objectMapper.readTree(objJson);

return jsonNode;

} catch (JsonProcessingException e) {

e.printStackTrace();

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

return null;

}

}

四、微信H5調起支付

這個url需要后臺實現,其實現功能如下:

1、接受微信服務器端發送的支付結果。

2、向微信服務器發送支付結果

具體 參考微信aip(http://pay.weixin.qq.com/wiki/doc/api/index.php?chapter=9_7)

具體代碼如下:

4.1、授權向后臺發起生成統一下訂單頁面wxrepay.jsp

String path = request.getContextPath();

String basePath = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + path + "/";

long t = System.currentTimeMillis();

%>

微信公眾號支付

商品

  • beacon 1分錢 1只
  • 測試支付信息

確定購買

var code = urlparameter("code");

function reppay(){

ajaxUtil({}, mainpath+"/pay/wxprepay.shtml?code=" + code, repay);

}

function repay(response){

var info = response;

var url = "wxpay?appId=" + info.appId + "&timeStamp=" +info.timeStamp + "&nonceStr=" + info.nonceStr +

"&pg=" +info.pg + "&signType=" +info.signType + "&paySign=" +info.paySign;

window.location.href= url + "&showwxpaytitle=1";

}

首先是請求服務端wxprepay.shml接口,后臺向微信支付平臺獲取支付訂單信息,返回前臺,wxpay.jsp頁面

4.2、確認支付頁面

String path = request.getContextPath();

String basePath = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + path + "/";

long t = System.currentTimeMillis();

%>

微信公眾號支付

微信js支付測試

  • 測試支付信息

立即支付

var appId = urlparameter("appId");

var timeStamp = urlparameter("timeStamp");

var nonceStr = urlparameter("nonceStr");

var pg = urlparameter("pg");

var signType = urlparameter("signType");

var paySign = urlparameter("paySign");

function onBridgeReady(){

WeixinJSBridge.invoke(

'getBrandWCPayRequest', {

"appId" : appId, //公眾號名稱,由商戶傳入

"timeStamp": timeStamp, //時間戳,自1970年以來的秒數

"nonceStr" : nonceStr, //隨機串

"package" : "prepay_id=" + pg,

"signType" : signType, //微信簽名方式:

"paySign" : paySign //微信簽名

},

function(res){

if(res.err_msg == "get_brand_wcpay_request:ok" ) {

alert("支付成功");

} // 使用以上方式判斷前端返回,微信團隊鄭重提示:res.err_msg將在用戶支付成功后返回 ok,但并不保證它絕對可靠。

}

);

}

function pay(){

if (typeof WeixinJSBridge == "undefined"){

if( document.addEventListener ){

document.addEventListener('WeixinJSBridgeReady', onBridgeReady, false);

}else if (document.attachEvent){

document.attachEvent('WeixinJSBridgeReady', onBridgeReady);

document.attachEvent('onWeixinJSBridgeReady', onBridgeReady);

}

}else{

onBridgeReady();

}

}

4.2、前臺涉及到的工具類javascript工具類common.js,樣式css.css就不貼了沒意義。var path="wxpay";

var mainpath = "/wxpay";

var appid = "wx16691fcb0523c1a4";

var urlpre = "http://www.xxx.com/wxpay/page";

var urlhost = "http://www.xxx.com/";

$(document).ready(function(){

$(".refresher").click(function(){

refresh();

});

$("#goback").click(function(){

goback();

});

});

function popupMsg(msg){

alert(msg);

}

function printUtilViaGet(panel, requestdata, ajaxurl, printfunction){

$.ajax({

type: 'GET',

url: ajaxurl,

data: requestdata,

cache:false,

dataType:"json",

async: false,

success: function(response) {

if (response.code){

if (panel != null && panel.length > 0){

$(panel).html("");

if (printfunction != null)

$(panel).html(printfunction(response.response));

}

return true;

} else {

//alert(response.reason);

}

},

error: function(x, e) {

//alert("error", x);

},

complete: function(x) {

//alert("call complete");

}

});

return false;

}

function ajaxUtilViaGet(requestdata, ajaxurl, succFunction, failFunction){

$.ajax({

url: ajaxurl,

type: "GET",

dataType: "json",

cache:false,

data: requestdata,

async: false,

success: function(response) {

if (response.code){

if (succFunction != null)

succFunction(response.response);

} else {

if (failFunction != null)

failFunction(response.response);

}

},

error: function(x, e) {

//alert("error", x);

},

complete: function(x) {

}

});

return false;

}

function printUtil(panel, requestdata, ajaxurl, printfunction, ajaxasync) {

if (isEmpty(ajaxasync)) {

ajaxasync = false;

}

$.ajax({

type : 'POST',

url : ajaxurl,

data : requestdata,

cache : false,

dataType : "json",

async : ajaxasync,

success : function(response) {

if (response.code) {

if (panel != null && panel.length > 0) {

$(panel).html("");

if (printfunction != null)

$(panel).html(printfunction(response.response));

}

return true;

} else {

// alert(response.reason);

}

},

error : function(x, e) {

// alert("error", x);

},

complete : function(x) {

// alert("call complete");

}

});

return false;

}

function appendUtil(panel, requestdata, ajaxurl, printfunction, ajaxasync) {

if (isEmpty(ajaxasync)) {

ajaxasync = false;

}

$.ajax({

type : 'POST',

url : ajaxurl,

data : requestdata,

cache : false,

dataType : "json",

async : ajaxasync,

success : function(response) {

if (response.code) {

if (panel != null && panel.length > 0) {

if (printfunction != null)

$(panel).append(printfunction(response.response));

}

return true;

} else {

// alert(response.reason);

}

},

error : function(x, e) {

// alert("error", x);

},

complete : function(x) {

// alert("call complete");

}

});

return false;

}

function ajaxUtilAsync(requestdata, ajaxurl, succFunction, failFunction) {

$.ajax({

url : ajaxurl,

type : "POST",

dataType : "json",

cache : false,

data : requestdata,

async : true,

success : function(response) {

if (typeof response.code == "number") {

if (response.code > 0) {

if (succFunction != null)

succFunction(response.response);

} else {

if (failFunction != null)

failFunction(response.response);

}

} else {

if (response.result) {

if (succFunction != null)

succFunction(response.response);

} else {

if (failFunction != null)

failFunction(response.response);

}

}

},

error : function(x, e) {

// alert("error", x);

},

complete : function(x) {

}

});

return false;

}

function ajaxUtil(requestdata, ajaxurl, succFunction, failFunction){

$.ajax({

url: ajaxurl,

type: "POST",

dataType: "json",

cache:false,

data: requestdata,

async: false,

success: function(response) {

if (typeof response.code == "number"){

if (response.code > 0){

if (succFunction != null)

succFunction(response.response);

} else {

if (failFunction != null)

failFunction(response.response);

}

} else {

if (response.result){

if (succFunction != null)

succFunction(response.response);

} else {

if (failFunction != null)

failFunction(response.response);

}

}

},

error: function(x, e) {

//alert("error", x);

},

complete: function(x) {

}

});

return false;

}

function loadSelection(panel, requestdata, ajaxurl, itemName){

ajaxUtil(requestdata, ajaxurl, function(response){

var list = response.list;

for (var i = 0;i

$(panel).append(""+list[i][itemName]+"");

}

}, null);

}

function ajaxSubmitRefresh(formId) {

var hideForm = $(formId);

var options = {

dataType : "json",

beforeSubmit : function() {

},

success : function(result) {

if (result.result){

showMsg("提交成功");

} else {

alert("提交失敗!");

}

},

error : function(result) {

alert("提交失敗!");

}

};

hideForm.ajaxSubmit(options);

}

function ajaxSubmitWithJump(formId, nextPage) {

var hideForm = $(formId);

var options = {

dataType : "json",

beforeSubmit : function() {

},

success : function(result) {

if (result.result){

alert("提交成功");

window.location.href = nextPage;

} else {

alert("提交失敗!");

}

},

error : function(result) {

alert("提交失敗!");

}

};

hideForm.ajaxSubmit(options);

}

function refresh(){

window.location.href = window.location.href;

}

function goback(){

history.go(-1);

}

function urlparameter(paras){

var url = location.href;

var paraString = url.substring(url.indexOf("?")+1,url.length).split("&");

var paraObj = {};

for (var i=0; j=paraString[i]; i++){

paraObj[j.substring(0,j.indexOf("=")).toLowerCase()] = j.substring(j.indexOf("=")+1,j.length);

}

var returnValue = paraObj[paras.toLowerCase()];

if(typeof(returnValue)=="undefined"){

return "";

}else{

return returnValue;

}

}

String.prototype.endWith=function(str){

if(str==null||str==""||this.length==0||str.length>this.length)

return false;

if(this.substring(this.length-str.length)==str)

return true;

else

return false;

return true;

};

String.prototype.startWith=function(str){

if(str==null||str==""||this.length==0||str.length>this.length)

return false;

if(this.substr(0,str.length)==str)

return true;

else

return false;

return true;

};

function getFileUrl(sourceId) {

var url = "";

if (navigator.userAgent.indexOf("MSIE")>=1) { // IE

url = document.getElementById(sourceId).value;

} else if(navigator.userAgent.indexOf("Firefox")>0) { // Firefox

url = window.URL.createObjectURL(document.getElementById(sourceId).files.item(0));

} else if(navigator.userAgent.indexOf("Chrome")>0) { // Chrome

url = window.URL.createObjectURL(document.getElementById(sourceId).files.item(0));

}

return url;

}

function preImg(sourceId, targetId) {

var url = getFileUrl(sourceId);

var imgPre = document.getElementById(targetId);

imgPre.src = url;

}

function initWX(){

$.ajax({

url:mainpath+'/wechatjs.do',

type:'POST',

dataType:'json',

async: false,

data: {url:location.href.split('#')[0]},

success:function(result){

console.log(result);

var data=result['response']['map'];

if(result['code']==1){

wx.config({

debug: false,

appId:data['appId'],

timestamp:data['timestamp'],

nonceStr:data['nonceStr'],

signature:data['signature'],

jsApiList: ['onMenuShareTimeline','onMenuShareAppMessage','getLocation', 'onMenuShareQQ', 'onMenuShareWeibo']

});

}else{

alert("fail to get code");

window.alert('fail');

};

}

});

}

var EARTH_RADIUS = 6378137.0; //單位M

var PI = Math.PI;

function getRad(d){

return d*PI/180.0;

}

function getGreatCircleDistance(lat1,lng1,lat2,lng2){

var radLat1 = getRad(lat1);

var radLat2 = getRad(lat2);

var a = radLat1 - radLat2;

var b = getRad(lng1) - getRad(lng2);

var s = 2*Math.asin(Math.sqrt(Math.pow(Math.sin(a/2),2) + Math.cos(radLat1)*Math.cos(radLat2)*Math.pow(Math.sin(b/2),2)));

s = s*EARTH_RADIUS;

s = Math.round(s*10000)/10000.0;

s = Math.round(s);

return s;

}

//對Date的擴展,將 Date 轉化為指定格式的String

//月(M)、日(d)、小時(h)、分(m)、秒(s)、季度(q) 可以用 1-2 個占位符,

//年(y)可以用 1-4 個占位符,毫秒(S)只能用 1 個占位符(是 1-3 位的數字)

//例子:

//(new Date()).Format("yyyy-MM-dd hh:mm:ss.S") ==> 2006-07-02 08:09:04.423

//(new Date()).Format("yyyy-M-d h:m:s.S") ==> 2006-7-2 8:9:4.18

Date.prototype.format = function(fmt)

{ //author: meizz

var o = {

"M+" : this.getMonth()+1, //月份

"d+" : this.getDate(), //日

"h+" : this.getHours(), //小時

"m+" : this.getMinutes(), //分

"s+" : this.getSeconds(), //秒

"q+" : Math.floor((this.getMonth()+3)/3), //季度

"S" : this.getMilliseconds() //毫秒

};

if(/(y+)/.test(fmt))

fmt=fmt.replace(RegExp.$1, (this.getFullYear()+"").substr(4 - RegExp.$1.length));

for(var k in o)

if(new RegExp("("+ k +")").test(fmt))

fmt = fmt.replace(RegExp.$1, (RegExp.$1.length==1) ? (o[k]) : (("00"+ o[k]).substr((""+ o[k]).length)));

return fmt;

};

//判斷為空

function isEmpty(src){

if(("undefined" == typeof src) || (src == null) || ($.trim(src) == "") ){

return true;

}

return false;

}

//判斷不為空

function notEmpty(src){

return !isEmpty(src);

}

//微信頁面授權 snsapi_base方式

function wecharauto2burl(url) {

return "https://open.weixin.qq.com/connect/oauth2/authorize?appid=" + appid

+ "&redirect_uri=" + encodeURIComponent(url)

+ "&response_type=code&scope=snsapi_base&state=xybank#wechat_redirect";

}

//頁面授權針對snsapi_base方式授權的url

function wecharauto2baseurl(url) {

return wecharauto2burl(urlpre+url);

}

//頁面授權針對snsapi_userinfo方式授權的url

function wecharauto2userinfourl(url) {

return "https://open.weixin.qq.com/connect/oauth2/authorize?appid=" + appid

+ "&redirect_uri=" + encodeURIComponent(urlpre+url)

+ "&response_type=code&scope=snsapi_userinfo&state=xybank#wechat_redirect";

}

//微信分享 此方法需放在wx.ready中

function shareWeChat(title, link, imgUrl, desc){

wx.onMenuShareTimeline({

title: title, // 分享標題

link: link, // 分享鏈接

imgUrl: imgUrl, // 分享圖標

success: function () {

// 用戶確認分享后執行的回調函數

},

cancel: function () {

// 用戶取消分享后執行的回調函數

}

});

//分享給朋友

wx.onMenuShareAppMessage({

title: title, // 分享標題

desc: desc, // 分享描述

link: link, // 分享鏈接

imgUrl: imgUrl, // 分享圖標

type: 'link', // 分享類型,music、video或link,不填默認為link

dataUrl: '', // 如果type是music或video,則要提供數據鏈接,默認為空

success: function () {

// 用戶確認分享后執行的回調函數

},

cancel: function () {

// 用戶取消分享后執行的回調函數

}

});

//分享到QQ

wx.onMenuShareQQ({

title: title, // 分享標題

desc: desc, // 分享描述

link: link, // 分享鏈接

imgUrl: imgUrl, // 分享圖標

success: function () {

// 用戶確認分享后執行的回調函數

},

cancel: function () {

// 用戶取消分享后執行的回調函數

}

});

//分享到騰訊微博

wx.onMenuShareWeibo({

title: title, // 分享標題

desc: desc, // 分享描述

link: link, // 分享鏈接

imgUrl: imgUrl, // 分享圖標

success: function () {

// 用戶確認分享后執行的回調函數

},

cancel: function () {

// 用戶取消分享后執行的回調函數

}

});

}

五、支付結果

公眾號調起效果如下:

支付成功后,微信服務器得到后臺的Notify通知后,會發微信說明支付信息,支付憑證如下:

后續會全部更新微信app支付,微信支付退款,微信企業向個人付款,支付寶相關支付。而且會上傳全部代碼到csdn資源下載處,盡請關注。

以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網!

總結

以上是生活随笔為你收集整理的h5通过php微信支付宝支付,用H5调用支付微信公众号支付的解析的全部內容,希望文章能夠幫你解決所遇到的問題。

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

天天操人人要 | 超碰99在线| 久久官网 | 99视频免费在线观看 | 在线导航av | 亚洲少妇久久 | 97国产精品免费 | 91久久在线观看 | 蜜桃av观看 | 久久国产精品久久久 | 天天干婷婷 | 久久影院一区 | 国产视频精品在线 | 色综合激情网 | 免费在线色电影 | 久久高清免费视频 | 九九视频免费在线观看 | 在线韩国电影免费观影完整版 | 99精品在线看 | 日韩视频免费观看高清 | 成人丝袜 | www.888.av| 成人精品99 | 特级西西444www大胆高清无视频 | 国产小视频在线播放 | 国产区av在线 | 国产精品18久久久 | 国产亚洲精品美女久久 | 免费观看第二部31集 | 欧美大片在线观看一区 | 91大神精品视频在线观看 | 一级黄色在线免费观看 | 亚洲激情 | 国产精品毛片 | 日韩色视频在线观看 | 国产一区二区视频在线播放 | 黄色av网站在线免费观看 | 国产亚洲精品久 | 久久久91精品国产 | 日韩欧美一区二区三区在线观看 | 97激情影院 | 又紧又大又爽精品一区二区 | 91视频麻豆视频 | 99这里只有精品视频 | 午夜精品久久久久久久99 | 日韩在线一区二区免费 | 成人午夜精品久久久久久久3d | 日本精品中文字幕在线观看 | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | 亚洲人视频在线 | 91在线最新 | 欧美aa一级片 | 亚洲一区二区视频在线播放 | 国产精品麻豆三级一区视频 | 天天弄天天操 | 免费看黄20分钟 | 国内小视频在线观看 | 午夜私人影院久久久久 | 欧美成人性网 | av理论电影 | 99精品在线免费 | 国产一级性生活视频 | 国产精品免费视频一区二区 | 国产精品久久久久久久久久新婚 | 高清久久久 | 麻豆播放 | 日韩在线视频观看 | 91av电影在线观看 | 国产一区二区三区免费视频 | 久久精品一区二区三区中文字幕 | 青青草久草在线 | 99免在线观看免费视频高清 | 国产美女视频 | 亚洲免费不卡 | 91中文字幕| 国精产品一二三线999 | av女优中文字幕在线观看 | 午夜精品影院 | 久久看免费视频 | 亚洲视频精品在线 | 久久久久久久久久毛片 | 中文字幕在线一区观看 | 国产在线 一区二区三区 | 在线视频免费观看 | 日本精油按摩3 | 国产精品一区二区免费在线观看 | 一区二区电影在线观看 | 不卡av电影在线 | 午夜美女福利直播 | 玖玖视频免费在线 | 国产精品成久久久久 | jizz18欧美18 | 成人av免费看 | 91香蕉国产| 97超级碰碰 | 成人久久久电影 | 中文av网站 | 国产精品久久久久永久免费看 | 久久久久久久久久久久99 | 亚洲美女视频在线 | 免费观看mv大片高清 | 有码视频在线观看 | 91私密视频 | 在线观看日韩免费视频 | 中文字幕刺激在线 | 亚洲理论视频 | 天天干夜夜擦 | 成年人视频在线免费观看 | 久草视频免费 | 日韩在线视 | 欧美一级xxxx| 免费h精品视频在线播放 | 亚洲免费av在线播放 | 91九色最新 | 狠狠操电影网 | 国产破处在线视频 | 一区二区三区免费在线播放 | 亚洲午夜久久久综合37日本 | 午夜视频在线观看欧美 | 午夜精品久久久久久久爽 | 久久99久久99精品免观看软件 | 国产在线va | 久一在线| 国产亚洲成av片在线观看 | 欧美在线a视频 | 国产精品岛国久久久久久久久红粉 | 国产最新91| 日韩大片在线播放 | 波多野结衣一区二区 | 中文字幕有码在线播放 | 天天爱综合 | 久久久久久久久精 | 精品美女在线视频 | 欧美日韩二区三区 | 亚洲欧美在线综合 | 99精品视频在线观看播放 | 亚洲三区在线 | 亚洲视频久久久久 | 久久久久久久国产精品 | 福利视频一区二区 | 国内精品久久久精品电影院 | 一级做a视频 | 99久久精品国产亚洲 | 激情久久久久久久久久久久久久久久 | 国产福利不卡视频 | 国产一级一片免费播放放a 一区二区三区国产欧美 | 三级视频片| 92精品国产成人观看免费 | 欧美日本国产在线观看 | 国产91精品一区二区 | 国产高清99 | 热99在线| 精品免费久久久久久 | 久久不卡日韩美女 | 欧美性色xo影院 | 国产视频精品网 | 亚洲国产精品传媒在线观看 | 日韩一级成人av | 久久99久久99精品中文字幕 | 亚洲欧美日韩一区二区三区在线观看 | 国产精品久久久一区二区三区网站 | 成人免费视频网 | 西西444www大胆高清图片 | 午夜 久久 tv | 亚洲另类视频 | 91漂亮少妇露脸在线播放 | 欧美日韩国产区 | 久久久久久免费 | 中文字幕精品www乱入免费视频 | 高清av网| 久久久免费毛片 | 99中文字幕在线观看 | 操操操综合 | 色丁香婷婷 | 久久精品视频国产 | 午夜在线观看影院 | 免费在线观看日韩欧美 | www视频在线播放 | 国产第一页在线播放 | 最近免费观看的电影完整版 | 992tv成人免费看片 | 国产成人黄色 | 免费黄色网止 | 激情黄色av| 在线观看黄网站 | 日韩中文在线视频 | 视频在线观看国产 | 中文字幕乱码视频 | 久久综合一本 | 丁香色天天| 亚洲成人黄色网址 | av中文字幕不卡 | 欧美大香线蕉线伊人久久 | 亚洲视频在线播放 | 18av在线视频 | 免费观看国产精品 | 国产免费作爱视频 | 亚洲成人频道 | 午夜美女视频 | 久久国产精彩视频 | 国产短视频在线播放 | 亚洲欧美国产日韩在线观看 | 在线视频你懂 | 成人免费网站在线观看 | 国产91在线免费视频 | 亚洲视频第一页 | 亚洲精品在线视频播放 | 精品国产自在精品国产精野外直播 | 91精品婷婷国产综合久久蝌蚪 | 国产三级视频 | 国产日韩欧美视频在线观看 | 美女视频黄免费网站 | 亚洲高清视频在线播放 | 亚洲精品国产精品国自产观看浪潮 | 一区二区三区在线播放 | 国产视频 亚洲视频 | 欧美成人精品欧美一级乱 | 国产专区视频在线观看 | 日本性生活免费看 | 亚洲欧美日韩国产一区二区 | 99久久99久久综合 | 欧美日韩国产一区 | 免费黄色在线网站 | 色天天综合久久久久综合片 | 国产日韩视频在线播放 | 色五丁香 | 91人人澡人人爽人人精品 | 成年人免费在线观看网站 | 日本大尺码专区mv | 深夜精品福利 | 一区二区三区电影在线播 | 久久久久观看 | 人人澡人人模 | 九九三级毛片 | 国产一区二区精品久久91 | 婷婷国产v亚洲v欧美久久 | 999热线在线观看 | 97超碰在线久草超碰在线观看 | 亚洲精品乱码久久久久v最新版 | 久久综合九色九九 | 国产高清视频免费观看 | 男女拍拍免费视频 | 日韩免费不卡视频 | 国产精品嫩草影视久久久 | 91高清免费在线观看 | 欧美一级电影免费观看 | 一级片视频免费观看 | 精品国产激情 | 激情在线免费视频 | 黄色的视频网站 | 国产精品久久视频 | 欧美在线视频一区二区三区 | 欧美淫aaa免费观看 日韩激情免费视频 | 91专区在线观看 | 欧美a在线免费观看 | 开心色婷婷 | 成人在线视频在线观看 | 欧美 日韩 视频 | 欧美性受极品xxxx喷水 | 少妇bbbb搡bbbb桶 | 夜夜骑日日 | 黄色电影网站在线观看 | 色噜噜日韩精品欧美一区二区 | 丝袜少妇在线 | 香蕉免费在线 | 国产精品久久久久久久久蜜臀 | 99久久久国产免费 | 国产99久久久国产 | 欧美一级在线看 | 久久电影日韩 | 91亚洲精品在线 | 999久久国精品免费观看网站 | 麻豆视频免费播放 | 午夜av色 | 激情中文在线 | 天天干一干 | 色偷偷88888欧美精品久久久 | 又黄又刺激 | 激情综合婷婷 | 精品国产乱码久久久久久久 | 国产精品大片免费观看 | 国产一区免费视频 | 久久久久国产精品免费网站 | 99免费在线播放99久久免费 | 808电影免费观看三年 | 久久伊人婷婷 | 99夜色 | 日韩美女av在线 | 精品久久久久免费极品大片 | 婷婷色在线播放 | 国产成人精品一区二三区 | 天天综合中文 | av看片网| 亚洲精品综合一区二区 | 人人澡人人模 | 麻豆极品| 国产剧情久久 | 国产高清av | 国产精品18久久久久久vr | 婷婷草 | 色婷婷免费视频 | 91三级在线观看 | 国产亚洲视频在线 | 久99热| 成年人视频在线免费观看 | 综合天天色 | 成人黄色小说在线观看 | 99久久99视频只有精品 | 欧美日韩91 | 欧美日韩高清在线一区 | 色婷婷婷 | adn—256中文在线观看 | 国产亚洲精品久久久久久久久久久久 | 久草视频首页 | 日本在线观看中文字幕 | 亚洲人成在线电影 | 天天人人综合 | 日韩欧美电影在线 | 97在线观看免费高清完整版在线观看 | 亚洲精品日韩在线观看 | 91麻豆精品国产91久久久更新时间 | 91欧美日韩国产 | 18久久久| 日韩精品视频在线观看免费 | 国产二区电影 | 成人h视频在线 | 亚洲精品66 | 久久久久 | 91在线资源 | 天天天色 | 91中文字幕永久在线 | 欧美日韩国产在线观看 | 人人爽人人爽人人片av免 | 午夜av色| 亚洲1区在线 | 中文字幕黄色av | 中文字幕成人一区 | 中文字幕一区二区三区四区在线视频 | 国产精品一区二区在线观看 | 91免费日韩| 日韩r级电影在线观看 | 91免费观看网站 | www.狠狠色.com| 亚洲欧洲精品一区 | 欧美一区二区三区免费看 | 日韩中文字幕免费看 | 天天插日日插 | 国产精品日韩久久久久 | 久草视频播放 | 久久a久久 | 国产麻豆精品传媒av国产下载 | 日本中文字幕影院 | av在线播放不卡 | 久草在线视频首页 | 一区二区三区在线影院 | 精品一区二区三区电影 | 探花视频在线观看 | 91在线影视 | 九九热国产| 亚洲国产资源 | 波多野结衣在线视频一区 | 在线视频精品播放 | 午夜久久久影院 | av高清一区 | 午夜一级免费电影 | 亚洲va男人天堂 | 婷婷激情小说网 | 国产色妞影院wwwxxx | 9999在线| 在线免费观看av网站 | 欧美伦理电影一区二区 | 中国一级片视频 | 青青河边草观看完整版高清 | 伊人精品在线 | 天天干天天做天天爱 | h久久| 日韩精品免费一线在线观看 | 午夜精品久久久久久99热明星 | 久久久久成人精品 | 在线观看国产区 | 久久综合色播五月 | 亚洲午夜精品久久久久久久久久久久 | 91亚洲视频在线观看 | 午夜国产一区 | 日韩无在线| 久草在线视频免赞 | 婷婷久操| 日日夜日日干 | 婷婷丁香色综合狠狠色 | 肉色欧美久久久久久久免费看 | www夜夜操com| 九九av| 国产精品资源网 | 国产一区二区播放 | 国产成人99av超碰超爽 | 一本一道久久a久久综合蜜桃 | 91麻豆精品国产91久久久久 | 91黄色成人| 国产精品久久99精品毛片三a | 四虎影视8848aamm| 九九热在线观看 | 成人久久18免费网站图片 | a级国产乱理论片在线观看 特级毛片在线观看 | 99久久精品日本一区二区免费 | 黄色91免费观看 | 国产高清在线 | 91麻豆精品久久久久久 | 欧美成人在线免费 | 久久综合色婷婷 | 91视频啊啊啊 | 国产精品第一 | 91手机视频 | 久久久久久久久久久网 | 免费亚洲婷婷 | 91av在 | 黄色三级免费片 | 日韩视频免费 | 黄色网大全| 国产精品18久久久久久vr | 亚州精品天堂中文字幕 | 国产精品观看在线亚洲人成网 | 国产免费a | a级国产乱理伦片在线观看 亚洲3级 | 四虎国产精 | 久久av黄色| 91伊人久久大香线蕉蜜芽人口 | 国产婷婷vvvv激情久 | 欧美一级特黄aaaaaa大片在线观看 | 亚洲 中文 欧美 日韩vr 在线 | 在线色网站 | 欧美日韩国产精品一区二区三区 | www.久艹 | 中文av不卡 | 午夜精品久久久99热福利 | 婷婷视频导航 | av黄色免费网站 | a黄色影院| 国产极品尤物在线 | 国产一区二区视频在线 | 亚洲一级免费观看 | 亚洲欧美视频 | 久久久国产网站 | 中文av在线播放 | 国产色在线,com | 开心婷婷色 | 国产一级视频在线免费观看 | 欧美精品一二三 | 国产成人久久精品77777 | 日韩欧美电影在线观看 | 五月婷婷综合在线视频 | 波多在线视频 | 国产精品观看视频 | 成人午夜在线电影 | 四虎永久网站 | 人人插人人玩 | 精品久久久久久综合 | 激情欧美xxxx | 91色在线观看视频 | 亚洲国产精品推荐 | 亚洲视频免费在线 | 黄视频色网站 | 久久视频精品 | 久久免费av电影 | 日韩黄色大片在线观看 | 免费福利在线 | 超级碰碰碰视频 | 99这里只有精品视频 | 精品欧美一区二区三区久久久 | 欧美在线不卡一区 | 久久激情日本aⅴ | 日韩激情片在线观看 | 中文字幕久久亚洲 | 久久伊人国产精品 | 在线导航福利 | 日韩成人精品一区二区三区 | 成人久久18免费 | 久久99热久久99精品 | 国产精品第三页 | 99中文字幕在线观看 | 国产高清不卡 | 久久伊人八月婷婷综合激情 | 曰本免费av | 天天鲁天天干天天射 | av丝袜在线 | 亚洲成人国产 | 国产精品久久久久9999吃药 | 韩国av一区二区三区在线观看 | 久久观看| 免费国产亚洲视频 | 亚洲国产剧情av | 色七七亚洲影院 | 国产免费观看高清完整版 | 日韩在线观看高清 | 五月天激情婷婷 | 色精品视频 | av中文字幕剧情 | 国产在线看 | 国产一卡久久电影永久 | 天天爽夜夜爽精品视频婷婷 | 成人免费一级片 | 国产糖心vlog在线观看 | 国产亚洲精品中文字幕 | 五月婷婷六月丁香在线观看 | 狠狠色狠狠色终合网 | 午夜av大片 | 日本黄色免费观看 | 91传媒在线| 成年人免费av网站 | 在线高清av | 日韩电影精品一区 | 国产黄色成人 | 日韩高清毛片 | 国产精品6 | 色视频国产直接看 | 精品日本视频 | 免费69视频 | 精品伊人久久久 | 精品一区中文字幕 | 久久免费播放视频 | 久久成年视频 | 成人h视频在线播放 | 国产精品96久久久久久吹潮 | 日韩精品久久久久久中文字幕8 | 日韩在线观看三区 | 国产无遮挡猛进猛出免费软件 | 成人在线视频论坛 | 91精品综合在线观看 | 午夜三级在线 | 91香蕉视频污在线 | 久久久久夜色 | 久久久久久久久久久久久久免费看 | 亚洲精品在线视频播放 | 亚洲一区二区视频在线播放 | 亚洲手机av | 91精品视频播放 | 免费性网站 | av在线激情 | 五月天综合激情 | 99久久99热这里只有精品 | 久久久久久久久久久黄色 | 久久69精品久久久久久久电影好 | 久久视讯| 国产视频精品网 | 免费看一级黄色大全 | 免费激情网| 97人人网 | 中文字幕一区二区三区四区在线视频 | 国产成人精品av | 黄色av影视 | 国产免费a | 色综合婷婷 | 久久观看| 国产一区在线视频观看 | 久久丁香| 国产精品第2页 | 天天色欧美 | 91久久黄色 | 亚洲国产天堂av | 在线观看网站你懂的 | 麻豆91精品91久久久 | 美女啪啪图片 | 欧美日韩激情视频8区 | 久久久免费| 国产精品久久久久久久久久久久 | 天天综合色 | 久久人人爽人人 | 天堂av最新网址 | 探花视频在线观看免费版 | 婷婷中文字幕在线观看 | 国产成人在线综合 | 国精产品999国精产品视频 | 国产视频一 | 日韩午夜av电影 | 99操视频| 国产视频每日更新 | 日日碰狠狠躁久久躁综合网 | 韩国三级在线一区 | 国产r级在线观看 | 九九热1| 伊人干综合 | 久久精品国产一区二区三区 | se婷婷| 国产在线视频导航 | 99成人精品 | 丝袜av一区 | 夜色成人av | 亚洲人人精品 | www99久久| 五月婷婷激情六月 | 国产视频精品视频 | 欧美a级在线免费观看 | 成年人在线看视频 | 激情丁香 | 97超碰免费在线观看 | 久久99国产综合精品 | 亚州激情视频 | 婷婷在线视频 | 亚洲天天在线 | 日韩视频区 | 夜夜躁狠狠躁日日躁视频黑人 | 99久久精品国 | 超碰在线91| 天海翼一区二区三区免费 | 天天干.com| 美女搞黄国产视频网站 | 手机看片| 91麻豆福利 | 欧美精品乱码99久久影院 | 99电影456麻豆 | 国内精品视频在线 | 久久精品96 | 久久久免费毛片 | 字幕网资源站中文字幕 | 日本成人黄色片 | 久草精品电影 | av免费在线播放 | 亚洲天堂精品 | 天天操天天操天天操 | 中文在线a天堂 | 精品国产免费久久 | 天天干天天操天天干 | 在线免费观看欧美日韩 | 日韩在线精品一区 | av免费在线观看网站 | 欧美有色| 91av视频在线观看 | 午夜色大片在线观看 | 正在播放国产91 | 69av国产 | 在线观看国产 | 亚洲爱视频 | 999国内精品永久免费视频 | 久久手机看片 | 国产打女人屁股调教97 | 国产精品久久久久久久久久久久久久 | 人人插超碰 | 日本韩国在线不卡 | av高清一区二区三区 | 久久福利| 成人久久久久 | 亚洲欧美精品一区二区 | 久久国产热视频 | 超碰在线最新 | 精品久久久亚洲 | 午夜视频在线观看一区二区三区 | 精品一区在线看 | 久草91视频 | 99久久爱 | 亚洲精品中文在线 | 色狠狠久久av五月综合 | 国产日本亚洲高清 | 久久精品成人欧美大片古装 | 91片黄在线观看动漫 | 丁香午夜婷婷 | 久久久激情网 | 91精品爽啪蜜夜国产在线播放 | 久久久久综合 | 国产又粗又长的视频 | 国产欧美中文字幕 | 欧美小视频在线观看 | 久久精品免费播放 | 日韩综合在线观看 | 国产 一区二区三区 在线 | 精品欧美一区二区在线观看 | 日韩精选在线观看 | 亚洲 在线 | av蜜桃在线 | 丁香婷婷在线观看 | 91精品国产麻豆国产自产影视 | 天堂av色婷婷一区二区三区 | 久久国产亚洲精品 | 黄色三级av| 国产在线 一区二区三区 | 性色视频在线 | 国产一区欧美日韩 | 一区二区三区高清在线观看 | 久草在线精品观看 | 国产在线精品国自产拍影院 | 国产午夜精品一区二区三区欧美 | 黄色视屏在线免费观看 | 国产在线观看高清视频 | 国产精品女人久久久久久 | 四虎永久免费在线观看 | 亚洲一区动漫 | 黄色成人在线网站 | 免费毛片一区二区三区久久久 | 日日日干 | 国产小视频免费在线网址 | 亚洲成人精品av | 成人a视频| 精品国产乱码久久久久久1区二区 | 日本资源中文字幕在线 | 天天色天天射天天综合网 | 国产精品美女免费 | 天天舔天天搞 | 69久久久久久久 | 91网址在线 | 五月天九九 | 亚洲国产精品久久久久久 | 91麻豆.com | 99久久精品久久亚洲精品 | 狠狠色丁香婷婷综合久小说久 | 日韩亚洲国产中文字幕 | 免费国产亚洲视频 | 免费看日韩 | 国产一区二区三区免费在线观看 | 激情视频免费在线观看 | 日韩av中文 | 久久久99精品免费观看乱色 | 久久久999 | 蜜臀av性久久久久蜜臀aⅴ涩爱 | 国产高清av | a成人v在线 | 91精品视频一区二区三区 | 精品免费在线视频 | 久久艹精品 | 成人av在线影院 | 国产精品毛片久久久久久 | 国产原创在线 | 天天操狠狠干 | 九七视频在线 | 麻豆视频大全 | 国产精品免费视频一区二区 | 亚洲黄色软件 | 97成人精品区在线播放 | 天天艹天天干天天 | 五月婷久久 | 奇人奇案qvod | 视频福利在线 | www.五月天激情 | 国产成人精品久久久久蜜臀 | 最近中文字幕免费大全 | 久久理论视频 | 久久伦理| 久久久久这里只有精品 | 亚洲欧美日本A∨在线观看 青青河边草观看完整版高清 | www.伊人网.com| 97人人模人人爽人人少妇 | 婷婷色av | 天堂黄色片 | 99色在线观看视频 | 久久一区二区免费视频 | 日韩电影久久 | 日本中文一区二区 | 97av在线| 东方av免费在线观看 | 久久专区 | 久久www免费视频 | 精品99视频 | 五月天婷婷在线观看视频 | 欧美在线视频日韩 | 国产黄色特级片 | 特级毛片爽www免费版 | 午夜视频在线观看一区二区三区 | 欧美aaa大片 | 九九热视频在线播放 | 国产精品久久久久久一二三四五 | 91自拍视频在线观看 | 欧美久久久久久久久中文字幕 | 福利视频 | 亚洲四虎在线 | 日本中文字幕系列 | 99精品国产99久久久久久97 | 日韩高清无线码2023 | 黄色天堂在线观看 | 最近中文字幕免费av | 日本爽妇网 | 久热免费 | 夜夜干夜夜 | 丝袜美女在线观看 | 国产三级午夜理伦三级 | 国产精品ssss在线亚洲 | 热久久免费国产视频 | 天天天天天操 | 精品国偷自产在线 | 97在线超碰 | 九九热在线播放 | 国产98色在线 | 日韩 | 欧美日本三级 | 国内视频在线观看 | 在线亚洲成人 | 国产精品每日更新 | 欧美精品一二三 | 波多野结衣综合网 | 国产成人av在线影院 | 国产一区久久 | 成人在线视频免费观看 | av一区二区在线观看中文字幕 | 久草在线免费资源 | 亚洲国产精品推荐 | 精品一二三四在线 | 国产超碰在线 | 中文字幕影片免费在线观看 | 波多野结衣在线观看视频 | 日本中文一级片 | 涩涩成人在线 | 一区二区三区影院 | av在线网站免费观看 | 欧美另类xxxx | 91中文字幕在线观看 | a级免费观看 | 99国产视频在线 | 怡红院成人在线 | a天堂最新版中文在线地址 久久99久久精品国产 | 久久国产经典 | 精品9999 | 激情婷婷久久 | 欧美福利精品 | 一区二区三区韩国免费中文网站 | 夜添久久精品亚洲国产精品 | 久久国产一区 | 国产精品va在线观看入 | 国产精品国产亚洲精品看不卡15 | 中文字幕中文字幕 | 久久人人精 | 国产中文字幕视频在线观看 | 亚洲国产片 | 国产精品99久久久久 | 成人久久18免费 | 国产91精品看黄网站 | 天天操天天艹 | 久久草草热国产精品直播 | 91成人精品一区在线播放69 | 日韩视频图片 | 久久成人综合视频 | 亚洲一区天堂 | 日日干网址 | 日韩精品在线视频 | 狠狠成人| av电影中文 | 青草草在线 | 欧美a级免费视频 | 中文字幕一区二区三区在线视频 | 日韩在线首页 | 操操操天天操 | 91成人免费 | 91成年人网站 | 91精品一区二区三区蜜臀 | 国产中文字幕视频在线 | 黄视频网站大全 | 波多野结衣在线观看一区二区三区 | 亚洲一级免费观看 | a极黄色片| 婷婷丁香国产 | 999电影免费在线观看 | 超碰人人舔 | 免费国产黄线在线观看视频 | 麻豆久久一区二区 | 精品夜夜嗨av一区二区三区 | 国产精品福利无圣光在线一区 | 中文在线免费观看 | 激情视频区 | 999视频精品 | 亚洲第一av在线播放 | av线上看| 国产精品美女久久久久久久久久久 | 九九综合九九 | 国产一级黄大片 | 欧美日本国产在线观看 | 欧美性天天 | 西西大胆啪啪 | 欧美性色19p| 在线观看91 | av免费在线网站 | 国产欧美久久久精品影院 | 99久久夜色精品国产亚洲96 | 亚洲成人资源在线观看 | 91经典在线| 久久久国产精品一区二区三区 | 国产一区二区在线观看免费 | 成人免费视频免费观看 | 四虎在线观看精品视频 | 色婷婷丁香 | 2023国产精品自产拍在线观看 | 中文字幕一区二区三区久久 | 天天搞夜夜骑 | 亚洲精品午夜国产va久久成人 | 色诱亚洲精品久久久久久 | 丁香视频 | 中午字幕在线观看 | 久久乱码卡一卡2卡三卡四 五月婷婷久 | 美女视频黄免费的久久 | 亚洲波多野结衣 | av色综合网 | 久久论理| 色橹橹欧美在线观看视频高清 | 国内少妇自拍视频一区 | 婷婷视频 | 免费看成年人 | 黄色av网站在线免费观看 | 99国产在线视频 | 欧美日韩在线免费观看 | www.色爱 | 99久久精品国产网站 | 99久久精品国产一区二区三区 | 爱爱av网站| 久草在线观看资源 | 欧美性猛片, | 亚洲成人频道 | 亚洲春色综合另类校园电影 | 精品国产精品久久一区免费式 | 欧美二区视频 | 国产大陆亚洲精品国产 | 99热最新精品 | 免费看国产黄色 | 日本久久精品视频 | 亚洲精品国产精品国自产观看 | 日韩美在线 | 欧美老人xxxx18 | 国产日韩欧美精品在线观看 | 国产精品一区免费观看 | 国产人免费人成免费视频 | 国产黄在线观看 | 日韩黄视频 | 亚洲日本va午夜在线电影 | 亚洲好视频 | 国产精品毛片久久久久久 | 伊人国产视频 | 2023国产精品自产拍在线观看 | 国产成人黄色片 | 国产视频2 | 天天干.com | 在线视频app | 久青草视频 | 国产欧美在线一区二区三区 | avwww在线观看 | 天天干夜夜擦 | 亚洲国产资源 | 国产69久久久 | 日韩中文字幕亚洲一区二区va在线 | 深爱激情站 | 热久久这里只有精品 | 免费看片成年人 | 又大又硬又黄又爽视频在线观看 | 中文字幕在线高清 | 日韩精品中文字幕av | 久草在线观 | 999久久a精品合区久久久 | 在线视频久 | 亚洲精品看片 | 一区二区三区视频在线 | 亚洲 欧美 综合 在线 精品 | 免费av试看| 黄视频色网站 | 99精品国产福利在线观看免费 | 色精品视频 | 粉嫩aⅴ一区二区三区 | 欧美精品在线一区二区 | 天天色影院 | 日韩在观看线 | 亚洲精品女人 | 亚洲乱码久久久 | 91看片在线 | 一区二区三区电影在线播 | 欧美激情第一页xxx 午夜性福利 | 免费日韩一区二区 | 午夜婷婷综合 | 丝袜美腿av | 国产专区在线 | 免费高清影视 | 中文字幕一区二区三区在线视频 | 96国产精品| 一级片免费观看视频 | 久久久久久国产一区二区三区 | 国产一级三级 | 丝袜美腿在线视频 | 国产r级在线观看 | 亚洲黑丝少妇 | 免费av在线网站 | 天天射日| 国产专区欧美专区 | 美女网站在线观看 | 精品久久久久久久久久久院品网 | 99性视频 | 天天激情综合 | 亚洲精品自在在线观看 | 色综合久久久久久中文网 | 久久免费大片 | 久久五月精品 | 成人综合日日夜夜 | 在线电影91 | 91亚色视频在线观看 | 99精品久久久久 | 国产一区二区免费 | 精品久久久久久久久久久久久久久久 | 国产亚洲永久域名 | 国产亚洲视频中文字幕视频 | 最新极品jizzhd欧美 | 国产精品一区二区av | 久久草草影视免费网 | 国产69久久久 | 欧美日韩视频一区二区三区 | 日韩在线三级 | 人人爽人人爽人人片av | 毛片随便看 | www.97色.com | 在线免费观看麻豆视频 | 欧美另类高清 |