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

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

时间: 2024-09-20 04:08:00

微信第三方登录(原生)demo【必看篇】的相关文章

C# 求一个微信第三方登录的Demo(一键登录),求贴代码

问题描述 C#求一个微信第三方登录的Demo(一键登录),求贴代码C#求一个微信第三方登录的Demo(一键登录),求贴代码C#求一个微信第三方登录的Demo(一键登录),求贴代码C#求一个微信第三方登录的Demo(一键登录),求贴代码C#求一个微信第三方登录的Demo(一键登录),求贴代码 解决方案 解决方案二:这种帖子是否可以删除啊

原生js仿jquery一些常用方法(必看篇)_javascript技巧

最近迷上了原生js,能不用jquery等框架的情况都会手写一些js方法,记得刚接触前端的时候为了选择器而使用jquery...现在利用扩展原型的方法实现一些jquery函数: 1.显示/隐藏 //hide() Object.prototype.hide = function(){ this.style.display="none"; return this; } //show() Object.prototype.show = function(){ this.style.displa

JS中BOM相关知识点总结(必看篇)_javascript技巧

window对象 ECMAScript是JavaScript的核心,但是如果要在web中使用javascript,那么BOM(浏览器对象模型)才是真正的核心.BOM提供了很多对象,用于访问浏览器的功能,这些功能与任何网页内容无关. window对象:BOM的核心对象是window,它表示浏览器的一个实例.在浏览器中,window对象有双重角色,它既是通过javascript访问浏览器窗口的一个接口,又是ECMAScript规定的Global对象. 因此,所有全局作用域中声明的变量.函数都会变成w

老生常谈php中传统验证与thinkphp框架(必看篇)

PHP(超文本预处理器)可用于小型网站的搭建,当用户需要注册登录是,需要与后台数据库进行匹配合格才能注册和登录,传统的方式步骤繁多,需要先连接数据库再用sql语句进行插入. <?php header("Content-type: text/html; charset=utf-8"); $conn =mysqli_connect("localhost","root",""); if (!$conn){ echo "

关于正则表达式基本语法的应用详解(必看篇)

1.正则表达式基本语法 两个特殊的符号'^'和'$'.他们的作用是分别指出一个字符串的开始和结束.例子如下: "^The":表示所有以"The"开始的字符串("There","The cat"等): "of despair$":表示所以以"of despair"结尾的字符串: "^abc$":表示开始和结尾都是"abc"的字符串--呵呵,只有&qu

objective-c-ios 微信第三方登录snsPlatform.loginClickHandler这一句崩溃

问题描述 ios 微信第三方登录snsPlatform.loginClickHandler这一句崩溃 UMSocialSnsPlatform *snsPlatform = [UMSocialSnsPlatformManager getSocialPlatformWithName:UMShareToWechatSession]; 全选复制放进笔记 snsPlatform.loginClickHandler(self,[UMSocialControllerService defaultControl

js正则表达式学习和总结(必看篇)_正则表达式

最近在做一个小项目时用到了正则匹配,感觉正则挺好用的,所以打算抽时间来小小总结一下. 正则表达式是一种文本模式,包括普通字符(例如,a 到 z 之间的字母)和特殊字符(称为"元字符").模式描述在搜索文本时要匹配的一个或多个字符串.RegExp 对象表示正则表达式,它是对字符串执行模式匹配的强大工具.正则表达式是一种查找以及字符串替换操作. 新建正则表达式 方式一:直接量语法 var reg = /pattern/attributes 方式二:创建 RegExp 对象的语法  var

iOS微信第三方登录实现_IOS

一.接入微信第三方登录准备工作.移动应用微信登录是基于OAuth2.0协议标准构建的微信OAuth2.0授权登录系统. 在进行微信OAuth2.0授权登录接入之前,在微信开放平台注册开发者帐号,并拥有一个已审核通过的移动应用,并获得相应的AppID和AppSecret,申请微信登录且通过审核后,可开始接入流程.(注意) 1.下载iOS微信SDK. 下载地址 2.将SDK放到工程目录中. 3.补充导入一些依赖框架. 4.添加URL Types 5.添加iOS9 URL Schemes. 注意:如果

Asp.Net实现FORM认证的一些使用技巧(必看篇)_实用技巧

最近因为项目代码重构需要重新整理用户登录和权限控制的部分,现有的代码大体是参照了.NET的FORM认证,并结合了PORTAL KITS的登录控制,代码比较啰嗦,可维护性比较差.于是有了以下的几个需求(大多数系统应该都会碰到): 1.用.NET自带的FORM认证来实现安全登录 2.登录后需要记录登录用户的基本信息,方便所有页面调用 3.记录本机登录状态,短时间关闭窗口后不用重新登录 4.权限控制和代码的文件夹结构相呼应,即按角色允许访问不同的目录 5.权限控制有可能需要细化到每一个页面,即按角色允