微信公众号里的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函数:


这是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已经获取到了,其他好像没什么问题了

你可能感兴趣的:(微信公众号里的PHP网站进行网页授权)