PHP   发布时间:2019-11-11  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了微信第三方登录(原生)demo【必看篇】大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

在一家ecstore二开公司有一段时间了,公司希望往自己研发产品上面走,一直在培养新人。

最近要自己去微信登录,自己就在ectore的框架基础上,写的原生微信第三方登录以此来熟悉微信第三方登录,在ecstore上面去写。

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

BACkground-color: #ccffcc">

首先:

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

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

获取AppID,AppSecret,之后的处理:

微信登录

处理微信登录开始

定义appid appsecert

http://www.sunmil.cn/wxGetCode;

绑定账号页面

{ //链接数据库 $link = mysqli_connect(DB_HOST,DB_USER,DB_password,db_name ) or die('数据库连接失败4'); $link = mysqli_connect('127.0.0.1','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");

}

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

{ // $url = "http://www.sunmil.cn"; //链接数据库 $link = mysqli_connect(DB_HOST,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 '失败了';
}

}

处理绑定注册页面

{ //链接数据库 $link = mysqli_connect(DB_HOST,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");

}

绑定注册页面

{ //链接数据库 $link = mysqli_connect(DB_HOST,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",time()-3600);
    $this->splash('success',app::get('b2c')->_('注册成功'),$ajax_@R_618_10613@est);
    }   
//会员注册成功,处理member_id 结束
  $this->splash('failed',$BACk_url,app::get('b2c')->_('注册失败'),$ajax_@R_618_10613@est);
}

}

临时页面

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

E){
//链接数据库
$link = mysqli_connect('127.0.0.1','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 "<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表里面是否存在该条数据
$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',time()+3600);
  header("LOCATIOn:http://www.sunmil.cn/passport-weixin.html");
}else{
  echo '失败了';
}  

}

curl模拟get请求

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【必看篇】就是小编分享给大家的全部内容了,希望能给大家一个参,也希望大家多多支持菜鸟教程。

大佬总结

以上是大佬教程为你收集整理的微信第三方登录(原生)demo【必看篇】全部内容,希望文章能够帮你解决微信第三方登录(原生)demo【必看篇】所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: