国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 語(yǔ)言 > PHP > 正文

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

2024-05-04 23:57:33
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

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

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

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

首先:

資料準(zhǔn)備:水印圖片 28*28  png格式 公司logo高清圖片 108*108   png格式 公司logo1.在微信開放平臺(tái) https://open.weixin.qq.com/中填寫基本信息,2.完成郵箱驗(yàn)證,3.并完善開發(fā)者資料,注冊(cè)成為開發(fā)者。4.在“賬號(hào)中心”完成開發(fā)者資質(zhì)認(rèn)證。5.進(jìn)入微信開放平臺(tái)管理中心網(wǎng)站應(yīng)用,點(diǎn)擊“創(chuàng)建應(yīng)用”按鈕。6.填寫基本信息,完成點(diǎn)擊下一步7.填寫平臺(tái)信息 應(yīng)用簽名:可在微信開發(fā)平臺(tái)的資源中心》》資源下載》》中下載“簽名生成工具”,用戶獲取已經(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>

處理微信登錄開始

定義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'));    }    //查詢數(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 開始      $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.href='http://www.sunmil.cn'</script>";        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表里面是否存在該條數(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è)參考,也希望大家多多支持VeVb武林網(wǎng)。


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到PHP教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 普兰县| 永福县| 晋城| 平安县| 芜湖市| 敦化市| 韩城市| 武功县| 民权县| 闵行区| 当阳市| 武功县| 兴和县| 灵山县| 贡嘎县| 红河县| 兴业县| 桂阳县| 彭山县| 信阳市| 阿鲁科尔沁旗| 两当县| 苍溪县| 炎陵县| 兴和县| 华容县| 邢台县| 崇阳县| 安西县| 永春县| 贺州市| 北海市| 泰安市| 苏尼特右旗| 丰县| 南通市| 竹溪县| 寿阳县| 江津市| 河东区| 郸城县|