最近项目组安排将一组Lua实现的web服务端代码重构成Go实现,所以顺便学习了下Lua和Go,这里记录下在尝试重构的过程中遇到的几个问题。

1.beego路由设置

路由设置简单说下,主要是调用了package routers的init()方法

// @APIVersion 1.0.0
// @Title beego Test API
// @Description beego has a very cool tools to autogenerate documents for your API
// @Contact astaxie@gmail.com
// @TermsOfServiceUrl http://beego.me/
// @License Apache 2.0
// @LicenseUrl http://www.apache.org/licenses/LICENSE-2.0.html
package routers import (
"github.com/astaxie/beego"
"market/src/controllers"
) func init() {
ns := beego.NewNamespace("/market",
beego.NSNamespace("/exchange",
beego.NSInclude(
&controllers.MarketController{},
&controllers.OnlineGameController{},
&controllers.GoodsResController{},
&controllers.UserInfoController{},
&controllers.MissionRewardController{},
),
),
)
beego.AddNamespace(ns)
}

再去package controllers下创建对应的路由

package controllers

import (
"common/log"
"encoding/json"
"github.com/astaxie/beego"
"market/src/models"
) type OnlineGameController struct {
beego.Controller
} // GetMarketInfo :
// @Title GetOnlineGameInfo
// @Description : get online game info
// @Success 0 {object} models.OnlineGameInfoResp
// @router /queryOnlineGameInfo [post,get]
func (this *OnlineGameController) GetOnlineGameInfo() {
this.Ctx.ResponseWriter.Header().Add("Access-Control-Allow-Origin", "*")
this.Ctx.ResponseWriter.Header().Add("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept") var req models.OnlineGameInfoRequest
reqData := this.GetString("data")
json.Unmarshal(([]byte)(reqData), &req) res := models.OnlineGameInfoResp{}
defer func() {
resJson, _ := json.Marshal(res)
this.Data["json"] = res
this.ServeJSON()
log.LOGACCESS("GetOnlineGameInfo:\nrequest param:%v, \ntransfer struct:%v, \nresponse:%v", reqData, req, string(resJson))
}() errCode, errMsg := req.ValidParam()
if errMsg != nil {
res.ErrCode = errCode
res.ErrMsg = errMsg.Error()
return
}
models.QueryOnlineGameInfoList(&req, &res)
}

其中:

 this.Ctx.ResponseWriter.Header().Add("Access-Control-Allow-Origin", "*")
this.Ctx.ResponseWriter.Header().Add("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept")

是为了解决beego响应的跨域问题,否则如ajax等请求接收不到返回值。

另外:注解@router可以生成路由router包的初始化方法

// @router /queryOnlineGameInfo [post,get]

如果没有,在编译执行时,会发现router的init方法中没有这个路由,尽管你可以手动加上去重新启动服务,但是下次重新编译执行时仍然会被刷掉

生成的init方法如下:

package routers

import (
"github.com/astaxie/beego"
"github.com/astaxie/beego/context/param"
) func init() { beego.GlobalControllerRouter["migu_market/src/controllers:OnlineGameController"] = append(beego.GlobalControllerRouter["migu_market/src/controllers:OnlineGameController"],
beego.ControllerComments{
Method: "GetOnlineGameInfo",
Router: `/queryOnlineGameInfo`,
AllowHTTPMethods: []string{"post", "get"},
MethodParams: param.Make(),
Params: nil})
.....
}

2.http请求的参数传递

var req models.OnlineGameInfoRequest
reqData := this.GetString("data")
json.Unmarshal(([]byte)(reqData), &req)

在上面controllers中,使用beego路由的 GetString("data")方法获取一个json字符串(注意这里是json字符串不是数组),所以在请求时参数也应为字符串,(以ajax为例)

var pid = "13";
var innerID = "13";
var gameID = "1";
var channel = "c1";
var version = "1";
var versionName = "v1";
var pkgArr = ["a","b","c"] var json = {};
json.channel = channel;
json.pid = pid;
json.versionName = versionName;
json.version = version;
json.gameID = gameID;
json.innerID = innerID;
json.pkgNames = pkgArr; $.post("http://127.0.0.1:18080/market/exchange/queryOnlineGameInfo",{
"data": JSON.stringify(json)
},function(data){
$("#response").html(JSON.stringify(data))
},'json');

这里对于JSON.stringify()有一个疑惑,对于json的两种写法出现不同的结果,如果有朋友看到此处,希望可以帮忙解答。如下两种写法,第二种写法会报错。

    var name = "shm";
var age = "18";
var sex = "man"; var student = {};
student.name = name;
student.age = age;
student.sex = sex; var pid = "13";
var innerID = "13";
var gameID = "1";
var channel = "c1";
var version = "1";
var versionName = "v1"; var json = {};
json.channel = channel;
json.pid = pid;
json.versionName = versionName;
json.version = version;
json.gameID = gameID;
json.innerID = innerID;
json.student = student; alert(JSON.stringify(data));
var json = {
channel : channel,
pid : pid,
versionName : versionName,
version : version,
gameID : gameID,
innerID : innerID,
student : {
name : name,
age : age,
sex : sex
}
alert(JSON.stringify(data));

在获取到json字符串后,使用json.Unmarshal解析,并把结果赋给一个指定的结构体实例,注意这里传的是指针。(很好理解,因为我们就是希望json方法在处理时把值赋给当前这个实例,如果传入的是实例,那么json方法接收的将是这个实例的一个副本,就是说方法的处理不会修改当前实例,这点跟java里有些区别,java传参时除了基本类型外,传的参数都是实例的引用也就是指针,而go做了区分,除指针外,传参均为值传递),对应的结构体定义如下:

package models

import (
"bytes"
"common/log"
"errors"
"github.com/astaxie/beego/orm"
"strconv"
"strings"
utf8 "unicode/utf8"
) type OnlineGameInfoRequest struct {
Channel string `json:"channel"`
Pid string `json:"pid"`
VersionName string `json:"versionName"`
Version string `json:"version"`
GameID string `json:"gameID"`
//Lua与文档不一致的字段
InnerID string `json:"innerID"`
FileCid string `json:"fileCid"`
PkgNames []string `json:"pkgNames"` IntGameID int
IntVersion int
IntInnerID int
IntPid int
} ...
}

