900字范文,内容丰富有趣,生活中的好帮手!
900字范文 > tp5微信公众号获取用户openid_微信公众号支付(一):获取用户openId

tp5微信公众号获取用户openid_微信公众号支付(一):获取用户openId

时间:2021-12-25 13:04:51

相关推荐

tp5微信公众号获取用户openid_微信公众号支付(一):获取用户openId

一、获取apikey,appsecret与商户号

注册公众号、商户号

二、获取用户的OpenId

1.设置【授权回调页面域名】

官方解释:用户在网页授权页同意授权给公众号后,微信会将授权数据传给一个回调页面,回调页面需在此域名下,以确保安全可靠。回调页面域名不支持IP地址。

aaarticlea/png;base64,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" alt="" />

aaarticlea/png;base64,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" alt="" />

2.用户同意授权

我是把这个url写在微信菜单下的,当进入这个页面的时候就让用户同意。注意:好像是静默授权的,用户不知道

1.url:

https://open./connect/oauth2/authorize?appid=appid&redirect_uri=url&response_type=code&scope=snsapi_userinfo&state=park#wechat_redirect

参数:appid:公众号的唯一标识

redirect_uri:重定向的url,就是授权后要跳转的页面

scope:应用授权作用域

snsapi_base:不弹出授权页面,直接跳转,只能获取用户openid

snsapi_userinfo:弹出授权页面,可通过openid拿到昵称、性别、所在地

state:重定向后带的参数

2.用户同意后会产生一个code,只有5分钟时间的有效期。

String code = request.getParameter("code")

3.code换openId

/**

* 常量类

* @author rory.wu

*

*/

public class Constants {

// 第三方用户唯一凭证

public static String appid = "";

// 第三方用户唯一凭证密钥

public static String appsecret = "";

//商户ID

public static String mch_id="";

//获取openId

public static String oauth2_url = "https://api./sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code";

}

/**

* 通用工具类

* @author rory.wu

* @version 1.0

* @since 08月05日

*/

