处理公共参数
This commit is contained in:
@@ -10,6 +10,9 @@ const (
|
|||||||
ErrCodeTokenIsInvalid = "-2"
|
ErrCodeTokenIsInvalid = "-2"
|
||||||
|
|
||||||
ErrCodeJsonSyncErr = "-105"
|
ErrCodeJsonSyncErr = "-105"
|
||||||
|
|
||||||
|
ErrCodeOpenAPIParamErrMethod = "1000" //参数错误,method
|
||||||
|
ErrCodeOpenAPIParamErrTimeStamp = "1001" //参数错误,timestamp
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
|
|||||||
@@ -2,7 +2,11 @@ package controllers
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"git.rosy.net.cn/baseapi/utils"
|
||||||
|
"git.rosy.net.cn/jx-callback/business/model"
|
||||||
|
"git.rosy.net.cn/jx-callback/globals"
|
||||||
"github.com/astaxie/beego/server/web"
|
"github.com/astaxie/beego/server/web"
|
||||||
|
"net/url"
|
||||||
"reflect"
|
"reflect"
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -31,21 +35,101 @@ func Init() {
|
|||||||
|
|
||||||
// @Title api调用入口
|
// @Title api调用入口
|
||||||
// @Description api调用入口
|
// @Description api调用入口
|
||||||
// @Param app_id formData string true "应用ID"
|
// @Param app_id formData string false "应用ID"
|
||||||
// @Param timestamp formData int true "unix时间戳"
|
// @Param timestamp formData int64 false "unix时间戳"
|
||||||
// @Param sign formData string true "签名"
|
// @Param sign formData string false "签名"
|
||||||
// @Param method formData string true "接口名"
|
// @Param method formData string false "接口名"
|
||||||
// @Success 200 {object} controllers.CallResult
|
// @Success 200 {object} controllers.CallResult
|
||||||
// @Failure 200 {object} controllers.CallResult
|
// @Failure 200 {object} controllers.CallResult
|
||||||
// @router /CallOpenAPI [post]
|
// @router /CallOpenAPI [post]
|
||||||
func (c *ApiController) CallOpenAPI() {
|
func (c *ApiController) CallOpenAPI() {
|
||||||
fmt.Println(routerMap)
|
var (
|
||||||
method := c.GetString("method")
|
err error
|
||||||
parms := []reflect.Value{reflect.ValueOf("test")}
|
errCode = model.ErrCodeGeneralFailed
|
||||||
|
callResult = &CallResult{}
|
||||||
|
accessID = utils.GetUUID()
|
||||||
|
requireParams []string
|
||||||
|
dataMap = make(map[string]interface{})
|
||||||
|
//now = time.Now().Unix()
|
||||||
|
parms, result []reflect.Value
|
||||||
|
urls url.Values
|
||||||
|
)
|
||||||
|
var (
|
||||||
|
appID, sign, method string
|
||||||
|
//timestamp int64
|
||||||
|
)
|
||||||
|
//判断必传参数是否传入begin
|
||||||
|
if appID = c.GetString("app_id"); appID == "" {
|
||||||
|
requireParams = append(requireParams, "app_id")
|
||||||
|
}
|
||||||
|
if method = c.GetString("method"); method == "" {
|
||||||
|
requireParams = append(requireParams, "method")
|
||||||
|
}
|
||||||
|
if sign = c.GetString("sign"); sign == "" {
|
||||||
|
requireParams = append(requireParams, "sign")
|
||||||
|
}
|
||||||
|
//if timestamp, err = c.GetInt64("timestamp"); err != nil {
|
||||||
|
// requireParams = append(requireParams, "timestamp")
|
||||||
|
//}
|
||||||
|
if len(requireParams) > 0 {
|
||||||
|
err = buildParamRequiredErr(requireParams)
|
||||||
|
}
|
||||||
|
//判断必传参数是否传入end
|
||||||
|
if err != nil {
|
||||||
|
goto end
|
||||||
|
}
|
||||||
|
//判断timestamp传入是否正确begin
|
||||||
|
//if len(utils.Int64ToStr(timestamp)) != len(utils.Int64ToStr(now)) {
|
||||||
|
// err = buildTimestampParamErr()
|
||||||
|
// errCode = model.ErrCodeOpenAPIParamErrTimeStamp
|
||||||
|
//}
|
||||||
|
//if now-timestamp < 5 {
|
||||||
|
// err = buildTimestampParamErr()
|
||||||
|
// errCode = model.ErrCodeOpenAPIParamErrTimeStamp
|
||||||
|
//}
|
||||||
|
//判断timestamp传入是否正确end
|
||||||
|
if err != nil {
|
||||||
|
goto end
|
||||||
|
}
|
||||||
|
//判断app_id和sign匹配begin
|
||||||
|
|
||||||
fmt.Println("routerMap[method].Call(parms)", routerMap[method].Call(parms))
|
//判断app_id和sign匹配end
|
||||||
|
//call
|
||||||
|
urls, _ = c.Input()
|
||||||
|
dataMap = utils.URLValues2Map(urls)
|
||||||
|
delete(dataMap, "app_id")
|
||||||
|
delete(dataMap, "method")
|
||||||
|
delete(dataMap, "timestamp")
|
||||||
|
parms = []reflect.Value{reflect.ValueOf(dataMap)}
|
||||||
|
if routerMap[method] == reflect.ValueOf(nil) {
|
||||||
|
errCode = model.ErrCodeOpenAPIParamErrMethod
|
||||||
|
err = buildMethodParamErr()
|
||||||
|
}
|
||||||
|
globals.SugarLogger.Debugf("Begin API CallOpenAPI Method: %s, accessUUID:%s, sign:%s\n", method, accessID, sign)
|
||||||
|
if err == nil {
|
||||||
|
result = routerMap[method].Call(parms)
|
||||||
|
fmt.Println("routerMap[method].Call(parms)", result)
|
||||||
|
goto success
|
||||||
|
} else {
|
||||||
|
callResult.Code = errCode
|
||||||
|
callResult.Desc = err.Error()
|
||||||
|
}
|
||||||
|
end:
|
||||||
|
{
|
||||||
|
callResult.Code = errCode
|
||||||
|
callResult.Desc = err.Error()
|
||||||
|
c.Data["json"] = callResult
|
||||||
|
c.ServeJSON()
|
||||||
|
}
|
||||||
|
success:
|
||||||
|
{
|
||||||
|
callResult.Code = model.ErrCodeSuccess
|
||||||
|
callResult.Data = ""
|
||||||
|
c.Data["json"] = callResult
|
||||||
|
c.ServeJSON()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *ApiController) AddPrint() {
|
func (c *ApiController) AddPrint(dataMap map[string]interface{}) (data interface{}, err error) {
|
||||||
fmt.Println("call AddPrint success ...")
|
return fmt.Println("call AddPrint success ...", dataMap)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,7 +1,34 @@
|
|||||||
package controllers
|
package controllers
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
type CallResult struct {
|
type CallResult struct {
|
||||||
Code string `json:"code"`
|
Code string `json:"code"`
|
||||||
Desc string `json:"desc"`
|
Desc string `json:"desc"`
|
||||||
Data string `json:"data"`
|
Data string `json:"data"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func buildParamRequiredErr(str []string) (err error) {
|
||||||
|
msg := "缺少参数["
|
||||||
|
for k, v := range str {
|
||||||
|
if k != 0 {
|
||||||
|
msg += "," + v
|
||||||
|
} else {
|
||||||
|
msg += v
|
||||||
|
}
|
||||||
|
}
|
||||||
|
msg += "],请传入正确的值!"
|
||||||
|
return fmt.Errorf(msg)
|
||||||
|
}
|
||||||
|
|
||||||
|
func buildParamErr(str string) (err error) {
|
||||||
|
return fmt.Errorf("参数[%s]错误,请传入正确的值!", str)
|
||||||
|
}
|
||||||
|
|
||||||
|
func buildMethodParamErr() (err error) {
|
||||||
|
return fmt.Errorf("参数['method']错误,请传入正确的值!")
|
||||||
|
}
|
||||||
|
|
||||||
|
func buildTimestampParamErr() (err error) {
|
||||||
|
return fmt.Errorf("参数['timestamp']和服务器时间差距过大,请传入正确的值!")
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user