Unity结合Flask实现排行榜功能

发表于:2015-3-05 10:43

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:Code Cabin    来源:51Testing软件测试网采编

  GET请求返回的JSON格式如下:
{
"data":
[
{
"id": 0,
"name": "A",
"score": 100
},
{
"id": 1,
"name": "B",
"score": 200
}
]
}
  这里的id其实是自增主键,可以不必保留,但为了后面处理方便就一起保留了。
  POST提交的JSON格式如下:
  {
  "id": 0,
  "name": "C",
  "score": 300
  }
  现在我们可以着手实现index方法了:
  def index():
  cur = g.db.execute('select id, name, score from rank order by score desc;')
  result = cur.fetchmany(100)
  data = []
  for row in result:
  data.append({'id': row[0], 'name': row[1], 'score': row[2]})
  return jsonify({'data': data})
  (其中jsonify和g在flask模块内。后面不再对导入进行说明,默认都是从flask导入。)
  在查询时对数据做了排序,并且只返回了前100条记录。可以用curl再测试一下。测试无误再实现create方法:
  def create():
  status = {'status': 'OK'}
  if not request.json or not 'name' in request.json or not 'score' in request.json:
  status['status'] = 'bad request'
  try:
  g.db.execute('insert into rank (name, score) values (?, ?)', [request.json['name'], request.json['score']])
  g.db.commit()
  except:
  status['status'] = 'database error'
  return jsonify(status)
  我们的POST请求都是JSON类型的,所以要从request.json获得,而不是args或者form。此外,返回了一个status变量,便于查看出错原因。
  再用curl测试一下POST。这次,我们要向POST请求中加入数据:
  curl -i -X POST -H "Content-Type: application/json" -d '{"id": 0, "name": "xyz", "score": "800"}' 127.0.0.1:5000/scores
  -H参数用于指定头部信息,-d参数可以携带数据,这里就是一条符合我们提交格式的JSON数据。
  现在服务器端就(暂时)实现完了。下面该写C#代码啦。
  我们需要设计一个和服务器交互、并返回数据给UI层的类。
  首先,这个类应该是单例的,要继承MonoBehaviour(因为和服务器交互要利用Coroutine);而且最好独立于场景之外。关于Unity中实现单例类的集中方式,请看我的另一篇文章。单例的代码如下:
private static SaveLoad _instance = null;
public static SaveLoad Instance {
get
{
if (_instance == null)
{
GameObject go = new GameObject("SaveLoadGameObject");
DontDestroyOnLoad(go);
_instance = go.AddComponent<SaveLoad>();
}
return _instance;
}
}
32/3<123>
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号