airkiss java sdk_微信网页开发之AirKiss配置指南

为了避免大家少走弯路,这里先介绍下硬性条件

1、必须是通过认证的微信服务号或者微信企业号才具有此功能。

2、有自己的云虚拟主机,也就是自己的网站。

开始配置:

一、公众号号的设置

1、进入微信公众平台后台,在公众号设置->功能设置界面下配置好JS接口安全域名,如下图

af27493c470f2588519dd13debaf3b5c.png

2、在基本配置里面完成IP白名单和服务器的配置,这步很重要,如下图

ebda46f24d1d47c045e6c1dbdaaf8520.png

二、网站代码结构如下

weixin--|

|---access_token.php

|---airkiss.php //公众号链接到该文件

|---jsapi_ticket.php

|---jssdk.php

|---MP_verify_yfiF3OWtLI4GfhBg.txt //JS接口验证文件,在设置JS接口时下载后放到网站的,名称随机

三、代码详情

1、access_token.php

{"access_token":"","expire_time":0}

2、airkiss.php

require_once "jssdk.php";

$jssdk = new JSSDK("yourAppID", "yourAppSecret");//这里改成自己的

$signPackage = $jssdk->GetSignPackage();

?>

wx.config({

beta:true,//开启内测接口调用,注入wx.invoke方法

debug:false,//关闭调试模式

appId: '<?php echo $signPackage["appId"];?>',//AppID

timestamp: <?php echo $signPackage["timestamp"];?>,//时间戳

nonceStr: '<?php echo $signPackage["nonceStr"];?>',//随机串

signature: '<?php echo $signPackage["signature"];?>',//签名

jsApiList: [

// 所有要调用的 API 都要加到这个列表中

'configWXDeviceWiFi'

]

});

wx.ready(function () {

// 在这里调用 API

wx.invoke('configWXDeviceWiFi');

});

wx.error(function(res){

alert("配置出错");

});

3、jsapi_ticket.php

{"jsapi_ticket":"","expire_time":0}

4、jssdk.php

class JSSDK {

private $appId;

private $appSecret;

public function __construct($appId, $appSecret) {

$this->appId = $appId;

$this->appSecret = $appSecret;

}

public function getSignPackage() {

$jsapiTicket = $this->getJsApiTicket();

// 注意 URL 一定要动态获取,不能 hardcode.

$protocol = (!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== 'off' || $_SERVER['SERVER_PORT'] == 443) ? "https://" : "http://";

$url = "$protocol$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]";

$timestamp = time();

$nonceStr = $this->createNonceStr();

// 这里参数的顺序要按照 key 值 ASCII 码升序排序

$string = "jsapi_ticket=$jsapiTicket&noncestr=$nonceStr&timestamp=$timestamp&url=$url";

$signature = sha1($string);

$signPackage = array(

"appId" => $this->appId,

"nonceStr" => $nonceStr,

"timestamp" => $timestamp,

"url" => $url,

"signature" => $signature,

"rawString" => $string

);

return $signPackage;

}

private function createNonceStr($length = 16) {

$chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";

$str = "";

for ($i = 0; $i < $length; $i++) {

$str .= substr($chars, mt_rand(0, strlen($chars) - 1), 1);

}

return $str;

}

private function getJsApiTicket() {

// jsapi_ticket 应该全局存储与更新,以下代码以写入到文件中做示例

$data = json_decode($this->get_php_file("jsapi_ticket.php"));

if ($data->expire_time < time()) {

$accessToken = $this->getAccessToken();

// 如果是企业号用以下 URL 获取 ticket

// $url = "https://qyapi.weixin.qq.com/cgi-bin/get_jsapi_ticket?access_token=$accessToken";

$url = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?type=jsapi&access_token=$accessToken";

$res = json_decode($this->httpGet($url));

$ticket = $res->ticket;

if ($ticket) {

$data->expire_time = time() + 7000;

$data->jsapi_ticket = $ticket;

$this->set_php_file("jsapi_ticket.php", json_encode($data));

}

} else {

$ticket = $data->jsapi_ticket;

}

return $ticket;

}

private function getAccessToken() {

// access_token 应该全局存储与更新,以下代码以写入到文件中做示例

$data = json_decode($this->get_php_file("access_token.php"));

if ($data->expire_time < time()) {

// 如果是企业号用以下URL获取access_token

// $url = "https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=$this->appId&corpsecret=$this->appSecret";

$url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=$this->appId&secret=$this->appSecret";

$res = json_decode($this->httpGet($url));

$access_token = $res->access_token;

if ($access_token) {

$data->expire_time = time() + 7000;

$data->access_token = $access_token;

$this->set_php_file("access_token.php", json_encode($data));

}

} else {

$access_token = $data->access_token;

}

return $access_token;

}

private function httpGet($url) {

$curl = curl_init();

curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);

curl_setopt($curl, CURLOPT_TIMEOUT, 500);

// 为保证第三方服务器与微信服务器之间数据传输的安全性,所有微信接口采用https方式调用,必须使用下面2行代码打开ssl安全校验。

// 如果在部署过程中代码在此处验证失败,请到 http://curl.haxx.se/ca/cacert.pem 下载新的证书判别文件。

curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, true);

curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 2);

curl_setopt($curl, CURLOPT_URL, $url);

$res = curl_exec($curl);

curl_close($curl);

return $res;

}

private function get_php_file($filename) {

return trim(substr(file_get_contents($filename), 15));

}

private function set_php_file($filename, $content) {

$fp = fopen($filename, "w");

fwrite($fp, "<?php exit();?>" . $content);

fclose($fp);

}

}

调通后,就可以出现下面的这个界面了

f7cd4f308b18dbd05a74c0aa0a0e6bf2.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值