微信公众号里的PHP网站进行网页授权

    要进行网页授权,肯定要和微信合作,首先,要有一个自己的公众号,而且必须要经过认证的公众号.(如果没有,可以去申请测试号)

    订阅号和服务号以及测试号:订阅号专注的是推送消息,所以一些高级接口会没有.服务号专注的是用户交互,所以接口会比订阅号多一点,相对的,推送消息的数量就会比订阅号少一点.而测试号,什么接口都有,但测试号,你懂得,用不时间长.

    本文的教程仅仅是微信入门教程,如有错误,欢迎指正!!!

我要说的是微信的网页授权功能.如果要开发网页授权功能,就需要一个服务号,服务号,服务号. 因为进行网页授权的时候,必须要填一个网页授权域名,这个网页授权域名在订阅号里面没有,不支持.所以要用服务号.

填好网页授权域名后,就可以进行代码的开发了.我这用的是PHP,思路都一样,具体代码差异,请找度娘............................

大致思路是:你先创建一个网页,让用户同意,当用户同意后,微信会带一个code参数来访问你填的网页授权域名底下的文件,比如http://授权域名/index.html、http://授权域名/index.php等,这个文件是你自己建的,名字你自己起(没错,这个网页授权就是上面说的网页授权),然后我们在index.html或index.php里会获得微信传过来的code,然后拿这个code和Appid等换取信息,这个信息就是用户的信息咯!!!得意

下面说代码:

    嗯.......进行网页授权,第一步需要先创建一个页面,这个页面是给用户授权的.比如你进微信公众号网站,他会弹出来一个界面,问你是否授权用微信号登录这个网站.创建这个页面的代码:

$AppId = "你的Appid";

$Redirect_Uri = urlencode('域名/index.html');//这里是code参数来访问你填的网页授权域名底下的文件,这里是index.html
//这个$Url 的scope 可以根据需求自己更改,我用的是snaapi_base,这个意思就是用户只要关注了这个公众号,就不需要再手动去确认授权了,直接就访问微信公众号里的网页了
$Url = "https://open.weixin.qq.com/connect/oauth2/authorize?appid=$AppId&redirect_uri=$Redirect_Uri&response_type=code&scope=snsapi_base&state=STATE#wechat_redirect";
//跳到这个$Url
header("Location:" .$Url);

这个授权界面弄好了,接下来就是再创建一个文件用来接收微信发的code了,再说一遍,你创建的这个文件就是上面代码里$Redirect_Uri 里域名后的那个文件.

你可以创建一个php文件,用$_Get["code"] 来获取code的信息.然后用code和APPid等去换取用户信息

但是,在这里,我用的是html文件,html 文件怎么去获取code呢?就要用js..... 这里,就要用到js函数了.

这个函数是获得Code的

function GetCode(name) {
    var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");
    var r = window.location.search.substr(1).match(reg);
    if (r != null) return unescape(r[2]); return null;
}

然后: 在前台html代码里执行js的GetUserInfo函数:

<script>
     GetUserInfo();
</script>
这是js里GetUserInfo()函数的代码,这里是用GetCode函数取得code,然后通过ajax把他传入后台php文件里
function GetUserInfo() {
    var code = GetCode("code"); //获得code
    $.ajax({
        url: "Controller/GetUserInfo.php",
        type: "GET",
        dataType: "json",
        data: {code:code},
        success: function (data) {
            
        },
        error: function () {
            alert("服务器连接错误:获取用户信息失败!...");
        }
    });
}

接下来,是PHP后台了:

  $Code = $_GET['code']; //这里获取到Code
    $Wx = new GetWxUserData();//这里通过Code和appid获得用户信息的过程我是写在GetWxUserData()类里的GetOpenid($code) 这个函数里的
    $Result = $Wx->GetOpenid($Code);
    $Openid = $Result["openid"]; //这里的$Openid就是用户的openid,可以把他通过echo json_encode($Openid) 返回到前台,就是前面
                js里GetUserInfo()的ajax里的success(data) {},这个data就是echo json_encode($Openid) 返回的数据.也可以把用户的openid运用在后台,比如存数据库之类的,反正随便你怎么用.

接下来,就是这个GetWxUserData类了,类的代码我不发了,我只发GetOpenid($Code)这个函数就行了:

private $AppId = "你的Appid";
private $Secret = "你的secret,就是开发者密码";

public function GetOpenid($Code) {

    $Url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=$this->AppId&secret=$this->Secret&code=$Code&grant_type=authorization_code";
    $Result = $this->https_request($Url);
    return json_decode($Result, true);//因为返回来的数据是json数据,所以要把他转化一下

}

public function https_request($Url, $Data = null) {

    $Curl = curl_init();
    curl_setopt($Curl, CURLOPT_URL, $Url);
    curl_setopt($Curl, CURLOPT_SSL_VERIFYPEER, FALSE);
    curl_setopt($Curl, CURLOPT_SSL_VERIFYHOST, FALSE);
    if (!empty($Data)) {
        curl_setopt($Curl, CURLOPT_POST, 1);
        curl_setopt($Curl, CURLOPT_POSTFIELDS, $Data);
    }
    curl_setopt($Curl, CURLOPT_RETURNTRANSFER, 1);
    $Output = curl_exec($Curl);
    curl_close($Curl);
    return $Output;

}
好了,到这里就可以了,openid已经获取到了.................................................其他好像没什么问题了

猜你喜欢

转载自blog.csdn.net/weixin_42497015/article/details/80810004