欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

微信第三方登錄(原生)demo【必看篇】

 更新時(shí)間:2017年05月26日 08:59:36   投稿:jingxian  
下面小編就為大家?guī)?lái)一篇微信第三方登錄(原生)demo【必看篇】。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

在一家ecstore二開(kāi)公司有一段時(shí)間了,公司希望往自己研發(fā)產(chǎn)品上面走,一直在培養(yǎng)新人。

最近要自己去微信登錄,自己就在ectore的框架基礎(chǔ)上,寫(xiě)的原生微信第三方登錄以此來(lái)熟悉微信第三方登錄,在ecstore上面去寫(xiě)。

一個(gè)簡(jiǎn)單的demo,不是很好,分享給大家,希望能給想做微信第三方登錄的朋友帶來(lái)思路...

首先:

資料準(zhǔn)備:

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

1.在微信開(kāi)放平臺(tái) https://open.weixin.qq.com/中填寫(xiě)基本信息,
2.完成郵箱驗(yàn)證,
3.并完善開(kāi)發(fā)者資料,注冊(cè)成為開(kāi)發(fā)者。
4.在“賬號(hào)中心”完成開(kāi)發(fā)者資質(zhì)認(rèn)證。
5.進(jìn)入微信開(kāi)放平臺(tái)管理中心網(wǎng)站應(yīng)用,點(diǎn)擊“創(chuàng)建應(yīng)用”按鈕。
6.填寫(xiě)基本信息,完成點(diǎn)擊下一步
7.填寫(xiě)平臺(tái)信息
 應(yīng)用簽名:可在微信開(kāi)發(fā)平臺(tái)的資源中心》》資源下載》》中下載“簽名生成工具”,用戶(hù)獲取已經(jīng)安裝到手機(jī)的第三方應(yīng)用的簽名。輸入應(yīng)用包名,即可獲得該應(yīng)用的簽名值。
8.提交審核后,在7個(gè)工作日內(nèi)騰訊將給出審核結(jié)果。(通常較快,幾個(gè)小時(shí)就可反饋結(jié)果)

獲取AppID,AppSecret,之后的處理:

需要在你想加的網(wǎng)站登錄頁(yè)給一個(gè)鏈接:<a href="https://open.weixin.qq.com/connect/qrconnect?appid=your appid &redirect_uri=http://www.sunmil.cn/passport-linshi.html&response_type=code&scope=snsapi_login&state=STATE#wechat_redirect" rel="external nofollow" >微信登錄</a>
<br><br>

處理微信登錄開(kāi)始

定義appid appsecert

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

綁定賬號(hào)頁(yè)面

public function weixin(){
   //鏈接數(shù)據(jù)庫(kù)
   $link = mysqli_connect(DB_HOST, DB_USER,DB_PASSWORD,DB_NAME ) or die('數(shù)據(jù)庫(kù)連接失敗4');
   $link = mysqli_connect('127.0.0.1', 'root','root', 'ec') or die('數(shù)據(jù)庫(kù)連接失敗');
   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");
 
 }

當(dāng)?shù)谝淮挝⑿诺卿?,處理綁定賬號(hào)頁(yè)面

public function handle($url=null){
    // $url = "http://www.sunmil.cn";
     //鏈接數(shù)據(jù)庫(kù)
    $link = mysqli_connect(DB_HOST, DB_USER,DB_PASSWORD,DB_NAME ) or die('數(shù)據(jù)庫(kù)連接失敗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()需要傳入一個(gè)參數(shù)
    $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'));
    }

    //查詢(xún)數(shù)據(jù)庫(kù)
    $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'];
    //鏈接數(shù)據(jù)庫(kù),插入數(shù)據(jù)
    $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 '失敗了';
    }
  }

處理綁定注冊(cè)頁(yè)面

