質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Vue CLI

Vue CLIは、Vue.jsでアプリケーション開発を行うためのコマンドラインインタフェース(CLI)に基づいた開発ツールです。インタラクティブなプロジェクトの雛形や設定なしで使用できるプロトタイプの作成など、さまざまな機能が用意されています。

Go

Go(golang)は、Googleで開発されたオープンソースのプログラミング言語です。

Q&A

解決済

1回答

373閲覧

vue-cli axios から golangのAPIをpostで呼び出したい

lkeix_

総合スコア12

Vue CLI

Vue CLIは、Vue.jsでアプリケーション開発を行うためのコマンドラインインタフェース(CLI)に基づいた開発ツールです。インタラクティブなプロジェクトの雛形や設定なしで使用できるプロトタイプの作成など、さまざまな機能が用意されています。

Go

Go(golang)は、Googleで開発されたオープンソースのプログラミング言語です。

0グッド

0クリップ

投稿2019/04/08 09:21

Vue-Cli axios golang のAPI呼び出し

axiosからgolang側のAPIをpostで呼び出したいのですが、Not Foundになってしまいます。

ちなみにGETなら正常にリクエストが送られます。(しかし、データがうまく取得できていない。。)

npm run buildして、静的ファイルを吐き出して、goでサーバを立てて動かしています。

リクエストを送るコードは以下のようになります。

Newuser.vue

axios.post('/apis/adduser/', params).then(res => { alert('「' + data.name + '」登録完了') }).catch(error => { alert('「' + data.name + '」登録失敗') console.log(error, data) })

localhost:8000/apis/adduserが呼び出すgolangのAPIになっています。

いかがサーバサイドのコードになります。

Serve.go

package main import ( "net/http" "./Users" "github.com/gin-gonic/gin" ) func main() { router := gin.Default() router.LoadHTMLGlob("../../dist/*.html") router.Static("/static/css", "../../dist/static/css") router.Static("/static/fonts", "../../dist/static/fonts") router.Static("/static/js", "../../dist/static/js") router.GET("/apis/adduser", Users.AddUser) router.Run(":8000") }

AddUser.go

func AddUser(g *gin.Context) { req := g.Request writer := g.Writer writer.WriteString("aaaa") req.ParseForm() fmt.Println(req.Method) fmt.Println(req.Form) var data = Data{} decoder := json.NewDecoder(req.Body) err := decoder.Decode(&data) if err == nil { panic(err) } fmt.Println("Name : " + data.Name + "\nMail : " + data.Mail + "\nID : " + data.Id + "\nPasswd :" + data.Ps) }

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

router.GET("/apis/adduser", Users.AddUser)
と書かれている通り、GETメソッドにのみ応答を返すように実装されているのでPOSTしても対応するハンドラが無いです。

投稿2019/04/08 13:01

nobonobo

総合スコア3367

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

lkeix_

2019/04/09 10:47 編集

router.POST("/apis/adduser",Users.AddUser)でPOSTメソッドに対応するハンドラを登録することができました。 いつもありがとうございます。BAにさせていただきます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問