问题.beego路由设置及请求参数传递的更多相关文章

  1. golang学习笔记6 beego项目路由设置

    golang学习笔记5 beego项目路由设置 前面我们已经创建了 beego 项目,而且我们也看到它已经运行起来了,那么是如何运行起来的呢?让我们从入口文件先分析起来吧: package main ...

  2. beego框架学习(二) -路由设置

    路由设置 什么是路由设置呢?前面介绍的 MVC 结构执行时,介绍过 beego 存在三种方式的路由:固定路由.正则路由.自动路由,接下来详细的讲解如何使用这三种路由. 基础路由 从beego1.2版本 ...

  3. 【beego】beego的路由设置

    beego 存在三种方式的路由:固定路由.正则路由.自动路由 基础路由 从 beego 1.2 版本开始支持了基本的 RESTful 函数式路由,应用中的大多数路由都会定义在 routers/rout ...

  4. IIS 7.5 + asp.net MVC4 设置路由处理URL请求

    使用asp.net MVC4开发的网站,在本地的VS012环境下运行,一切正常.但当发布到Windows 2008 R2(IIS7.5 + Framework4.5)上时,访问相关网页时,出现有下面的 ...

  5. .Net Core 学习路由和请求参数传递

    一.配置默认路由方式 {Controller=Home}/{action=Index}/{id?} 默认请求地址:http://localhost:xxx/home/index /id? 是可选项例如 ...

  6. begoo——路由设置

    路由本质是URL与要为该URL调用的视图函数之间的映射表,其实就是你定义的使用那个URL调用那段代码的关系对应表. 首先看一下最简单的路由: package routers import ( &quo ...

  7. Go语言web开发---Beego路由

    参考链接(查看更多):https://beego.me/docs/mvc/controller/router.md 基础路由 从 beego 1.2 版本开始支持了基本的 RESTful 函数式路由, ...

  8. MVC3.0,路由设置实现伪静态IIS中404错误

    C# code? 1 2 3 4 5  routes.MapRoute("NewQueryTest.asp",                 "NewQueryTest ...

  9. express中路由设置的坑-----1

    router.get('/commodities/sortable', utils.logged, function (req, res) { Commodity.find({force_top:tr ...

随机推荐

  1. Linux基本操作及安装(部分)

    1.分别用cat \tac\nl三个命令查看文件/etc/ssh/sshd_config文件中的内容,   并用自己的话总计出这三个文档操作命令的不同之处? [root@localhost ~]# c ...

  2. grep使用集合

    一.grep使用 (一).选项 -a 不要忽略二进制数据. -A<显示列数> 除了显示符合范本样式的那一行之外,并显示该行之后的内容. -b 在显示符合范本样式的那一行之外,并显示该行之前 ...

  3. jQuery插件之路(三)——文件上传(支持拖拽上传)

    好了,这次咱一改往日的作风,就不多说废话了,哈哈.先贴上源代码地址,点击获取.然后直接进入主题啦,当然,如果你觉得我有哪里写的不对或者欠妥的地方,欢迎留言指出.在附上一些代码之前,我们还是先来了解下, ...

  4. 【Java例题】4.1 级数求和1

    1. 计算级数之和: y=1-1/2+1/4-1/8+...+ (-1)^(n-1)/2^(n-1). 这里的"^"表示乘方. package chapter4; import j ...

  5. springboot集成redis实现消息发布订阅模式-双通道(跨多服务器)

    基础配置参考https://blog.csdn.net/llll234/article/details/80966952 查看了基础配置那么会遇到一下几个问题: 1.实际应用中可能会订阅多个通道,而一 ...

  6. Prometheus 集成 Node Exporter

    文章首发于公众号<程序员果果> 地址:https://mp.weixin.qq.com/s/40ULB9UWbXVA21MxqnjBxw 简介 Prometheus 官方和一些第三方,已经 ...

  7. Java一个简单的文件工具集

    class FileUtils { //文件目录下文件总数目 public static int fileNumber(File dir) { int filenumber = 0; if(dir.e ...

  8. Flink 源码解析 —— Standalone Session Cluster 启动流程深度分析之 Job Manager 启动

    Job Manager 启动 https://t.zsxq.com/AurR3rN 博客 1.Flink 从0到1学习 -- Apache Flink 介绍 2.Flink 从0到1学习 -- Mac ...

  9. laya 下以光标为中心缩放对象

    private MouseWheel(e: Laya.Event) { console.log("event"); let currentSp = e.target as Laya ...

  10. RuntimeError: one of the variables needed for gradient computation has been modified by an inplace

    vgg里面的 ReLU默认的参数inplace=True 当我们调用vgg结构的时候注意 要将inplace改成 False 不然会报错 RuntimeError: one of the variab ...