微信授权连接URL生成类库


微信需要网页授权的时候,需要拼接URL,每次都手动好痛苦

在确保微信公众账号拥有授权作用域(scope参数)的权限的前提下(服务号获得高级接口后,默认拥有scope参数中的snsapi_base和snsapi_userinfo),引导关注者打开如下页面:

https://open.weixin.qq.com/connect/oauth2/authorize?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE#wechat_redirect 若提示“该链接无法访问”,请检查参数是否填写错误,是否拥有scope参数对应的授权作用域权限。

尤其注意:由于授权操作安全等级较高,所以在发起授权请求时,微信会对授权链接做正则强匹配校验,如果链接的参数顺序不对,授权页面将无法正常访问

参考链接(请在微信客户端中打开此链接体验):

scope为snsapi_base

https://open.weixin.qq.com/connect/oauth2/authorize?appid=wx520c15f417810387&redirect_uri=https%3A%2F%2Fchong.qq.com%2Fphp%2Findex.php%3Fd%3D%26c%3DwxAdapter%26m%3DmobileDeal%26showwxpaytitle%3D1%26vb2ctag%3D4_2030_5_1194_60&response_type=code&scope=snsapi_base&state=123#wechat_redirect

scope为snsapi_userinfo

https://open.weixin.qq.com/connect/oauth2/authorize?appid=wxf0e81c3bee622d60&redirect_uri=http%3A%2F%2Fnba.bluewebgame.com%2Foauth_response.php&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirect

尤其注意:跳转回调redirect_uri,应当使用https链接来确保授权code的安全性。

 

参数说明

参数是否必须说明
appid公众号的唯一标识
redirect_uri授权后重定向的回调链接地址, 请使用 urlEncode 对链接进行处理
response_type返回类型,请填写code
scope应用授权作用域,snsapi_base (不弹出授权页面,直接跳转,只能获取用户openid),snsapi_userinfo (弹出授权页面,可通过openid拿到昵称、性别、所在地。并且, 即使在未关注的情况下,只要用户授权,也能获取其信息 )
state重定向后会带上state参数,开发者可以填写a-zA-Z0-9的参数值,最多128字节
#wechat_redirect无论直接打开还是做页面302重定向时候,必须带此参数

 

下图为scope等于snsapi_userinfo时的授权页面:

用户同意授权后

如果用户同意授权,页面将跳转至 redirect_uri/?code=CODE&state=STATE。

code说明 : code作为换取access_token的票据,每次用户授权带上的code将不一样,code只能使用一次,5分钟未被使用自动过期。

 

代码类库,根据条件生成授权URL

 

public class WXURLHelper
{
    /// <summary>
    /// 
    /// </summary>
    /// <param name="appID">公众号的唯一标识</param>
    /// <param name="redirect_uri">授权后重定向的回调链接地址 包含http或https</param>
    /// <param name="scope">应用授权作用域</param>
    /// <param name="state">
    /// 重定向后会带上state参数,开发者可以填写a-zA-Z0-9的参数值,最多128字节
    /// 页面将跳转至 redirect_uri/?code=CODE&state=STATE。
    /// </param>
    /// <returns></returns>
    public static string GenerateURL(string appID, string redirect_uri, EnumScope scope, string state)
    {
        return "https://open.weixin.qq.com/connect/oauth2/authorize?" +
            $"appid={appID}" +
            $"&redirect_uri={System.Web.HttpUtility.UrlEncode(redirect_uri)}" +
            $"&response_type=code" +
            $"&scope={scope.ToString()}" +
            $"&state={state}" +
            $"&connect_redirect=1#wechat_redirect";
    }
    public enum EnumScope
    {
        /// <summary>
        /// 不弹出授权页面,直接跳转,只能获取用户openid
        /// </summary>
        snsapi_base,
        /// <summary>
        /// 弹出授权页面,可通过openid拿到昵称、性别、所在地。并且, 即使在未关注的情况下,只要用户授权,也能获取其信息
        /// </summary>
        snsapi_userinfo
    }
}
GarsonZhang www.yesdotnet.com

 

版权声明:本文为YES开发框架网发布内容,转载请附上原文出处连接
YES开发框架
下一篇:验证码生成
评论列表

发表评论

评论内容
昵称:
关联文章

授权连接URL生成
支付,特约子商户商户号未授权服务商的产品权限
关于授权
支付:特约子商户商户号未授权服务商的产品权限
支付:支付成功没有回调通知Notify_URL
JS 接口签名校验工具 (qq.com)
EFCore官方扩展
支付官方相关工具下载
Asp.net H5唤起支付和支付回调
YESWEB POS开发调试
Electron调用C#dll
支付:JSAPI支付 开发手册
支付,当面付,开发手册
支付接口签名校验工具
支付:签名计算.net4.5
【荐】开源Winform控件:花木兰控件
支付:C#计算签名
/支付宝 在线支付测试工具
支付:受理机构必须传入sub_mch_id
业务模块特殊URL配置