我无法通过 api 将数据从 java 程序插入到 laravel 应用程序

I cant insert data from a java program to laravel app via api

我是 laravel 的新手,我想通过 java 程序通过 laravel api 将数据保存到我的在线服务器,但我遇到了错误。

这是我在 api.php 上的路线:

Route::middleware('auth:api')->get('/user', function (Request $request) {
    return $request->user();
});


Route::post('hooks','ApiTestController@store');

我的 ApiTestController:它只处理 POST 请求然后保存到 table.

public function store(Request $request)
    {

            $postdata = json_decode($request->input('post_data'), true);
            $datas = $postdata['header'];
            $data = $datas[0];
            $testH = new TestH();
            $testH->test_date = $data['test_date'];
            $testH->expiration = $data['test_date'];
            $testH->source = $data['source'];


            $testH->save();

            return $testH;
   }

和我的 java 代码:

try {
    //local development server url
    URL url = new URL("http://127.0.0.1:8000/api/hooks");
    URLConnection con = url.openConnection();
    // activate the output
    con.setDoOutput(true);
    PrintStream ps = new PrintStream(con.getOutputStream());

        //create the JSON String
        String json = null;
        StringWriter sw = new StringWriter();
        JSONWriter wr = new JSONWriter(sw);

        try {
            wr.object().key("header").array();

            wr.object();
            wr.key("test_date").value(new Date());
            wr.key("source").value("TEST");
            wr.key("expiration").value(new Date());


            wr.endObject();

            wr.endArray().endObject();
            json = sw.toString();
            System.out.println(json);
        } catch (JSONException ex) {
            Logger.getLogger(WebConnectSample.class.getName()).log(Level.SEVERE, null, ex);
        }

        // send to laravel server
        ps.print("post_data="+json);

        HttpURLConnection httpConn = (HttpURLConnection) con;
        InputStream is;
        if (httpConn.getResponseCode() >= 419) {
            is = httpConn.getErrorStream();
        } else {
            is = httpConn.getInputStream();
        }

        // read the server reply
        BufferedReader in = new BufferedReader(new InputStreamReader(con.getInputStream()));
        String line = null;
        while ((line = in.readLine()) != null) {
            System.out.println(line);
            // close the print stream
        }
        ps.close();
    } catch (Exception e) {
        e.printStackTrace();
    }
  }

问题是当我不通过 $testH->save() 保存时一切正常。但是如果我包含它 java returns 并出现以下错误:

Type error: Argument 1 passed to Illuminate\Routing\Middleware\ThrottleRequests::addHeaders() must be an instance of Symfony\Component\HttpFoundation\Response, string given, called in C:\Users\relixusdev\Documents\WebProjects\tcmsite\vendor\laravel\framework\src\Illuminate\Routing\Middleware\ThrottleRequests.php on line 61

知道是什么部分导致了错误吗?它与身份验证有关吗?我只想通过我的 java 程序保存到在线数据库。

尝试使用前缀如下的路由组

Route::group(['prefix' => 'api'], function() {
   Route::post('hooks','ApiTestController@store');
});

如果有人来这里遇到同样的问题,我发现问题是我的 table 中没有 created_at 和 updated_at 列。我没有意识到它是 laravel 的要求。傻我。