mysql数据库存储微信中带有表情符号的昵称
1.在存储之前用base64对数据进行编码然后存入
base64_encode()
2.从数据库拿出来之前再进行解码
base64_decode()
1.在存储之前用base64对数据进行编码然后存入
base64_encode()
2.从数据库拿出来之前再进行解码
base64_decode()
<?php
$text="阡陌建站\r\n广州专业建站团队 \r\n企业官网建设\r\n公众号开发\r\n小程序开发";
$d=str_replace("\r\n", "\n", $text);
echo $d;
?>
**这是输出结果:**
阡陌建站
广州专业建站团队
企业官网建设
公众号开发
小程序开发
<?php
$text='阡陌建站\r\n广州专业建站团队 \r\n企业官网建设\r\n公众号开发\r\n小程序开发';
$d=str_replace("\r\n", "\n", $text);
echo $d;
?>
**这是输出结果:**
阡陌建站\r\n广州专业建站团队 \r\n企业官网建设\r\n公众号开发\r\n小程序开发
通过以上两个的验证:单引号无法对rn解析,双引号才支持nr的识别。
如果数据是赋值或从数据库查询处理的,要进行这个处理。(笨鱼验证过,从数据查询出来,经过多番验证和亲测,代码要做以下修改才能识别)。
$d=str_replace("\\r\\n", "\n", $text);
开发微信过程中,发现拉取用户信息中,如果用户呢称含有表情emoji的符合,是无法用mysql的utf8编码存储的。目前可以使用utf8mb4来存储。虽然能存储,但展示也是一大问题,本人建议最好的解决方案是过滤掉:以下是从网上抄的代码:
/*
*过滤掉微信呢称的emoji表情
*/
public function filterEmoji($str){
$str = preg_replace_callback('/./u',function (array $match) {
return strlen($match[0]) >= 4 ? '' : $match[0];
},$str);
return $str;
}
完结撒花!
前置步骤:
1、注册微信公众号
2、开发者配置----基本配置-----拿到APPID(开发者ID)和APPKEY(开发者密钥)
3、服务器配置
这里就是介绍【服务器配置】,在开始以前,先做下白名单设置:
【设置】---【基本设置】----【白名单】---添加你本地的公网IP即可,不懂移步这里
现在进入今天的正题:
如何进行服务器地址的有效验证,也就是人常说的TOKEN验证。
就官方而言,微信服务器在验证token的时候会发送GET请求到服务器的地址上(我的地址是www.kinmor.com/weixin/index/checkSignature[thinkphp3.2.3]),会请求带以下四个参数:
在验证的时候我做个小测试,下面是我接收到的参数
{"signature":"bd44ae804d379f63150a2dbb371137613f30f1c7","echostr":"1252117117333880755","timestamp":"1528768433","nonce":"902738055"}
signature 微信加密签名,signature结合了开发者填写的token参数和请求中的timestamp参数、nonce参数。
timestamp 时间戳
nonce 随机数
echostr 随机字符串
官方的加密/校验流程如下:
下面是我的代码:
/**
* 验证签名
* @return bool
*/
public function checkSignature() {
/*{"signature":"bd44ae804d379f63150a2dbb371137613f30f1c7","echostr":"1252117117333880755","timestamp":"1528768433","nonce":"902738055"}
#$signature ='bd44ae804d379f63150a2dbb371137613f30f1c7';
#$timestamp ='1528768433';
#$nonce='902738055';*/
$signature = $_GET["signature"];
$timestamp = $_GET["timestamp"];
$nonce = $_GET["nonce"];
$echostr = $_GET["echostr"];
$token = C('TOKEN');
$tmpArr = array($token, $timestamp, $nonce);
sort($tmpArr, SORT_STRING);
$tmpStr = implode($tmpArr);
$tmpStr = sha1($tmpStr);
if($tmpStr == $signature&&$echostr){
echo $echostr;
exit;
}
}
/*$signature = isset($_GET["signature"])?$_GET["signature"]:'';
$signature = isset($_GET["msg_signature"])?$_GET["msg_signature"]:$signature; //如果存在加密验证则用加密验证段
$timestamp = isset($_GET["timestamp"])?$_GET["timestamp"]:'';
$nonce = isset($_GET["nonce"])?$_GET["nonce"]:'';
$echostr = isset($_GET["echostr"])?$_GET["echostr"]:'';
$token = $this->options['token'];
$tmpArr = array($token, $timestamp, $nonce);
sort($tmpArr, SORT_STRING);
$tmpStr = implode($tmpArr);
$tmpStr = sha1($tmpStr);
if($tmpStr == $signature&&$echostr){
echo $echostr;
exit;
}*/
在上面的代码中,用到的配置是token,注意这里的token值一定要和微信公众号【服务器配置】--【token】的值保持一致。上面我为了更方便管理,将token进行了预定义。
接口调试返回"errcode": 40164, "errmsg": "invalid ip 220.115.189.50, not in whitelist"
解决办法:
【登录公众后台】——【设置】——【基本设置】——【白名单添加】
备注说明:
这里添加的是你本地的IP地址(公网),不会查询点击这里