gpt4 book ai didi

perl - 如何为所有传入的 URL 创建通用处理程序?

转载 作者:行者123 更新时间:2023-12-04 14:41:38 26 4
gpt4 key购买 nike

我正在编写一些 web api,它以 JSON 格式返回数据。

对于所有传入的 url,如果缓存期未到期,我需要从缓存返回一些结果。

此逻辑对所有 URL 都是通用的。

题:

如何为 Mojolicious::Lite 中的所有传入 URL 实现一些通用逻辑?

我试着做

any '/:bar' => [bar => qr/.+/] => sub {
# ...
# Return JSON object immediately from cache if it is applicable
# ...
}

但这会导致很长的页面加载和
Template "bar.html.ep" not found

在 morbo 日志中(但在很长的延迟后,最终将执行 get "/target"处理程序)。

我是 Mojo 的完美新手,所以任何帮助将不胜感激

谢谢!

最佳答案

是的,一个 before_dispatch hook 似乎是正确的方法,它确实适用于 Mojolicious::Lite .这是一个概念证明,它将为每个唯一请求生成一个新结果,但为重复请求返回重复结果。在此程序中,常规请求处理程序填充缓存,但如果您想将该部分与代码的主要功能分开,您可以在 after_dispatch 中进行缓存。钩。

use Mojolicious::Lite;

our %CACHE;

any '/:any' => sub {
my $self = shift;
my $param = $self->param('any');
my $result = { reqtime => time, param => $param, number => rand };
my $path = $self->req->url->path->to_string;
$CACHE{$path} //= $result;
$self->render( json => $result );
};

app->hook( before_dispatch => sub {
my $c = shift;
my $path = $c->req->url->path->to_string;
if (defined($CACHE{$path})) {
$c->render( json => $CACHE{$path}, status => 200 );
}
} );
app->secrets([42])->start;

示例运行:
$ morbo cachedemo.pl >/dev/null 2>&1 &

$ for req in foo foo1 foo2 foo3 foo foo1
> do curl http://localhost:3000/$req ; echo ; sleep 1 ; done

{"number":0.848003210075227,"reqtime":1444254617,"param":"foo"}
{"number":0.0745738560703799,"reqtime":1444254618,"param":"foo1"}
{"number":0.484934245556467,"reqtime":1444254619,"param":"foo2"}
{"number":0.181112856445004,"reqtime":1444254620,"param":"foo3"}
{"number":0.848003210075227,"reqtime":1444254617,"param":"foo"} <-- dup
{"number":0.0745738560703799,"reqtime":1444254618,"param":"foo1"} <-- dup

关于perl - 如何为所有传入的 URL 创建通用处理程序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32992325/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com