热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

微信第三方登录demo

一个简单的demo,不是很好,分享给大家,希望能给想做微信第三方登录的朋友带来思路...
首先:


资料准备:

      水印图片 28*28         png格式        公司logo
      高清图片 108*108     png格式       公司logo

      1.在微信开放平台 https://open.weixin.qq.com/中填写基本信息,
      2.完成邮箱验证,
      3.并完善开发者资料,注册成为开发者。
      4.在“账号中心”完成开发者资质认证。
      5.进入微信开放平台管理中心网站应用,点击“创建应用”按钮。
      6.填写基本信息,完成点击下一步
      7.填写平台信息
        应用签名:可在微信开发平台的资源中心》》资源下载》》中下载“签名生成工具”,用户获取已经安装到手机的第三方应用的签名。输入应用包名,即可获得该应用的签名值。
      8.提交审核后,在7个工作日内腾讯将给出审核结果。(通常较快,几个小时就可反馈结果)


获取AppID,AppSecret,之后的处理


需要在你想加的网站登录页给一个链接:http://www.sunmil.cn/passport-linshi.html&response_type=code&scope=snsapi_login&state=STATE#wechat_redirect">微信登录


处理微信登录开始

定义appid appsecert


    private $appid = "your appid";
    private $appsecert = "your appsecert";
    private $redirect_uri = "http://www.sunmil.cn/wxGetCode";



绑定账号页面


  public function weixin(){
        //链接数据库
        $link = mysqli_connect(DB_HOST, DB_USER,DB_PASSWORD,DB_NAME ) or die('数据库连接失败4');
        $link = mysqli_connect('127.0.0.1', 'root','root', 'ec') or die('数据库连接失败');
        mysqli_set_charset($link,'utf8');

        //接收openid
        $openid = $_COOKIE['openid'];

        $sql = "select * from sdb_trustlogin_trustinfo where openid = '$openid' ";
        $res = mysqli_query($link, $sql);
        $row = mysqli_fetch_assoc($res);

        $this->pagedata['realname'] = $row['realname'];
        $this->pagedata['avatar'] =  $row['avatar'];

        $this->page("site/passport/weixin.html");

    }


当第一次微信登录,处理绑定账号页面


    public function handle($url=null){        // $url = "http://www.sunmil.cn";
         //链接数据库
        $link = mysqli_connect(DB_HOST, DB_USER,DB_PASSWORD,DB_NAME ) or die('数据库连接失败3');
            mysqli_set_charset($link,'utf8');            $post = utils::_filter_input($_POST);        $userData = array(            'login_account' => $post['uname'],
            'login_password' => $post['password']
        );        $member_id = kernel::single('pam_passport_site_basic')->login($userData,$post['verifycode'],$msg);        $b2c_members_model = $this->app->model('members');        $member_point_model = $this->app->model('member_point');        $member_data = $b2c_members_model->getList( 'member_lv_id,experience,point', array('member_id'=>$member_id) );        
        $member_data = $member_data[0];        $member_data['order_num'] = $this->app->model('orders')->count( array('member_id'=>$member_id) );  

        $b2c_members_model->update($member_data,array('member_id'=>$member_id));        $this->userObject->set_member_session($member_id);        $this->bind_member($member_id);        $this->set_COOKIE('loginName',$post['uname'],time()+31536000);//用于记住密码
        // setCartNum()需要传入一个参数
        $aCart = array();        $this->app->model('cart_objects')->setCartNum($aCart);        $url = $this->userPassport->get_next_page('pc');        if( !$url ){            $url = kernel::single('b2c_frontpage')->gen_url(array('app'=>'b2c','ctl'=>'site_member','act'=>'index'));
        }        //查询数据库
        $uname = $_POST['uname'];        $sql = "select * from sdb_pam_members where password_account = '$uname' ";        $res = mysqli_query($link, $sql);        $row = mysqli_fetch_assoc($res);        $member_id = $row['member_id'];        //链接数据库,插入数据
        $openid =  $_COOKIE['openid'];        $sql = "update sdb_trustlogin_trustinfo set member_id = ('{$member_id}')  where openid = '{$openid}'";        $res = mysqli_query($link, $sql); 

        if($res && mysqli_affected_rows($link) > 0){ 
            //删除COOKIE
            setCOOKIE("openid", $openid, time()-3600);
            kernel::single('pam_lock')->flush_lock($member_id);            $this->splash('success',$url,app::get('b2c')->_('登录成功'),true); 
        }else{            echo '失败了';
        }
    }