public class CommonUtil {

private static Logger log = Logger.getLogger(CommonUtil.class);

public static JSONObject httpsRequestToJsonObject(String requestUrl, String requestMethod, String outputStr) {

JSONObject jsonObject = null;

try {

StringBuffer buffer = httpsRequest(requestUrl, requestMethod, outputStr);

jsonObject = JSONObject.fromObject(buffer.toString());

} catch (ConnectException ce) {

log.error("连接超时:"+ce.getMessage());

} catch (Exception e) {

log.error("https请求异常:"+e.getMessage());

}

return jsonObject;

}

private static StringBuffer httpsRequest(String requestUrl, String requestMethod, String output)

throws NoSuchAlgorithmException, NoSuchProviderException, KeyManagementException, MalformedURLException,

IOException, ProtocolException, UnsupportedEncodingException {

URL url = new URL(requestUrl);

HttpsURLConnection connection = (HttpsURLConnection) url.openConnection();

connection.setDoOutput(true);

connection.setDoInput(true);

connection.setUseCaches(false);

connection.setRequestMethod(requestMethod);

if (null != 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();

inputStream = null;

connection.disconnect();

return buffer;

} }

/**

* 获取用户的openId,并放入session

* @param code 微信返回的code

*/

private void setOpenId(String code) {

session.put("code", code);

String oauth2_url = Constants.oauth2_url.replace("APPID", Constants.appid).replace("SECRET", Constants.appsecret).replace("CODE", String.valueOf(session.get("code")));

log.info("oauth2_url:"+oauth2_url);

JSONObject jsonObject = CommonUtil.httpsRequestToJsonObject(oauth2_url, "POST", null);

log.info("jsonObject:"+jsonObject);

Object errorCode = jsonObject.get("errcode");

if(errorCode != null) {

log.info("code不合法");

}else{

String openId = jsonObject.getString("openid");

log.info("openId:"+openId);

session.put("openId", openId);

}

}

oauth2_url返回的格式是:

{

"access_token":"ACCESS_TOKEN",

"expires_in":7200,

"refresh_token":"REFRESH_TOKEN",

"openid":"OPENID", "scope":"SCOPE",

"unionid": "o6_bmasdasdsad6_2sgVt7hMZOPfL"

}

Code无效时:

{

"errcode":40029

,"errmsg":"invalid code"

}

微信公众号网页授权获取用户openid

最近一个项目是在微信公众号内二次开发,涉及到微信公众号支付,根据文档要求想要支付就必须要获取到用户的openid. 这是微信官方文档https://mp./wiki?t=re ...

微信网页授权-公众号支付(获取openid、用户信息等)

名词解释: openid 用户唯一标识,请注意,在未关注公众号时,用户访问公众号的网页,也会产生一个用户和公众号唯一的OpenID 业务功能描述:实现H5页面可以在微信浏览器里面进行微信支付,所以需要 ...

thinkphp.2 thinkphp5微信支付 微信公众号支付 thinkphp 微信扫码支付 thinkphp 微信企业付款5

前面已经跑通了微信支付的流程,接下来吧微信支付和微信企业付款接入到thinkphp中,版本是3.2 把微信支付类.企业付款类整合到一起放到第三方类库,这里我把微信支付帮助类和企业付款类放到同一个文件了 ...

微信公众号开发系列-获取微信OpenID

在微信开发时候在做消息接口交互的时候须要使用带微信加密ID(OpenId),下面讲讲述2中类型方式获取微信OpenID.接收事件推送方式和网页授权获取用户基本信息方式获取. 1.通过接收被动消息方式获 ...

微信公众号支付JSAPI网页,total_fee错误不正确,header重定向参数丢失,无法获取订单号和金额解决

微信公众号支付官方demo错误, 公众号支付只能用在微信里,也就是微信内部浏览器. 1.到WxPayHubHelper.php文件 JsApi_pub()类下createOauthUrlForCode ...

使用开源库MAGICODES.WECHAT.SDK进行微信公众号支付开发

概要 博客使用Word发博,发布后,排版会出现很多问题,敬请谅解.可加群获取原始文档. 本篇主要讲解微信支付的开发流程,相关业务基于MAGICODES.WECHAT.SDK实现.通过本篇教程,您可以很 ...

微信公众号支付流程(Node实现)

前言 花费了一天时间,调通了微信公众号支付.作下记录,方便以后再次填坑.先声明,微信公众号支付,不同于微信H5支付,这点在本文结束时再详细说明. 微信配置 设置测试目录 在微信公众平台设置,栏目见下图 ...

微信公众号支付开发全过程 --JAVA

按照惯例,开头总得写点感想 ------------------------------------------------------------------ 业务流程 这个微信官网说的还是很详细的 ...

到处是坑的微信公众号支付开发(java)

之前公司项目开发中支付是用阿里的支付做的,那叫一个简单,随意:悲催的是,现在公司开发了微信公众号,所以我步入了全是坑的微信支付开发中... ------------------------------ ...

微信公众号支付|微信H5支付|微信扫码支付|小程序支付|APP微信支付解决方案总结

最近负责的一些项目开发,都用到了微信支付(微信公众号支付.微信H5支付.微信扫码支付.APP微信支付).在开发的过程中,在调试支付的过程中,或多或少都遇到了一些问题,今天总结下,分享,留存. 先说注意 ...

随机推荐

Android中 int 和 String 互相转换的多种方法

1 如何将字串 String 转换成整数 int? A. 有两个方法: 1). int i = Integer.parseInt([String]); 或i = Integer.parseInt([ ...

Genome2D编译方法

Genome2D是一个高效的2D引擎,现在支持Flash(stage3d)和HTML5,因为只有作者一个人在维护,就没开源代码. 最近和作者沟通了下,已经开源啦. 作者划分了几个模块,编译起来不是特别 ...

江西理工大学C语言程序设计竞赛(初级组)

ACM ICPC WORLD FINAL 解法:排序大家都知道,去重的话,初学者用数组就好了 #include #include us ...

win7中protel99添加元件库

protel打开时默认添加MiscellaneousDevices.lib,点击ADD/REMOVE按钮添加所需要的库时,弹出“文件无法识别”. 点击面板右下方“FIND”按钮,弹出如下对话框时不要 ...

程序不稳定是因为C++基础不扎实

最近开发的程序,逻辑上都实现了,但是感觉运行不稳定,程序时不时崩溃(不是逻辑运行不正确),至少找出2个错误: 情况1:char* szRemoteReal = new char[MAX_LENGTH] ...

C++ primer札记10-继承

包.继承,多态性C++的三个基本概念,在这里,我们重点总结继承的东西 1 类派生列表 类派生列表中指定一个派生类继承基类,来自列表与一个或多个基类如: class B : public A1,prot ...

[Spark内核] 第37课:Task执行内幕与结果处理解密

本课主题 Task执行内幕与结果处理解密 引言 这一章我们主要关心的是 Task 是怎样被计算的以及结果是怎么被处理的 了解Task 是怎样被计算的以及结果是怎么被处理的 Task 执行原理流程图 ...

内置函数 -- bytes -- 字节码与字符串相互转换

说明: 1. 返回值为一个新的不可修改字节数组,每个数字元素都必须在0 - 255范围内,是bytearray函数的具有相同的行为,差别仅仅是返回的字节数组不可修改. 2. 当3个参数都不传的时候,返 ...

git工具——版本的创建与回退

1.创建一个版本库 进入要管理的文件路径:cd f:/ZK/Opencv3.4.2-YOLOv3 输入命令: git init 2.版本创建与回退 在文件目录下创建一个文件code.txt: vi c ...

用户ID的代码生成

public class Uid { private static final String machineIdString = Integer.toHexString(new Object().ha ...

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。