ActiveWeb: пользовательские контроллеры в подпакетах не работают
Я создал RouteConfig
класс в app.config
пакет следующим образом:
public class RouteConfig extends AbstractRouteConfig {
@Override
public void init(AppContext appContext) {
route("/{controller}/{aut_id}/").to(AuthorsController.class).action("findById");
}
я создал AppControllerConfig
учебный класс:
package app.config;
import app.controllers.CatchAllFilter;
import app.controllers.api.v2.AuthorsController;
import org.javalite.activeweb.AbstractControllerConfig;
import org.javalite.activeweb.AppContext;
import org.javalite.activeweb.controller_filters.DBConnectionFilter;
public class AppControllerConfig extends AbstractControllerConfig {
public void init(AppContext context) {
add(new DBConnectionFilter(), new CatchAllFilter()).to(AuthorsController.class);
}
}
Я также определил APIController
Класс следующим образом:
package app.controllers;
import org.javalite.activeweb.AppController;
public abstract class APIController extends AppController {
@Override
protected String getContentType() {
return "application/json";
}
@Override
protected String getLayout() {
return null;
}
}
AuthorsController
в app.controllers.api.v2
пакет:
import app.controllers.APIController;
import app.models.Author;
public class AuthorsController extends APIController {
public void findById() {
if (blank("aut_id")) {
throw new RuntimeException("aut_id number is mandatory but was empty or null");
} else {
Author author = Author.findById(param("aut_id"));
String jsonResponse = author.toJson(false);
respond(jsonResponse);
}
}
}
При попытке получить доступ к URL http://localhost:8080/api/v2/authors/9
Я получаю ошибку:
Request properties: Request URL: http://localhost:8080/api/v2/authors/9
ContextPath:
Query String: null
URI Full Path: /api/v2/authors/9
URI Path: /api/v2/authors/9
Method: GET
Request parameters: {}
Request headers: {Cookie=_ga=GA1.1.1833610632.1527846931; JSESSIONID=node03k88mhw4nihozrzi9ehiiadj0.node0, Cache-Control=no-cache, Accept=text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8, Upgrade-Insecure-Requests=1, Connection=keep-alive, User-Agent=Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/68.0.3440.106 Safari/537.36, Host=localhost:8080, Pragma=no-cache, Accept-Encoding=gzip, deflate, br, Accept-Language=en,fr;q=0.9,ru;q=0.8}
org.javalite.activeweb.ActionNotFoundException: java.lang.NoSuchMethodException: app.controllers.api.v2.AuthorsController.9(); app.controllers.api.v2.AuthorsController.9()
[qtp1987707214-16] WARN ParamCopy - found 'session' value set by controller. It is reserved by ActiveWeb and will be overwritten.
[qtp1987707214-16] INFO FreeMarkerTemplateManager - rendering template: '/system/404' with layout: '/layouts/default_layout', session: node018slc2f7n5p0v67173ezr8guc0
[qtp1987707214-16] WARN FreeMarkerTemplateManager - Current location: /Users/Serguei/projects/java/newton-interventions
[qtp1987707214-16] ERROR RequestDispatcher - ActiveWeb internal error:
org.javalite.activeweb.ViewMissingException: Failed to render template: '/system/404.ftl', with layout: '/layouts/default_layout'; Template "/system/404.ftl" not found.
Что я делаю неправильно? Я даже не захожу AuthorsController
... Кажется, он игнорирует мое определение маршрута и пытается найти следующее:
"method":"GET","action":"9","error":"java.lang.NoSuchMethodException: app.controllers.api.v2.AuthorsController.9()
При объявлении index
Действуйте в том же контроллере следующим образом:
public void index() {
final String json = Author.findFirst("AUT_ID = 9").toJson(false);
respond(json);
}
и удар http://localhost:8080/api/v2/authors
, оно работает.
2 ответа
Это сбрасывало ошибку в системе маршрутизации: https://github.com/javalite/activeweb/issues/397 Ошибка была исправлена и новый снимок развернут в версии Sonatype: 2.3-SNAPSHOT. https://oss.sonatype.org/content/repositories/snapshots/org/javalite/activeweb/2.3-SNAPSHOT/
Теперь вы можете попробовать проверить, работает ли это. BWT, спасибо за подробное описание, это помогло настроить правильную спецификацию: RouterCustomSpec
Наконец, я понял, как заставить это работать.
Я изменил объявление маршрута в RouteConfig
Класс следующим образом:
route("/{controller}/find-by-id}/{id}").to(AuthorsController.class).action("findById");
Я изменилсяfindById
метод в AuthorsController
следующее:
public void findById() {
System.out.println(params());
if (blank("id")) {
throw new RuntimeException("autId number is mandatory but was empty or null");
} else {
Author author = Author.findById(param("id"));
String jsonResponse = author.toJson(false);
respond(jsonResponse);
}
}
Кажется, что по соглашению имя параметра, переданного в качестве числа в URL, считается id
и ничего больше, верно?