php+html完成前端微信登录

本文详细介绍了微信OAuth2.0授权登录的过程,包括如何重定向用户到微信授权页面获取code,通过code换取access_token和openid,以及如何将openid保存在session中实现用户标识。同时,代码示例展示了PHP实现的步骤,适用于微信公众号或小程序的登录场景。
摘要由CSDN通过智能技术生成
index.php
<?
session_start();
//ini_set("display_errors", "On");
//header("Content-type:text/html;charset=utf-8");
//define('SERVICE_CONFIG', true);

//include '../common/config2.php';
//require_once '../common/common2.php';
//require_once '../common/jwt/JWT.php';
//use \Firebase\JWT\JWT;


$appid = "appid";  
//$jwt = $_SERVER['HTTP_TOKEN'];//app
if(is_weixin()){ //判断是否微信内打开
  if(empty($_SESSION['_openid'])){
    $redirect_uri = urlencode ("redirect_uri");
    $url ="https://open.weixin.qq.com/connect/oauth2/authorize?appid=$appid&redirect_uri=$redirect_uri&response_type=code&scope=snsapi_base&state=1#wechat_redirect";
    header("Location:".$url);
  }
  $openid=$_SESSION['_openid'];
 // $jwt = JWT::encode(array('uid'=>0,'openid'=>$openid,'subscribe'=>$subscribe,'appid'=>$appid), LE_JWT_KEY);
}
?>
<html>
...
<script>
    var openid = '<?=$openid?>';
</script>
</html>

w1.php
<?
session_start();
//ini_set("display_errors", "On");
//define('SERVICE_CONFIG', true);
//include '../common/config2.php';
//require_once '../common/common2.php';
$code = $_GET["code"];

function httpGet($url) {
	$curl = curl_init();
	curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
	curl_setopt($curl, CURLOPT_TIMEOUT, 500);
    // 为保证第三方服务器与微信服务器之间数据传输的安全性,所有微信接口采用https方式调用,必须使用下面2行代码打开ssl安全校验。
    // 如果在部署过程中代码在此处验证失败,请到 http://curl.haxx.se/ca/cacert.pem 下载新的证书判别文件。
	curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, true);
        //curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, true);
	curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 2);
	curl_setopt($curl, CURLOPT_URL, $url);

	$res = curl_exec($curl);
	curl_close($curl);

	return $res;
}

$appid = "appid";  
$secret = "secret";  

//第一步:取全局access_token
// $access_token = get_access_token($appid); 

//第二步:取得openid

$oauth2Url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=$appid&secret=$secret&code=$code&grant_type=authorization_code";
$oauth2 = json_decode(httpGet($oauth2Url),true);
print_r($oauth2);
//第三步:根据全局access_token和openid查询用户信息  
$openid = $oauth2['openid'];  

$_SESSION['_openid']=$openid;

if(!empty($_SESSION['_openid'])){
	header("Location:./");
}

两个文件放在一个路径下

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值