处理绑定注册页面


public function weixin1(){          //链接数据库
        $link = mysqli_connect(DB_HOST, DB_USER,DB_PASSWORD,DB_NAME ) or die('数据库连接失败2');
        mysqli_set_charset($link,'utf8');        //接收openid
        $openid = $_COOKIE['openid'];        $sql = "select * from sdb_trustlogin_trustinfo where openid = '$openid' ";        $res = mysqli_query($link, $sql);        $row = mysqli_fetch_assoc($res);        $this->pagedata['realname'] = $row['realname'];        $this->pagedata['avatar'] =  $row['avatar'];        $this->page("site/passport/weixin1.html");

    }


绑定注册页面


 public function handle1($url=null){        //链接数据库
        $link = mysqli_connect(DB_HOST, DB_USER,DB_PASSWORD,DB_NAME ) or die('数据库连接失败1');
        mysqli_set_charset($link,'utf8');        $_POST = utils::_filter_input($_POST);        
        $saveData = $this->userPassport->pre_signup_process($_POST);        if( $member_id = $this->userPassport->save_members($saveData,$msg) ){            $this->userObject->set_member_session($member_id);            $this->bind_member($member_id);            foreach(kernel::servicelist('b2c_save_post_om') as $object) {                $object->set_arr($member_id, 'member');                $refer_url = $object->get_arr($member_id, 'member');
            }            /*注册完成后做某些操作! begin*/
            foreach(kernel::servicelist('b2c_register_after') as $object) {                $object->registerActive($member_id);
            }            /*end*/
            $data['member_id'] = $member_id;            $data['uname'] = $saveData['pam_account']['login_account'];            $data['passwd'] = $_POST['pam_account']['psw_confirm'];            $data['email'] = $_POST['contact']['email'];            $data['refer_url'] = $refer_url ? $refer_url : '';            $data['is_frontend'] = true;            $obj_account=$this->app->model('member_account');            $obj_account->fireEvent('register',$data,$member_id);            if(!strpos($_SESSION['pc_next_page'],'cart')){                $url = $this->gen_url(array('app'=>'b2c','ctl'=>'site_passport','act'=>'sign_tips'));
            }else{                $url = $_SESSION['pc_next_page'];
            }            //会员注册成功,处理member_id 开始
            $login_name = $_POST["pam_account"]["login_name"];            $sql = "select member_id from sdb_pam_members where password_account = '{$login_name}'";            // echo $sql;
            $res = mysqli_query($link, $sql);            $row = mysqli_fetch_assoc($res);            $member_id = $row['member_id'];            //链接数据库,插入数据
            $openid =  $_COOKIE['openid'];            $sql = "update sdb_trustlogin_trustinfo set member_id = ('{$member_id}')  where openid = '{$openid}'";            $res = mysqli_query($link, $sql); 

            if($res && mysqli_affected_rows($link) > 0){ 

                 //删除COOKIE
                setCOOKIE("openid", $openid, time()-3600);                $this->splash('success',$url,app::get('b2c')->_('注册成功'),$ajax_request);
                }     
        //会员注册成功,处理member_id 结束
            $this->splash('failed',$back_url,app::get('b2c')->_('注册失败'),$ajax_request);
        }
    }


