thinkPHP3.2 微信登录(微信扫码登录)

2024-09-01 15:48

本文主要是介绍thinkPHP3.2 微信登录(微信扫码登录),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

define("APPID", "fff");//你微信定义的appid

define("APPSECRET","ffff");//你微信公众号的appsecret

//微信登录
//第一步:用户同意授权,获取code
public function acceptAction(){

//这个链接是获取code的链接 链接会带上code参数
$REDIRECT_URI = "http://你的域名/Home/Index/getToken";
echo $REDIRECT_URI."<br>";
$REDIRECT_URI = urlencode($REDIRECT_URI);
echo $REDIRECT_URI."<br>";
$scope = "snsapi_login";
echo $scope."<br>";
$state = md5(mktime());
echo $state."<br>";
//https://open.weixin.qq.com/connect/qrconnect?appid=wxbdc5610cc59c1631&redirect_uri=https%3A%2F%2Fpassport.yhd.com%2Fwechat%2Fcallback.do&response_type=code&scope=snsapi_login&state=3d6be0a4035d839573b04816624a415e#wechat_redirect
//网站将微信登录二维码内嵌到自己页面中,用户使用微信扫码授权后通过js将code返回给网站。
$url = "https://open.weixin.qq.com/connect/qrconnect?appid=".APPID."&redirect_uri=".$REDIRECT_URI."&response_type=code&scope=".$scope."&state=".$state."#wechat_redirect";

//如果是微信客户端登录的话,把url换成($url = "https://open.weixin.qq.com/connect/oauth2/authorize?appid=".APPID."&redirect_uri=".$REDIRECT_URI."&response_type=code&scope=".$scope."&state=".$state."#wechat_redirect";)这个就可以了
header("location:$url");

}
//用户同意之后就获取code  通过获取code可以获取一切东西了 
public function getTokenAction(){
//获取accse_token
$code = $_GET["code"];
//echo $code;
//echo "<br>";
//用code获取access_yoken
$url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=".APPID."&secret=".APPSECRET."&code=".$code."&grant_type=authorization_code";
//这里可以获取全部的东西  access_token openid scope
$res = $this->https_requestAction($url);
$res  = json_decode($res,true);
$openid = $res["openid"];
//echo "<pre>";
//print_r($res);
//echo $openid;
//echo "<br>";
$access_token = $res["access_token"];
//echo $access_token;
//这里是获取用户信息
$url = "https://api.weixin.qq.com/sns/userinfo?access_token=".$access_token."&openid=".$openid."&lang=zh_CN";
$res = $this->https_requestAction($url);
$res = json_decode($res,true);
//写入session
//print_r($res);

//把用户的信息写入session 以备查用

//查询数据库中是否存在该微信用户
$user=M('users');
$nums=$user->where(array("wxopenid"=>$openid))->count();

$_SESSION['wxopenid']=$res['openid'];
$_SESSION['wxnickname']=$res['nickname'];
$_SESSION['wxhead']=$res['headimgurl'];

//echo $nums;
if($nums>0){
$result=$user->where(array('wxopenid'=>$openid))->find();
    $_SESSION = $result;
$_SESSION['logtype']='wxcontect';//标记用户登录的类型为QQ登录
$_SESSION['bind']='yes';//标记用户是否绑定了手机号
//判断手否手机端访问
if($this->isMobileAction()){
$this->redirect('Web/User/index');
  exit();
}
$this->redirect("/Home/User/userinfo");
}
//直接跳到首页
else{
$_SESSION['logtype']='wxcontect';
$_SESSION['userid']=2;
$_SESSION['bind']='no';
$this->redirect("/Home/Index/index");

}

//$weixn = $res["openid"];
//$nickname = $res["nickname"];
//$_SESSION["weixin"]=$weixin;
//header("location:http://你的域名/Home/Index/index");
}
public function https_requestAction($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;
}

这篇关于thinkPHP3.2 微信登录(微信扫码登录)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1127369

相关文章

JWT + 拦截器实现无状态登录系统

《JWT+拦截器实现无状态登录系统》JWT(JSONWebToken)提供了一种无状态的解决方案:用户登录后,服务器返回一个Token,后续请求携带该Token即可完成身份验证,无需服务器存储会话... 目录✅ 引言 一、JWT 是什么? 二、技术选型 三、项目结构 四、核心代码实现4.1 添加依赖(pom

Spring Security重写AuthenticationManager实现账号密码登录或者手机号码登录

《SpringSecurity重写AuthenticationManager实现账号密码登录或者手机号码登录》本文主要介绍了SpringSecurity重写AuthenticationManage... 目录一、创建自定义认证提供者CustomAuthenticationProvider二、创建认证业务Us

Springboot项目登录校验功能实现

《Springboot项目登录校验功能实现》本文介绍了Web登录校验的重要性,对比了Cookie、Session和JWT三种会话技术,分析其优缺点,并讲解了过滤器与拦截器的统一拦截方案,推荐使用JWT... 目录引言一、登录校验的基本概念二、HTTP协议的无状态性三、会话跟android踪技术1. Cook

使用Redis快速实现共享Session登录的详细步骤

《使用Redis快速实现共享Session登录的详细步骤》在Web开发中,Session通常用于存储用户的会话信息,允许用户在多个页面之间保持登录状态,Redis是一个开源的高性能键值数据库,广泛用于... 目录前言实现原理:步骤:使用Redis实现共享Session登录1. 引入Redis依赖2. 配置R

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、

Ubuntu 24.04启用root图形登录的操作流程

《Ubuntu24.04启用root图形登录的操作流程》Ubuntu默认禁用root账户的图形与SSH登录,这是为了安全,但在某些场景你可能需要直接用root登录GNOME桌面,本文以Ubuntu2... 目录一、前言二、准备工作三、设置 root 密码四、启用图形界面 root 登录1. 修改 GDM 配

Spring Boot 结合 WxJava 实现文章上传微信公众号草稿箱与群发

《SpringBoot结合WxJava实现文章上传微信公众号草稿箱与群发》本文将详细介绍如何使用SpringBoot框架结合WxJava开发工具包,实现文章上传到微信公众号草稿箱以及群发功能,... 目录一、项目环境准备1.1 开发环境1.2 微信公众号准备二、Spring Boot 项目搭建2.1 创建

nginx 负载均衡配置及如何解决重复登录问题

《nginx负载均衡配置及如何解决重复登录问题》文章详解Nginx源码安装与Docker部署,介绍四层/七层代理区别及负载均衡策略,通过ip_hash解决重复登录问题,对nginx负载均衡配置及如何... 目录一:源码安装:1.配置编译参数2.编译3.编译安装 二,四层代理和七层代理区别1.二者混合使用举例

java向微信服务号发送消息的完整步骤实例

《java向微信服务号发送消息的完整步骤实例》:本文主要介绍java向微信服务号发送消息的相关资料,包括申请测试号获取appID/appsecret、关注公众号获取openID、配置消息模板及代码... 目录步骤1. 申请测试系统2. 公众号账号信息3. 关注测试号二维码4. 消息模板接口5. Java测试

CSS3打造的现代交互式登录界面详细实现过程

《CSS3打造的现代交互式登录界面详细实现过程》本文介绍CSS3和jQuery在登录界面设计中的应用,涵盖动画、选择器、自定义字体及盒模型技术,提升界面美观与交互性,同时优化性能和可访问性,感兴趣的朋... 目录1. css3用户登录界面设计概述1.1 用户界面设计的重要性1.2 CSS3的新特性与优势1.