使用PHP进行微信公众平台开发的示例
1. SAE 数据库的连接。需要主机名和端口,以后的使用是一样的。 2.XML 的处理。微信发送的消息格式都是 XML 格式,你返回的消息也必须是 XML 格式。从 XML 里提取数据,用 SimpleXML,强大又容易使用。包装成 XML 消息呢?把消息模板保存为字符串,然后用 sprintf 进行格式化输出。 解析微信服务器 POST 的数据: $postStr = $GLOBALS["HTTP_RAW_POST_DATA"]; //获取POST数据
//用SimpleXML解析POST过来的XML数据 $fromUsername = $postObj->FromUserName; //获取发送方帐号(OpenID) 返回文本消息: //格式化消息模板 3. API 接口的调用。网上有很多 API 接口,如百度翻译,有道翻译,天气预报等,对接口的调用可以直接用 file_get_contents ,也可以用 curl 的方式进行抓取,然后根据返回数据的格式进行数据解析,一般都是 xml 格式或者 json 格式,处理时用 SimpleXML 和 json_decode 是很方便的。对于抓取 API 内容,用重新封装的函数: if(function_exists('file_get_contents')){
}
} return $file_contents; 百度翻译 API 的调用如下: //首先对要翻译的文字进行 urlencode 处理 //注册的API Key //生成翻译API的URL GET地址 $text=json_decode(my_get_file_contents($baidu_url)); $text = $text->trans_result; return $text[0]->dst; 4.对 “附近” 的经纬度的计算。用如下模型,计算正方形的经纬度。采用 Haversin 公式。 $EARTH_RADIUS = 6371;
$dlng = 2 asin(sin($distance / (2 $EARTH_RADIUS)) / cos(deg2rad($lat))); $dlng = rad2deg($dlng); $dlat = $distance/$EARTH_RADIUS; return array( 将查询结果按时间降序排列,message 为数据库中的一个表,location_X 为维度,location_Y 为经度: 5. 对字符串的检查。限定为 6-20个字母,符合则返回 true ,否则返回 false,采用正则表达式进行匹配: 6.对含中文的字符串取子串时,用 mb_substr 进行截取 http://www.php.net/manual/zh/function.mb-substr.php7.检测中英文混合的字符串长度"; //结果:22
echo mb_strlen($str,"UTF8")."
"; //结果:12 $strlen = (strlen($str)+mb_strlen($str,"UTF8"))/2; echo $strlen; //结果:17 ?> 8. 检测是否含有中文";
//if (preg_match("/^[".chr(0xa1)."-".chr(0xff)."]+$/",$str)) { //只能在GB2312情况下使用
//if (preg_match("/^[x7f-xff]+$/",$str)) { //兼容gb2312,utf-8 //判断字符串是否全是中文
if (preg_match("/[x7f-xff]/",$str)) { //判断字符串中是否有中文
echo "正确输入";
} else {
echo "错误输入";
}
?>
双字节字符编码范围 1. GBK (GB2312/GB18030) x00-xff GBK双字节编码范围 x20-x7f ASCII xa1-xff 中文 gb2312 x80-xff 中文 gbk 2. UTF-8 (Unicode) u4e00-u9fa5 中文 x3130-x318F 韩文 xAC00-xD7A3 韩文 u0800-u4e00 日文 9. Jquery Mobile 的使用官网:http://blog.jquerymobile.com/ 原来自己写手机网页,真是无比痛苦,CSS 调试各种烦,跨平台也很不好,后来发现了这个库,果然简单了好多,而且界面看起来漂亮多了。 不过也引入了一些新的问题,比如页面内 CSS 和 Javascript 的加载,因为 Jquery Mobile 默认是使用 Ajax 加载页面的,并不会刷新整个 html ,而是请求一个 page 而已,所以对于多个 page 的页面不会完全加载,对于 head 里面的 CSS 和 Javascript 也不会加载,所以一个方法是在链接的属性里设置 ajax=false,指明不通过 Ajax 加载页面,另一个是把 CSS 和 Javascript 的加载放在 page 里面。在这里就不具体谈了。10. 移动 Web 调试一开始每次调试个页面都要手机连接 WIFI 去刷新,简直不能忍!后来终于学乖了... 推荐这个网站:http://www.responsinator.com/?url= 把自己的网页 url 放在顶端的输入框里面然后“Go”,你就可以看到自己网页在各个平台下了显示效果,连 Kindle 都有.. 当然,开发者必备的谷歌也可以为我们代理成手机浏览器,按 F12 进入开发者模式然后点击右下角的 setting 的图标,可以在 Overrides 里面设置 User Agent 和 Device metrics,效果同样不错。(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |