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

最近要自己去微信登录,自己就在ectore的框架基础上,写的原生微信第三方登录以此来熟悉微信第三方登录,在ecstore上面去写。
一个简单的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,之后的处理:
需要在你想加的网站登录页给一个链接:<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;
绑定账号页面
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 "<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',$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【必看篇】就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
# 微信第三方登录demo
# iOS实现第三方微信登录方式实例解析(最新最全)
# 第三方
# 绑定
# 给大家
# 注册成功
# 很好
# 就在
# 基础上
# 失败了
# 腾讯
# 你想
# 希望能
# 可在
# 不存在
# 就可
# 这篇
# 能给
# 会用
# 大家一起
# 转化为
# 想做
相关文章:
c++ stringstream用法详解_c++字符串与数字转换利器
活动邀请函制作网站有哪些,活动邀请函文案?
建设网站制作价格,怎样建立自己的公司网站?
建站之星安装后如何配置SEO及设计样式?
如何确保FTP站点访问权限与数据传输安全?
商务网站制作工程师,从哪几个方面把握电子商务网站主页和页面的特色设计?
家具网站制作软件,家具厂怎么跑业务?
建站主机是否等同于虚拟主机?
如何通过服务器快速搭建网站?完整步骤解析
专业网站建设制作报价,网页设计制作要考什么证?
如何在Golang中使用encoding/gob序列化对象_存储和传输数据
怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?
武汉网站如何制作,黄黄高铁武穴北站途经哪些村庄?
西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?
php能控制zigbee模块吗_php通过串口与cc2530 zigbee通信【介绍】
定制建站流程解析:需求评估与SEO优化功能开发指南
微信小程序 五星评分(包括半颗星评分)实例代码
建站之星体验版:智能建站系统+响应式设计,多端适配快速建站
,有什么在线背英语单词效率比较高的网站?
在线制作视频网站免费,都有哪些好的动漫网站?
如何在Windows虚拟主机上快速搭建网站?
北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?
网站网页制作电话怎么打,怎样安装和使用钉钉软件免费打电话?
建站上传速度慢?如何优化加速网站加载效率?
如何构建满足综合性能需求的优质建站方案?
如何高效生成建站之星成品网站源码?
ui设计制作网站有哪些,手机UI设计网址吗?
香港服务器网站生成指南:免费资源整合与高速稳定配置方案
c++怎么使用类型萃取type_traits_c++ 模板元编程类型判断【方法】
建站之星如何开启自定义404页面避免用户流失?
制作网站的公司有哪些,做一个公司网站要多少钱?
教学论文网站制作软件有哪些,写论文用什么软件
?
,怎么在广州志愿者网站注册?
如何在宝塔面板创建新站点?
如何高效利用200m空间完成建站?
移民网站制作流程,怎么看加拿大移民官网?
如何在IIS中新建站点并配置端口与物理路径?
制作企业网站建设方案,怎样建设一个公司网站?
详解jQuery停止动画——stop()方法的使用
洛阳网站制作公司有哪些,洛阳的招聘网站都有哪些?
网站视频怎么制作,哪个网站可以免费收看好莱坞经典大片?
合肥做个网站多少钱,合肥本地有没有比较靠谱的交友平台?
太原网站制作公司有哪些,网约车营运证查询官网?
南平网站制作公司,2025年南平市事业单位报名时间?
如何选择香港主机高效搭建外贸独立站?
建站为何优先选择香港服务器?
大学网站设计制作软件有哪些,如何将网站制作成自己app?
建站主机默认首页配置指南:核心功能与访问路径优化
微课制作网站有哪些,微课网怎么进?
广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?
*请认真填写需求信息,我们会在24小时内与您取得联系。