微信小程序与php后端交互_微信小程序数据库放哪

微信小程序与php后端交互_微信小程序数据库放哪这里简单介绍用php后台实现获取openid并保存到数据库;微信的登陆流程是这样的首先前端发送请求到服务器:wx.login({success:function(res){varcode=res.code;//发送给服务器的codewx.getUserInfo({success:function(res){varuserNick=res.userInfo.nickName;…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

这里简单介绍用php后台实现获取openid并保存到数据库;

微信的登陆流程是这样的

607ee5c5601fc300550938c71fd215ed.png

首先前端发送请求到服务器:

wx.login({

success: function (res) {

var code = res.code;//发送给服务器的code

wx.getUserInfo({

success: function (res) {

var userNick = res.userInfo.nickName;//用户昵称

var avataUrl = res.userInfo.avatarUrl;//用户头像地址

var gender = res.userInfo.gender;//用户性别

if (code) {

wx.request({

url: ‘http://localhost/test/getopenid.php’,//服务器的地址,现在微信小程序只支持https请求,所以调试的时候请勾选不校监安全域名

data: {

code: code,

nick: userNick,

avaurl: avataUrl,

sex: gender,

},

header: {

‘content-type’: ‘application/json’

},

success: function (res) {

console.log(res.data);

wx.setStorageSync(‘name’, res.data.name);//将获取信息写入本地缓存

wx.setStorageSync(‘openid’, res.data.openid);

wx.setStorageSync(‘imgUrl’, res.data.imgurl);

wx.setStorageSync(‘sex’, res.data.sex);

}

})

}

else {

console.log(“获取用户登录态失败!”);

}

}

})

},

fail: function (error) {

console.log(‘login failed ‘ + error);

}

})

这样就实现了将前端获取的code发送到服务器,code每次获取的都不一样;

服务器getopenid.php代码:

text();

function text()

{

$code = $_GET[‘code’];//小程序传来的code值

$nick = $_GET[‘nick’];//小程序传来的用户昵称

$imgUrl = $_GET[‘avaurl’];//小程序传来的用户头像地址

$sex = $_GET[‘sex’];//小程序传来的用户性别

$url = ‘https://api.weixin.qq.com/sns/jscode2session?appid=yourAppid&secret=appSecret&js_code=’ . $code . ‘&grant_type=authorization_code’;

//yourAppid为开发者appid.appSecret为开发者的appsecret,都可以从微信公众平台获取;

$info = file_get_contents($url);//发送HTTPs请求并获取返回的数据,推荐使用curl

$json = json_decode($info);//对json数据解码

$arr = get_object_vars($json);

$openid = $arr[‘openid’];

$session_key = $arr[‘session_key’];

$con = mysqli_connect(‘localhost’, ‘root’, ‘123’);//连接数据库

if ($con) {

if (mysqli_select_db($con, ‘students’)) {

$sql1 = “select * from weixin where openid = ‘$openid'”;

$result = mysqli_query($con, $sql1);

$result = mysqli_fetch_assoc($result);

if ($result!=null) {//如果数据库中存在此用户的信息,则不需要重新获取

$result = json_encode($result);

echo $result;

}

else {//没有则将数据存入数据库

if ($sex == ‘0’) {

$sex = ‘none’;

} else {

$sex = ‘1’ ? ‘man’ : ‘women’;

}

$sql = “insert into weixin values (‘$nick’,’$openid’,’$session_key’,’$imgUrl’,’$sex’)”;

if (mysqli_query($con, $sql)) {

$arr[‘nick’] = $nick;

$arr[‘imgUrl’] = $imgUrl;

$arr[‘sex’] = $sex;

$arr = json_encode($arr);

echo $arr;

} else {

die(‘failed’ . mysqli_error($con));

}

}

}

} else {

die(mysqli_error());

}

}

?>

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/192503.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • intellijidea激活码2021【2021最新】

    (intellijidea激活码2021)JetBrains旗下有多款编译器工具(如:IntelliJ、WebStorm、PyCharm等)在各编程领域几乎都占据了垄断地位。建立在开源IntelliJ平台之上,过去15年以来,JetBrains一直在不断发展和完善这个平台。这个平台可以针对您的开发工作流进行微调并且能够提供…

    2022年3月21日
    66
  • 完整javaEE学生信息管理系统[通俗易懂]

    完整javaEE学生信息管理系统[通俗易懂]基于javaweb的ssm学校教务管理系统(管理员,教师,学生)文章结构一、开发框架及业务方向1.开发环境2.开发框架3.整体业务二、项目结构及页面展示1.项目整体结构2.用户页面3.管理员页面***需要源码的加企鹅:671033846;备注CSDN即可******文章结构一、开发框架及业务方向1.开发环境操作系统不限:java特性,一套代码,导出运行jdk版本不限:推荐jdk1.8tomcat版本不限:推荐Tomcat8.0数据库mysql:版本不限,推荐mysql8.0以下开发工具:e

    2022年10月16日
    3
  • Python3网络爬虫教程2——urlopen的返回对象

    Python3网络爬虫教程2——urlopen的返回对象上接:Python3网络爬虫教程1——初始爬虫(爬虫是干嘛的?)https://blog.csdn.net/u011318077/article/details/865088722.3.urlopen的返回对象rsp=request.urlopen(url)有时候不一定能获得对象,断网了,服务器故障等等geturl:返回请求对象的URLinfo:返回反馈对象的meta信息…

    2025年6月3日
    3
  • 请描述django模板中标签的作用?_抽奖券模板

    请描述django模板中标签的作用?_抽奖券模板常用的模板标签if标签if标签相当于Python中的if语句,有elif和else相对应,但是所有的标签都需要用标签符号({%%})进行包裹。if标签中可以使用==、!=、<、<=、&

    2022年7月29日
    6
  • Spring jar包下载

    Spring jar包下载Spring的下载及目录结构Spring的第一个版本是在2004年发布的,经过10多年的发展,Spring的版本也在不断地升级优化中。Spring开发所需的JAR包分为两个部分,具体如下。1、Spring框架包Spring4.3.6版本的框架压缩包,名称为spring-framework-4.3.6.RELEASE-dist.zip,此压缩包可以通过地址”https…

    2022年5月14日
    35
  • node.js安装及环境配置超详细教程【Windows系统安装包方式】

    node.js安装及环境配置超详细教程【Windows系统安装包方式】简单的说Node.js就是运行在服务端的JavaScript。Node.js是一个基于ChromeJavaScript运行时建立的一个平台。Node.js是一个事件驱动I/O服务端JavaScript环境,基于Google的V8引擎,V8引擎执行Javascript的速度非常快,性能非常好。

    2022年5月23日
    51

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号