问题.beego路由设置及请求参数传递
最近项目组安排将一组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路由设置及请求参数传递的更多相关文章
- golang学习笔记6 beego项目路由设置
golang学习笔记5 beego项目路由设置 前面我们已经创建了 beego 项目,而且我们也看到它已经运行起来了,那么是如何运行起来的呢?让我们从入口文件先分析起来吧: package main ...
- beego框架学习(二) -路由设置
路由设置 什么是路由设置呢?前面介绍的 MVC 结构执行时,介绍过 beego 存在三种方式的路由:固定路由.正则路由.自动路由,接下来详细的讲解如何使用这三种路由. 基础路由 从beego1.2版本 ...
- 【beego】beego的路由设置
beego 存在三种方式的路由:固定路由.正则路由.自动路由 基础路由 从 beego 1.2 版本开始支持了基本的 RESTful 函数式路由,应用中的大多数路由都会定义在 routers/rout ...
- IIS 7.5 + asp.net MVC4 设置路由处理URL请求
使用asp.net MVC4开发的网站,在本地的VS012环境下运行,一切正常.但当发布到Windows 2008 R2(IIS7.5 + Framework4.5)上时,访问相关网页时,出现有下面的 ...
- .Net Core 学习路由和请求参数传递
一.配置默认路由方式 {Controller=Home}/{action=Index}/{id?} 默认请求地址:http://localhost:xxx/home/index /id? 是可选项例如 ...
- begoo——路由设置
路由本质是URL与要为该URL调用的视图函数之间的映射表,其实就是你定义的使用那个URL调用那段代码的关系对应表. 首先看一下最简单的路由: package routers import ( &quo ...
- Go语言web开发---Beego路由
参考链接(查看更多):https://beego.me/docs/mvc/controller/router.md 基础路由 从 beego 1.2 版本开始支持了基本的 RESTful 函数式路由, ...
- MVC3.0,路由设置实现伪静态IIS中404错误
C# code? 1 2 3 4 5 routes.MapRoute("NewQueryTest.asp", "NewQueryTest ...
- express中路由设置的坑-----1
router.get('/commodities/sortable', utils.logged, function (req, res) { Commodity.find({force_top:tr ...
随机推荐
- c#小灶——初识c#
提到c#,就不得不说.net,.net是微软开发的一个平台,简单来说,在这个平台上,可以编写.运行程序.可能很多人觉得这个平台离我们很遥远,其实不然,这个平台就一直在我们的windows操作系统里,默 ...
- 基于spring的观察者模式
简单的说,观察者模式,就类似于 广播站发送广播,和收音机的关系.多个收音机去收听同一个广播频道. 在实际的业务场景中,可以是这样的.创建订单成功后,发布事件.然后减库存.发送短信.调用微信.调用物流服 ...
- java中System.out.println()打印输出结果
疑点:syso()是打印输出语句,打印的是什么? syso()不同情况下打印输出的结果不一样: 1. package com.briup; public class Syso { public sta ...
- AUTOSAR学习之RTE - 可运行实体
本文介绍RTE的运行体(runnable). An AUTOSAR component defines one or more "runnable entities". A run ...
- 算法与数据结构基础 - 链表(Linked List)
链表基础 链表(Linked List)相比数组(Array),物理存储上非连续.不支持O(1)时间按索引存取:但链表也有其优点,灵活的内存管理.允许在链表任意位置上插入和删除节点.单向链表结构一般如 ...
- 通过Blazor使用C#开发SPA单页面应用程序(2)
今天我们尝试创建一个默认的Blazor应用. 1.安装 .Net Core 3.0需要Visual Studio 2019 的支持. 安装.Net Core 3.0 预览版 SDK版本,注意预览版对应 ...
- 压力测试-jmeter
1. 场景描述 新申请的服务器,要压测下python算法程序最多能执行多少条数据,有几年没用压力测试工具-jmeter了,重新下载了最新版本,记录下,也希望能帮到准备使用jmeter做压测的朋友. 2 ...
- 优雅的在WinForm/WPF/控制台 中使用特性封装WebApi
优雅的在WinForm/WPF/控制台 中使用特性封装WebApi 说明 在C/S端作为Server,建立HTTP请求,方便快捷. 1.使用到的类库 Newtonsoft.dll 2.封装 HttpL ...
- 扩展GroupBox控件
1.GroupBox的边框颜色可以自行设置: 2.GroupBox可以设置边框的为圆角: 3.设置GroupBox标题在控件中的位置. 4.设置GroupBox标题的字体和颜色. 具体实现步骤Pane ...
- 100天搞定机器学习|day39 Tensorflow Keras手写数字识别
提示:建议先看day36-38的内容 TensorFlow™ 是一个采用数据流图(data flow graphs),用于数值计算的开源软件库.节点(Nodes)在图中表示数学操作,图中的线(edge ...