当使用yaws_api特定代码时,雅司“进程死亡”

时间:2012-10-28 13:12:59

标签: erlang yaws

我有一个小yaws appmod测试:

-module(webservice).
-include("../include/yaws_api.hrl").
-compile(export_all).

http(parse_query,Arg) ->
    yaws_api:parse_query(Arg);

out(Arg) -> 
    {html, [http(parse_query,Arg)]}.

当yaws_api:parse_query函数运行时,我从yaws交互模式获得以下ERROR REPORT:

Yaws process died: {function_clause,
                   [{yaws_server,binary_size,
                        [0,{"i",undefined}],
                        [{file,"yaws_server.erl"},{line,3015}]},
                    {yaws_server,binary_size,2,
                        [{file,"yaws_server.erl"},{line,3018}]},
                    {yaws_server,binary_size,2,
                        [{file,"yaws_server.erl"},{line,3018}]},
                    {yaws_server,deflate_accumulated,4,
                        [{file,"yaws_server.erl"},{line,3712}]},
                    {yaws_server,deliver_accumulated,4,
                        [{file,"yaws_server.erl"},{line,3666}]},
                    {yaws_server,finish_up_dyn_file,2,
                        [{file,"yaws_server.erl"},{line,2745}]},
                    {yaws_server,aloop,4,
                        [{file,"yaws_server.erl"},{line,1175}]},
                    {yaws_server,acceptor0,2,
                        [{file,"yaws_server.erl"},{line,1016}]}]}

appmod在config中设置:

<server localhost>
    port = 8080
    listen = 127.0.0.1
    #docroot = /usr/share/yaws
    docroot = /usr/lib/yaws/www
    appmods = </,webservice>
    # dir_listings = true
</server>

1 个答案:

答案 0 :(得分:8)

虽然您没有显示它,但您尝试访问的URL看起来像是一个查询字符串,其中包含至少一个名为i的变量,如下所示:

http://example.com/foo?i=10

对于该网址,yaws_api:parse_query/1将返回[{"i","10"}],然后您尝试使用{html, iolist()}构造以HTML格式返回Yaws。不幸的是,[{"i","10"}]不是一个iolist,字符串或二进制文件,所以Yaws失败了。

您可以使用[{"i","10"}]调用将yaws_api:f/2转换为字符串来解决此问题,如下所示:

out(Arg) ->
    {html, yaws_api:f("~p", [http(parse_query,Arg)])}.

或使用标准io_lib:format/2来电:

out(Arg) ->
    {html, io_lib:format("~p", [http(parse_query,Arg)])}.

yaws_api:f/2函数只是io_lib:format/2的包装。