public function weixin1(){
     //鏈接數(shù)據(jù)庫(kù)
    $link = mysqli_connect(DB_HOST, DB_USER,DB_PASSWORD,DB_NAME ) or die('數(shù)據(jù)庫(kù)連接失敗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");

  }

綁定注冊(cè)頁(yè)面

public function handle1($url=null){
    //鏈接數(shù)據(jù)庫(kù)
    $link = mysqli_connect(DB_HOST, DB_USER,DB_PASSWORD,DB_NAME ) or die('數(shù)據(jù)庫(kù)連接失敗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');
      }

      /*注冊(cè)完成后做某些操作! 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'];
      }

      //會(huì)員注冊(cè)成功,處理member_id 開(kāi)始
      $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'];

      //鏈接數(shù)據(jù)庫(kù),插入數(shù)據(jù)
      $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')->_('注冊(cè)成功'),$ajax_request);
        }   
    //會(huì)員注冊(cè)成功,處理member_id 結(jié)束
      $this->splash('failed',$back_url,app::get('b2c')->_('注冊(cè)失敗'),$ajax_request);
    }
  }

臨時(shí)頁(yè)面

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){

    //鏈接數(shù)據(jù)庫(kù)
    $link = mysqli_connect('127.0.0.1', 'root','root', 'ec') or die('數(shù)據(jù)庫(kù)連接失敗');
    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請(qǐng)求,獲取結(jié)果
    $res = $this->http_curl($url);
    //轉(zhuǎn)化為數(shù)組
    $result = json_decode($res,true);
    $openid = $result['openid'];

    //openid存在,直接登錄,openid不存在,先注冊(cè)再登錄
    $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'];
        //查出會(huì)員信息
        $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 "<script>window.location.;
        exit;
      }
    }

    $access_token = $result['access_token'];
    //獲取用戶(hù)基本信息
    $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表里面是否存在該條數(shù)據(jù)
    $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';
    //連接數(shù)據(jù)庫(kù),插入數(shù)據(jù)
    $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請(qǐng)求

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;
  }

處理微信登錄結(jié)束

就可以實(shí)現(xiàn)微信登錄了,當(dāng)然了,一個(gè)簡(jiǎn)單熟悉微信第三登錄的demo,有機(jī)會(huì)用tp框架分裝完善一個(gè)完整的微信第三方登錄。

歡迎留言,大家一起討論。

以上這篇微信第三方登錄(原生)demo【必看篇】就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 關(guān)于laravel5.5的定時(shí)任務(wù)詳解(demo)

    關(guān)于laravel5.5的定時(shí)任務(wù)詳解(demo)

    今天小編就為大家分享一篇關(guān)于laravel5.5的定時(shí)任務(wù)詳解(demo),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-10-10
  • smarty內(nèi)部日期函數(shù)html_select_date()用法實(shí)例分析

    smarty內(nèi)部日期函數(shù)html_select_date()用法實(shí)例分析

    這篇文章主要介紹了smarty內(nèi)部日期函數(shù)html_select_date()用法,以實(shí)例形式較為詳細(xì)的分析了smarty模板中內(nèi)部日期函數(shù)html_select_date()的各項(xiàng)參數(shù)、功能及使用技巧,需要的朋友可以參考下
    2015-07-07
  • PHPStrom 新建FTP項(xiàng)目以及在線(xiàn)操作教程

    PHPStrom 新建FTP項(xiàng)目以及在線(xiàn)操作教程

    PhpStorm是一個(gè)輕量級(jí)且便捷的PHP IDE,其提供的智能代碼補(bǔ)全,快速導(dǎo)航以及即時(shí)錯(cuò)誤檢查等功能大大提高了編碼效率。它是一款商業(yè)的 PHP 集成開(kāi)發(fā)工具,以其獨(dú)特的開(kāi)發(fā)便利性,短時(shí)間內(nèi)贏(yíng)得了大量PHPer的青睞。今天我們來(lái)詳細(xì)學(xué)習(xí)下FTP相關(guān)的操作
    2016-10-10
  • Laravel5.1 框架登錄和注冊(cè)實(shí)現(xiàn)方法詳解

    Laravel5.1 框架登錄和注冊(cè)實(shí)現(xiàn)方法詳解

    這篇文章主要介紹了Laravel5.1 框架登錄和注冊(cè)實(shí)現(xiàn)方法,結(jié)合實(shí)例形式詳細(xì)分析了laravel5.1框架登錄與注冊(cè)相關(guān)配置、路由、實(shí)現(xiàn)方法與操作注意事項(xiàng),需要的朋友可以參考下
    2020-01-01
  • ThinkPHP讓../Public在模板不解析(直接輸出)的方法

    ThinkPHP讓../Public在模板不解析(直接輸出)的方法

    這篇文章主要介紹了ThinkPHP讓../Public在模板不解析,直接輸出的方法,涉及通過(guò)模板常量設(shè)置修改默認(rèn)變量替換的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-10-10
  • PHP笛卡爾積實(shí)現(xiàn)原理及代碼實(shí)例

    PHP笛卡爾積實(shí)現(xiàn)原理及代碼實(shí)例

    這篇文章主要介紹了PHP笛卡爾積實(shí)現(xiàn)原理及代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-12-12
  • YII2框架中excel表格導(dǎo)出的方法詳解

    YII2框架中excel表格導(dǎo)出的方法詳解

    最近在研究PHP的Yii框架,很喜歡,碰到導(dǎo)出Excel的問(wèn)題,研究了一下,就有了下面這篇文章,這篇文章主要給大家介紹了關(guān)于YII2框架中excel表格導(dǎo)出的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來(lái)一起看看吧。
    2017-07-07
  • PHP版本升級(jí)到7.x后wordpress的一些修改及wordpress技巧

    PHP版本升級(jí)到7.x后wordpress的一些修改及wordpress技巧

    這篇文章主要介紹了PHP版本升級(jí)到7.x后wordpress的一些修改及wordpress技巧的相關(guān)資料,需要的朋友可以參考下
    2015-12-12
  • 用PHP實(shí)現(xiàn)的服務(wù)端socket具體實(shí)例

    用PHP實(shí)現(xiàn)的服務(wù)端socket具體實(shí)例

    這篇文章主要介紹了用PHP實(shí)現(xiàn)的服務(wù)端socket具體實(shí)例,有對(duì)這方面不懂的同學(xué)可以參考下
    2021-01-01
  • IIS服務(wù)器中部署PHP案例詳解

    IIS服務(wù)器中部署PHP案例詳解

    這篇文章主要介紹了IIS服務(wù)器中部署PHP案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08

最新評(píng)論