微信公众平台开发最佳实践
上QQ阅读APP看书,第一时间看更新

2.1 新浪SAE

Sina App Engine(以下简称SAE)是新浪研发中心于2009年8月开始内部开发,并在2009年11月3日正式推出第一个Alpha版本的国内首个公有云计算平台(http://sae.sina.com.cn),SAE是新浪云计算战略的核心组成部分。

SAE作为国内的公有云计算,从开发伊始借鉴吸纳Google、Amazon等国外公司的公有云计算的成功技术经验,并很快推出不同于他们的具有自身特色的云计算平台。SAE选择在国内流行最广的Web开发语言PHP作为首选的支持语言,Web开发者可以在Linux、Mac、Windows上通过SVN或者Web版在线代码编辑器进行开发、部署、调试,团队开发时还可以进行成员协作,不同的角色将对代码、项目拥有不同的权限;SAE提供了一系列分布式计算、存储服务供开发者使用,包括分布式文件存储、分布式数据库集群、分布式缓存、分布式定时服务等,这些服务将大大降低开发者的开发成本。同时SAE整体架构的高可靠性和新浪的品牌保证大大降低了开发者的运营风险。另外,作为典型的云计算,SAE采用“所付即所用,所付仅所用”的计费理念,通过日志和统计中心精确地计算每个应用的资源消耗(包括CPU、内存、磁盘等)。

总之,SAE就是简单高效的分布式Web服务开发、运行平台。

2.1.1 申请账号

SAE的注册地址为http://sae.sina.com.cn/?m=user&a=reg,在浏览器中输入该网址,将自动跳转到“SAE新浪云计算平台”在新浪微博的应用授权界面,如图2-1所示。

如果你还没有新浪微博账号,需要注册一个,注册新浪微博账号的过程比较简单,本书就不再介绍了。在图2-1中填写新浪微博账号及密码之后,点击“登录”按钮,将跳转到授权确认页面,如图2-2所示。

点击“授权”按钮,将跳转到SAE的用户注册页面,如图2-3所示。

填写真实姓名、安全邮箱、安全密码、确认密码、绑定手机及验证码之后,点击“下一步”按钮,将跳转到手机号验证页面,如图2-4所示。

图2-1 SAE登录界面

图2-2 SAE新浪云计算平台授权确认页面

图2-3 SAE用户注册页面

图2-4 SAE手机认证页面

填写手机收到的短信验证码后,点击“验证手机”按钮,将提示注册成功。

至此,我们成功注册了SAE账号。

2.1.2 创建应用

使用注册成功的新浪微博账号登录SAE,登录后界面如图2-5所示。

图2-5 SAE登录页面

图2-6 应用列表

在最上方右侧的导航列表中,点击“我的应用”链接,再从下拉列表中选择“应用列表”链接,将跳转到“应用列表”页面,如图2-6所示。

点击页面中的“创建新应用”按钮,这时会弹出提示框,提示禁止放置违法违规内容,点击“继续创建”按钮,弹出创建应用页面,如图2-7所示。

图2-7 创建应用

在应用创建页面中,依次填写二级域名(AppID)、应用名称、验证码,开发语言选择PHP,应用类型选择web应用。如果AppID已经被其他人注册,会提示已经被占用,需要重新填入。填写完毕后,点击“创建应用”按钮,将弹出安全认证框,系统将要求输入安全密码,在正确输入安全密码之后,将提示创建成功,如图2-8所示。

图2-8 应用创建成功

应用创建成功之后,会自动跳转到应用列表中,在应用列表中可以看到刚才创建的应用。

2.1.3 创建版本

在应用列表中,点击刚才创建的应用cctv15,进入应用信息页面,如图2-9所示。

图2-9 应用信息

找到左侧目录下的“应用管理”,点击下面的“代码管理”链接,跳转到代码管理页面,如图2-10所示。

图2-10 代码管理

点击右侧的“这里创建一个版本”按钮,将弹出创建版本页面,如图2-11所示。

版本号默认为1,可以不更改,直接点击“创建”按钮,如图2-12所示。

图2-11 创建版本

图2-12 创建版本成功

至此,就成功创建了一个域名URL为http://cctv15.sinaapp.com/的SAE应用了。这个URL将会在后面用到。

2.1.4 上传代码

将以下PHP代码保存到文件index.php。或者直接使用微信官方提供的文件。

<?php
/*
    方倍工作 http://www.cnblogs.com/txw1958/
    CopyRight 2013 www.doucube.com  All Rights Reserved
*/
define("TOKEN", "weixin");
$wechatObj = new wechatCallbackapiTest();
if (isset($_GET['echostr'])) {
    $wechatObj->valid();
}else{
    $wechatObj->responseMsg();
}
class wechatCallbackapiTest
{
    public function valid()
    {
        $echoStr = $_GET["echostr"];
        if($this->checkSignature()){
            echo $echoStr;
            exit;
        }
    }
    private function checkSignature()
    {
        $signature = $_GET["signature"];
        $timestamp = $_GET["timestamp"];
        $nonce = $_GET["nonce"];
        $token = TOKEN;
        $tmpArr = array($token, $timestamp, $nonce);
        sort($tmpArr);
        $tmpStr = implode( $tmpArr );
        $tmpStr = sha1( $tmpStr );
        if( $tmpStr == $signature ){
            return true;
        }else{
            return false;
        }
    }
    public function responseMsg()
    {
        $postStr = $GLOBALS["HTTP_RAW_POST_DATA"];
        if (!empty($postStr)){
            $postObj = simplexml_load_string($postStr, 'SimpleXMLElement', LIBXML_NOCDATA);
            $fromUsername = $postObj->FromUserName;
            $toUsername = $postObj->ToUserName;
            $keyword = trim($postObj->Content);
            $time = time();
            $textTpl = "<xml>
                        <ToUserName><![CDATA[%s]]></ToUserName>
                        <FromUserName><![CDATA[%s]]></FromUserName>
                        <CreateTime>%s</CreateTime>
                        <MsgType><![CDATA[%s]]></MsgType>
                        <Content><![CDATA[%s]]></Content>
                        <FuncFlag>0</FuncFlag>
                        </xml>";
            if($keyword == "?" || $keyword == "?")
            {
                $msgType = "text";
                $contentStr = date("Y-m-d H:i:s",time());
                $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
                echo $resultStr;
            }
        }else{
            echo "";
            exit;
        }
    }
}
?>

图2-13 设置文件为以UTF-8无BOM格式编码

请注意,必须使用专业的开发软件来保存操作,如Notepad++,不要使用Windows自带的记事本等,保存时需设置格式为“UTF-8无BOM格式”。图2-13是Notepad++的设置。

然后使用压缩软件WinRAR将其压缩成ZIP格式(见图2-14),注意不能用RAR格式,因为SAE不支持RAR格式的文件上传。

图2-14 压缩ZIP文件

这样就会生成一个index.zip的压缩文件。

再回到我们之前创建的SAE应用的代码管理界面中,点击“操作”按钮,在下拉列表中选择“上传代码包”,如图2-15所示。

图2-15 选择上传代码包

选择上传代码包后,将弹出“代码上传”页面,点击“上传文件”按钮,选择刚才压缩的index.zip文件,点击“上传”按钮,上传成功后的界面如图2-16所示。

图2-16 代码上传

再次回到代码管理界面中,点击“操作”按钮,在下拉列表中选择“编辑代码”,如图2-17所示。

在新的代码编辑页面中,可以看到index.php已经上传成功,双击该文件可以查看源代码,如图2-18所示。

图2-17 编辑代码

图2-18 查看源代码

至此,新浪云应用的创建完成,并且成功上传了微信公众平台的接口文件。