临时页面


 public function linshi(){        $code =  $_GET['code'];        $state =  $_GET['state'];        if($state === 'STATE'){            $this->loginWeixin($code);
        }elseif($state === 'wxBind'){            $this->bindWeixin($code);
        }else{            return redirect("http://www.sunmil.cn");
        }
    }


loginWeixin


  private function loginWeixin($code){        //链接数据库
        $link = mysqli_connect('127.0.0.1', 'root','root', 'ec') or die('数据库连接失败');
        mysqli_set_charset($link,'utf8');        $appid = $this->appid;        $appsecert = $this->appsecert;        $url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=".$appid."&secret=".$appsecert."&code=".$code."&grant_type=authorization_code";        //curl模拟get请求,获取结果
        $res = $this->http_curl($url);        //转化为数组
        $result = json_decode($res,true);        $openid = $result['openid'];        //openid存在,直接登录,openid不存在,先注册再登录
        $sql = "select openid from sdb_trustlogin_trustinfo";        $res = mysqli_query($link, $sql);        $row = mysqli_fetch_all($res);            
        //foreach 判断
        foreach ($row As  $v) {            if(in_array($openid,$v,true)){                //缺少登录信息

                $sql = "select member_id from sdb_trustlogin_trustinfo where openid = '{$openid}'";                //查出member_id
                $res = mysqli_query($link, $sql);                $row = mysqli_fetch_assoc($res);                $member_id = $row['member_id'];                //查出会员信息
                $sql = "select * from sdb_pam_members where member_id = '{$member_id}'";                $res = mysqli_query($link, $sql);                $row = mysqli_fetch_assoc($res);                $login_name = $row['login_account'];                //存入COOKIE  
                setCOOKIE('UNAME',$login_name, time()+360000);                echo "";                exit;
            }
        }        $access_token = $result['access_token'];        //获取用户基本信息
        $getInfoUrl = "https://api.weixin.qq.com/sns/userinfo?access_token=".$access_token."&openid=".$openid."&lang=zh_CN";        $userInfo = $this->http_curl($getInfoUrl);        $trustinfo = json_decode($userInfo);        //判断trustinfo表里面是否存在该条数据
        $openid     =   $trustinfo->openid;        $nickname   =   $trustinfo->nickname; 
        $sex        =   $trustinfo->sex; 
        $city       =   $trustinfo->city; 
        $province   =   $trustinfo->province; 
        $country    =   $trustinfo->country; 
        $avatar     =   $trustinfo->headimgurl;        $trust_source = 'trustlogin_plugin_weixin';        //连接数据库,插入数据
        $sql = "insert into sdb_trustlogin_trustinfo  (openid,realname,avatar,gender,province,city,trust_source) values ('{$openid}','{$nickname}','{$avatar}','{$sex}','{$province}','{$city}','{$trust_source}')";        $res = mysqli_query($link, $sql); 

        if($res && mysqli_affected_rows($link) > 0){ 
             //存入COOKIE 
            setCOOKIE('openid',$openid, time()+3600);            header("Location:http://www.sunmil.cn/passport-weixin.html");
        }else{            echo '失败了';
        }   
    }


curl模拟get请求


 private function http_curl($url){        $curlobj = curl_init();
        curl_setopt($curlobj, CURLOPT_URL, $url);
        curl_setopt($curlobj, CURLOPT_RETURNTRANSFER, 1);
        curl_setopt($curlobj, CURLOPT_SSL_VERIFYPEER, FALSE);
        curl_setopt($curlobj, CURLOPT_SSL_VERIFYHOST, FALSE);        $output = curl_exec($curlobj);
        curl_close($curlobj);        return $output;
    }


处理微信登录结束

就可以实现微信登录了,当然了,一个简单熟悉微信第三登录的demo,有机会用tp框架分装完善一个完整的微信第三方登录。

欢迎留言,大家一起讨论。

以上就是微信第三方登录demo 的详细内容,更多请关注 第一PHP社区 其它相关文章!


