zoukankan      html  css  js  c++  java
  • firefly笔记一之http模块

    原地址:http://www.9miao.com/question-15-54380.html

    Firefly是免费开源的游戏服务器端框架,开发语言是python,基于twisted框架开发,作为一名前端人员都有一颗后端的梦。。希望能坚持下去一直把自己的学习新东西的过程记录下来,不对的地方能够及时一起探讨。
            首先确认好Firefly的搭建环境已经OK,没有搭建的可以参考官方网站:
            http://bbs.9miao.com/forum.php?m ... 3009&fromuid=87
            http://bbs.9miao.com/forum.php?m ... 3956&fromuid=87
            为了更好的熟悉整个流程以及学习(这正是开源的力量)Firefly我们先从头新建一个工程一步步来
           <ignore_js_op>


            2:由于新建的工程默认是支持一个长连接的配置,所以先把配置改成web的配置
                    (1)修改config.json文件 把testserver的key改为我们的webport:
                           <ignore_js_op>


                    (2)修改app/apptest.py
                           <ignore_js_op>


                    (3) 启动Firefly
                           <ignore_js_op>


                    (4)(打开浏览器输入http://localhost:1000/snoy)(因为我是远程其他电脑所以IP是另外一个台电脑IP,本地直接写localhost即可) 
                           <ignore_js_op>


            3 再深入了解一下,我们真正开发时肯定是要传入参数的,例如一般弱联网游戏通过json来相互交互协议数据等,google查了下最常用的json库是simplejson。首先下载安装simplejson,官网是https://pypi.python.org/pypi/simplejson/ 直接下载安装即可。
                    (1)重新修改app/apptest文件

    1. #coding:utf8

    2. from firefly.server.globalobject import webserviceHandle

    3. from twisted.web import resource

    4. import simplejson as json

    5. @webserviceHandle('snoy')

    6. class helloFirefly(resource.Resource):

    7.     def render(self, request):

    8.         length = request.getHeader('content-length')

    9.         print length

    10.         version = request.getHeader('Version')

    11.         print version

    12.         code = request.code

    13.         print code

    14.         method = request.method

    15.         print method

    16.         print request.path

    17.         print request.transport

    18.         value = request.args

    19.         jsonData = json.dumps(value)

    20.         print jsonData

    21.         s = json.loads(jsonData)

    22.         print s

    23.         print s["uid"]

    24.         

    25.         #test

    26.         value1 = '{"name":"test", "type":{"name":"seq", "parameter":["1", "2"]}}'

    27.         s = json.loads(value1)

    28.         print s

    29.         print s.keys()

    30.         print s["name"]

    31.         print s["type"]["name"]

    32.         print s["type"]["parameter"][1]        

    33.         

    34.         return s

    复制代码

    (2)关闭Firefly 再重新打开
                            关闭: pkill -9 -f python*
                              打开: python startmaster.py
                     (浏览器输入http://localhost:1000/snoy?uid=1&passwd=hello&acc=xiuxinming)
                    注意查看服务器打印内容:
                   <ignore_js_op>


                    (3)代码解析:通过看Twisted文档知道Twisted技术体系包含2个层次:协议和工厂。协议负责连接成功以后对交互的处理,而工厂则是负责连接        过程。在HTTP协议中,连接之后还有个生成HTTP请求报文的过程,所以构造出了一个Request对象来处理具体的一个HTTP请求的报文。在HTTP中的请求报文处理对象是 twisted.web.http.Request 类;HTTP的协议类是 twisted.web.http.HTTPChannel ;HTTP工厂是 twisted.web.http.HTTPFactory类;
    这里知道客户端发给服务器的信息在request里面,那么通过request我们知道所有关于客户端的信息,其中对我们最主要的就是后面的内容了。
    看打印效果request.args是所以参数的内容,但是看内容格式是字典格式,所以首先通过simplejson把字典转化为json格式内容然后再读取出来value;
    基本上到这里对于客户端的解析部分应该就OK了。再来看下封包的格式,主要是simplejson的使用看simplejson文档主要就4个方法详细请看http://blog.sina.com.cn/s/blog_7ca42bff010185ha.html
            4:基本上如果只是应用的话对于弱社交部分够使用了以上,但是既然是开源为什么不进去看看到底咋回事呢,虽然一点不懂Twisted和Firefly。。。
            反过来追踪看看Firefly到底做了什么,首先追踪webserviceHandle在哪里出现,发现是在firefly-masterfireflyfireflyserverglobalobject里面,看里面几个方法有
           <ignore_js_op>


            虽然不懂具体是什么意思,但是看名字应该是各种服务的注册,刚入手从最简单的开始,看web部分的处理,大概意思应该是注册的功能。搜索putChild果然出现在Twisted官方文档里面

    1. def putChild(self, path, child): (source)

    2. from twisted.web.resource.IResource

    3. Register a static child.

    4. You almost certainly don't want '/' in your path. If you intended to have the root of a folder, e.g. /foo/, you want path to be ''.

    5. def render(self, request): (source)

    6. from twisted.web.resource.IResource

    7. overridden in twisted.flow.web.Resource, twisted.web.distrib.ResourceSubscription, twisted.web.error.ErrorPage, twisted.web.proxy.ReverseProxyResource, twisted.web.rewrite.RewriterResource, twisted.web.script.PythonScript, twisted.web.script.ResourceScriptDirectory, twisted.web.script.ResourceScriptWrapper, twisted.web.soap.SOAPPublisher, twisted.web.static.ASISProcessor, twisted.web.static.Data, twisted.web.static.DirectoryLister, twisted.web.static.File, twisted.web.static.Redirect, twisted.web.twcgi.CGIDirectory, twisted.web.twcgi.CGIScript, twisted.web.util.DeferredResource, twisted.web.util.ParentRedirect, twisted.web.util.Redirect, twisted.web.vhost.NameVirtualHost, twisted.web.widgets.Gadget, twisted.web.widgets.Page, twisted.web.widgets.WidgetResource, twisted.web.woven.controller.BlankPage, twisted.web.woven.controller.Controller, twisted.web.woven.form.FormProcessor, twisted.web.woven.guard.SessionWrapper, twisted.web.woven.tapestry.Tapestry, twisted.web.woven.template.DOMController, twisted.web.woven.template.DOMTemplate

    8. Render a given resource. See IResource's render method.

    9. I delegate to methods of self with the form 'render_METHOD' where METHOD is the HTTP that was used to make the request. Examples: render_GET, render_HEAD, render_POST, and so on. Generally you should implement those methods instead of overriding this one.

    10. render_METHOD methods are expected to return a string which will be the rendered page, unless the return value is twisted.web.server.NOT_DONE_YET, in which case it is this class's responsibility to write the results to request.write(data), then call request.finish().

    11. Old code that overrides render() directly is likewise expected to return a string or NOT_DONE_YET.

    复制代码

    通过阅读文档大概了解到resource是一个总节点会往下分发Resource,根据需求可以添加不同的child,render()方法是回调具体处理每一个节点的方法。那基本上有些疑问就解决了,为什么建立好render()方法之后客户端发来请求会自动调用,为什么注册一个webserviceHandle传个参数"snoy"就会自动找到这里来处理。那如果建立多个webserviceHandle传不同参数会不会都会被调用呢?经过测试时可以的,但是只能建立一级目录例如只能是http://172.16.3.229:1000/snoy  而不能是http://172.16.3.229:1000/snoy/test1/test2/   具体原因等以后深入了细看。

      再仔细想我们是直接处理的逻辑,那么包头啊 解析啊 发送等等哪里帮我们处理的呢?还是打开源代码看到个web文件夹进去看一下只有一个delayrequest.py文件,进去看了下很像是引擎帮我们封装了细节问题,我们只要处理逻辑就OK了,具体是不是还等待确定。
            最后想问一下很二的问题。。。python既然是脚本语言为什么我在运行服务器代码之后,修改了py文件但是发现测试效果并没有变化呢,一定要重新启动服务器才管用,按理来说不会啊,例如lua 都是运行起来之后动态随时可以看到更改效果。

  • 相关阅读:
    java.lang.IllegalAccessError: tried to access field org.slf4j.impl.StaticLoggerBinder.SINGLETON from class org.slf4j.LoggerFactory
    项目开发中关于权限的实现方案简单描述(帮助以后回忆)
    一些比较有用的模板
    递归之遍历部门
    关于s2sh框架关于hibernate懒加载问题的说明和解决方案
    Hibernate实体映射配置(XML)简单三步完美配置
    项目添加性能监控日志
    redis常用命令大全
    redis主从同步
    redis之哨兵部署运行日志解读
  • 原文地址:https://www.cnblogs.com/123ing/p/3905036.html
Copyright © 2011-2022 走看看