码迷,mamicode.com
首页 > 微信 > 详细

捋一捋PHP第三方微信登录

时间:2018-06-01 13:43:21      阅读:274      评论:0      收藏:0      [点我收藏+]

标签:微信登录   wechat   login   

PC端扫二维码登录
先说步骤吧:
    微信网站登录的文档在https://open.weixin.qq.com/cgi-bin/showdocument?action=dir_list&t=resource/res_list&verify=1&id=open1419316505&token=41ab5f757248bbbdcc2aad1a6d52b49fdc19579e&lang=zh_CN


    1.微信登录请求,其实你可以当成是个url跳转。https://open.weixin.qq.com/connect/qrconnect?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE#wechat_redirect
        参数 是否必须 说明
        appid 是 应用唯一标识
        redirect_uri 是 重定向地址,需要进行UrlEncode
        response_type 是 填code
        scope 是 应用授权作用域,拥有多个作用域用逗号(,)分隔,网页应用目前仅填写snsapi_login即可
        state 否 用于保持请求和回调的状态,授权请求后原样带回给第三方。该参数可用于防止csrf×××(跨站请求伪造×××),建议第三方带上该参数,可设置为简单的随机数加session进行校验
        把appid参数传给开放平台。链接页面会显示一个二维码。
        技术分享图片
    2.用户扫码二维码,扫码成功后,会跳转回你传的域名地址。
        同时域名后面会带有code和state参数。这个code则是我们需要拿到的钥匙
        redirect_uri?code=CODE&state=STATE
    3.在redirect_uri跳转的页面或者控制器中,接收code值
        code每次会生成一个,用后即会销毁,也就是你不能不停跳转。
    4.通过appid、appSecret还有code值,请求open的access_token接口,获得access_token。
        { 
            "access_token":"ACCESS_TOKEN", 
            "expires_in":7200, 
            "refresh_token":"REFRESH_TOKEN",
            "openid":"OPENID", 
            "scope":"SCOPE",
            "unionid": "o6_bmasdasdsad6_2sgVt7hMZOPfL"
        }

        参数 说明
            access_token 接口调用凭证
            expires_in access_token接口调用凭证超时时间,单位(秒)
            refresh_token 用户刷新access_token
            openid 授权用户唯一标识
            scope 用户授权的作用域,使用逗号(,)分隔
            unionid 当且仅当该网站应用已获得该用户的userinfo授权时,才会出现该字段。

        这里解释一下,access_token是接口凭证,请求接口需要带上,时间为2个小时。openid是获取用户信息的参数,就如username。而unionid则是uid,用户的唯一ID。
    5.拿到token和openid后,可以通过UserInfo接口获得用户数据。https://api.weixin.qq.com/sns/userinfo?access_token=ACCESS_TOKEN&openid=OPENID
        正确的Json返回结果:
        { 
            "openid":"OPENID",
            "nickname":"NICKNAME",
            "sex":1,
            "province":"PROVINCE",
            "city":"CITY",
            "country":"COUNTRY",
            "headimgurl": "http://wx.qlogo.cn/mmopen/g3MonUZtNHkdmzicIlibx6iaFqAc56vxLSUfpb6n5WKSYVY0ChQKkiaJSgQ1dZuTOgvLLrhJbERQQ4eMsv84eavHiaiceqxibJxCfHe/0",
            "privilege":[
                "PRIVILEGE1", 
                "PRIVILEGE2"
            ],
            "unionid": " o6_bmasdasdsad6_2sgVt7hMZOPfL"
        }

微信网页授权(微信浏览器)即H5微信登录

    网页授权流程分为四步:

        1、引导用户进入授权页面同意授权,获取code

        2、通过code换取网页授权access_token(与基础支持中的access_token不同)

        3、如果需要,开发者可以刷新网页授权access_token,避免过期

        4、通过网页授权access_token和openid获取用户基本信息(支持UnionID机制)

            如果网页授权作用域为snsapi_userinfo,则此时开发者可以通过access_token和openid拉取用户信息了。



捋一捋PHP第三方微信登录

标签:微信登录   wechat   login   

原文地址:http://blog.51cto.com/13716819/2122904

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!