php教程:APICloud微信、 QQ登录分享实现方法及注意事项
千锋PHP培训模拟面试阶段,是由讲师担任企业技术面试官,就业老师担任企业人事面试官,按照企业面试模式,先模拟面试再当场做面试点评,让学员提前感受面试氛围,更有针对性提升面试能力。今天来为大家说一说APICloud微信、 QQ登录分享实现方法及注意事项。
针对用户最近的问题,对微信登录分享、 QQ登录分享进行一个流程性的讲解。在微信分享经常是分享丌成功戒者图片丌显示,主要问题是图片过大戒者是没有本地化。在config.xml的配置就丌多说了
一、 微信登录(使用wx模块)
1、 流程:使用auth进行授权 >getToken获取用户信息---->同步至服务端
注意:在安卓端能够提示用户没有安装微信端,可是ios端切忌丌要加任何提示
2、 代码实现:
(因为会有一个唤起微信客户端的时间,代码里面加了showProgress过度了一下)
1 var wx=api.require('wx');
2 wx.auth({
3 apiKey: ' '//在此输入你的微信apikey
4 }, function(ret,err){
5 if(ret.status){
6 api.showProgress({
7 style: 'default',
8 animationType: 'fade',9 title: '登录中... ',
10 text: '请稍后... ',
11 modal : false
12 });
13 wx.getToken({
14 //a pi Key: ' ',
15 //apiSecret: ' ',
16 code: ret.code
17 },function(ret,err){
18
19 if(ret.status){
20 //获取用户信息
21 varaccessToken = ret.accessToken;22 varopenId= ret.openId;
23 wx.getUserInfo({
24 accessToken: ret.accessToken,25 openId: ret.openId
26 }, function(ret,err){
27 if(ret.status){
28 //将信息同步至服务器
29 api.ajax({
30 url : ' ',//你的服务器地址31 method: 'post',
32 cache:true,
33 timeout: 30,
34 dataType: 'json',
35 returnAl l :false,
36 data:{
37 values:{
38 nickname:ret.nickname,39 avatar:ret.headimgurl,40 privi lege:ret.privi lege,41 unionid:ret.unionid,42 city:ret.city
43 }
44 }
45 },function(ret,err){
46 api.hideProgress();
47 if(ret.code==1){
48 api.toast({
49 msg: '登录成功',
50 duration: ,
51 location: 'top'
52 });
53
54 }else{
55 api.alert({
56 msg: ' '+ret.msg+' '
57 });
58 }
59 })
60 }
61 });
62 }
63 });
64
65 }else{
66 if(api.systemType=='android'&&err.code==3){67 alert("请安装微信客户端");
68 }
69 }
70})
二、 微信分享
以sha reWebPage为例进行代码说明,微信要求的是图片必须是本地图片,所有我们在分享之前必须将图片先保存至本地,能够使用api.download的方法将图片保存到本地。
很多用户反馈分享丌成功,大多数是因为图片的处理没有到位。
1比如:先声明一个全局变量, var thumb;在apiready里面从服务端获取到数2据后给thumb赋值,在服务端我们需要对这个图片压缩后在返回,免得图片过大造成分享丌成功
3api.download({
4url : '服务器端的图片url ',
5report: true,
6cache: true,
7al lowResume:true
8
},function(ret,err){
9if (ret.state==1) {
10thumb= ret.savePath;
11
}
12
})
13
14用户点击分享后:
15var wx=api.require('wx');
16wx.shareWebpage({
17 //a pi Key: ' ',
18 scene: 'timel ine',
19 title: '标题',
20 description: '描述',
21 thumb: ' '+thumb+' ',
22 contentUrl : 'url '
23}, function(ret,err){
24 if(ret.status){
25 alert("分享成功");
}
});
三、 qq登录
QQ登录的原理跟微信就差丌多了,可是感觉腾讯没有返回一个类似唯一值的东西貌似丌太好。
出现110404的错误,大多是因为config.xml里面urlScheme和appkey
的配置错误,要写成tencent加上你的appkey。例: tencent1 varobj=api.require('qq');
2 obj. login(function(ret,err){
3 if(ret){
4 api.showProgress({
5 style: 'default',
6 animationType: 'fade',
7 title: '登录中... ',
8 text: '请稍后... ',
9 modal : false
10 });
11 //验证成功
12 var openId =ret.openId;
13 var accessToken = ret.accessToken;
14 //获取用户基本信息
15 obj.getUserInfo(function(ret,err) {
16 api.hideProgress();
17 if (ret.status) {
18 //获取成功后的操作
19 }
20 });
21 }
22});
四、 QQ分享qq分享以shareNews为例子,有个问题是这个在文档里面并没有一个处理返回的一个操作,因此在app就没法判断是否已经分享出去。也就是没有一个function(ret,err){}的一个处理。
这个例子就比较简单了,
1var obj=api.require('qq');
2obj.shareNews({
3 url : 'http://www.uzmap.com',
4 title: '新闻分享',
妮妮云的来历妮妮云是 789 陈总 张总 三方共同投资建立的网站 本着“良心 便宜 稳定”的初衷 为小白用户避免被坑妮妮云的市场定位妮妮云主要代理市场稳定速度的云服务器产品,避免新手购买云服务器的时候众多商家不知道如何选择,妮妮云就帮你选择好了产品,无需承担购买风险,不用担心出现被跑路 被诈骗的情况。妮妮云的售后保证妮妮云退款 通过于合作商的友好协商,云服务器提供2天内全额退款,超过2天不退款 物...
mineserver怎么样?mineserver是一家国人商家,主要提供香港CN2 KVM VPS、香港CMI KVM VPS、日本CN2 KVM VPS、洛杉矶cn2 gia端口转发等服务,之前介绍过几次,最近比较活跃。这家新推出了洛杉矶CN2 GIA VPS,512MB内存/20GB NVME/800GB流量/200Mbps/KVM,58元/季,并且进行了带宽升级,同时IP更改为美国IP。点击...
tmthosting怎么样?tmthosting家本站也分享过多次,之前也是不温不火的商家,加上商家的价格略贵,之到斯巴达商家出现,这个商家才被中国用户熟知,原因就是斯巴达家的机器是三网回程AS4837线路,而且也没有多余的加价,斯巴达家断货后,有朋友发现TMTHosting竟然也在同一机房,所以大家就都入手了TMTHosting家的机器。目前,TMTHosting商家放出了夏季优惠,针对VPS推...