推荐阅读
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 解决VS写C#项目导入MySQL数据源报错“You have a usable connection already”问题的正确方法
    本文介绍了在VS写C#项目导入MySQL数据源时出现报错“You have a usable connection already”的问题,并给出了正确的解决方法。详细描述了问题的出现情况和报错信息,并提供了解决该问题的步骤和注意事项。 ... [详细]
  • 本文介绍了前端人员必须知道的三个问题,即前端都做哪些事、前端都需要哪些技术,以及前端的发展阶段。初级阶段包括HTML、CSS、JavaScript和jQuery的基础知识。进阶阶段涵盖了面向对象编程、响应式设计、Ajax、HTML5等新兴技术。高级阶段包括架构基础、模块化开发、预编译和前沿规范等内容。此外,还介绍了一些后端服务,如Node.js。 ... [详细]
  • 本文介绍了如何使用jQuery和AJAX来实现动态更新两个div的方法。通过调用PHP文件并返回JSON字符串,可以将不同的文本分别插入到两个div中,从而实现页面的动态更新。 ... [详细]
  • 如何实现织梦DedeCms全站伪静态
    本文介绍了如何通过修改织梦DedeCms源代码来实现全站伪静态,以提高管理和SEO效果。全站伪静态可以避免重复URL的问题,同时通过使用mod_rewrite伪静态模块和.htaccess正则表达式,可以更好地适应搜索引擎的需求。文章还提到了一些相关的技术和工具,如Ubuntu、qt编程、tomcat端口、爬虫、php request根目录等。 ... [详细]
  • Java实战之电影在线观看系统的实现
    本文介绍了Java实战之电影在线观看系统的实现过程。首先对项目进行了简述,然后展示了系统的效果图。接着介绍了系统的核心代码,包括后台用户管理控制器、电影管理控制器和前台电影控制器。最后对项目的环境配置和使用的技术进行了说明,包括JSP、Spring、SpringMVC、MyBatis、html、css、JavaScript、JQuery、Ajax、layui和maven等。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • Oracle Database 10g许可授予信息及高级功能详解
    本文介绍了Oracle Database 10g许可授予信息及其中的高级功能,包括数据库优化数据包、SQL访问指导、SQL优化指导、SQL优化集和重组对象。同时提供了详细说明,指导用户在Oracle Database 10g中如何使用这些功能。 ... [详细]
  • 原文地址:https:www.cnblogs.combaoyipSpringBoot_YML.html1.在springboot中,有两种配置文件,一种 ... [详细]
  • 本文详细介绍了在ASP.NET中获取插入记录的ID的几种方法,包括使用SCOPE_IDENTITY()和IDENT_CURRENT()函数,以及通过ExecuteReader方法执行SQL语句获取ID的步骤。同时,还提供了使用这些方法的示例代码和注意事项。对于需要获取表中最后一个插入操作所产生的ID或马上使用刚插入的新记录ID的开发者来说,本文提供了一些有用的技巧和建议。 ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
  • 本文详细介绍了MySQL表分区的创建、增加和删除方法,包括查看分区数据量和全库数据量的方法。欢迎大家阅读并给予点评。 ... [详细]
  • 本文介绍了一种处理AJAX操作授权过期的全局方式,以解决Asp.net MVC中Session过期异常的问题。同时还介绍了基于WebImage的图片上传工具类。详细内容请参考链接:https://www.cnblogs.com/starluck/p/8284949.html ... [详细]
  • 本文介绍了Java后台Jsonp处理方法及其应用场景。首先解释了Jsonp是一个非官方的协议,它允许在服务器端通过Script tags返回至客户端,并通过javascript callback的形式实现跨域访问。然后介绍了JSON系统开发方法,它是一种面向数据结构的分析和设计方法,以活动为中心,将一连串的活动顺序组合成一个完整的工作进程。接着给出了一个客户端示例代码,使用了jQuery的ajax方法请求一个Jsonp数据。 ... [详细]
author-avatar
qzy4799723
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有