upload.yaws не работает с erlang R16B-03.7.el7 и yaws 1.98-2.el7

Мне нужна помощь. У меня был рабочий сайт. Последним шагом перед запуском было обновление ssl-сертификатов. Этого не произошло из-за ошибки в этой версии erlang. Я обновил erlang, а затем обнаружил несоответствие уровней кода между erlang и драйвером yaws. Я загрузил и выполнил зевки и, к моему огромному удовольствию, смог обновить сертификаты ssl. После запуска развертывания пользователь указал, что функция загрузки не работает. Я проверил, что он все еще работает с версией, которая не будет принимать сертификат SSL. Я предположил, что проблема была в процессе сборки, поэтому я начал с новой виртуальной машины CentOS 7 и Erlang и Yaws из этого дистрибутива. Та же проблема. Похоже, что я могу загрузить или новые сертификаты, но не оба. Моя версия загрузки - слегка измененная версия из std upload.yaws. Однако я поднял это и попробовал это. Это также не удалось. Ниже приведены уровни программного обеспечения, код ошибки и данные о сбое.

Любая помощь будет оценена.

________ Код _____________________________________________________________________ CentOS 3.10.0-123.6.3.el7.x86_64 erlang.x86_64 R16B-03.7.el7 @epel yaws.x86_64 1.98-2.el7 @epel

_КОД____________________________________________________________________________________________________________________________

 -record(upload, { % represents state for a partially processed upload
      fd,
      filename,
      last}).

-define(DIR, "/var/lib/yaws/www/cwfiles/").

showup(List) -> % Adds the rows of files from the DB
    [{tr,[],[
        {th,[], "File Name"}
    ]},
    map(fun(Y) ->  {TFid,FName} = Y, [
        {tr,[],[
                {td,[], [{input, [{type,text},{name,"Filename"},{value,FName}]}]},
            {td,[], [{a,[{href,["dpagepost.yaws?action=delf&    fid=",integer_to_list(TFid),"&fname=",[FName]]}],"Delete File"}]}
        ]}
    ] end, List)].

upload(A) -> upload(A,[]).
upload(A, Comment) ->
Css = css_head(A,on,57),
    Body = case getadmen(A) of
        true ->
            Ref=dbconnect(),
            {selected,_,LFil} = odbc:sql_query(Ref,"select fid,filename from files"),
            odbc:disconnect(Ref),
            {ehtml, [
                {h2, [], "Update Files (Upload/Delete)"},
                {hr},
                {h3,[], [Comment]},
                {hr},
                {table, [], [
                    showup(LFil) % Do rows from DB
                ]}, %end table
                {hr},
                {form, [{enctype, "multipart/form-data"},{action,"    /dpagepost.yaws?action=addf"},{method,post}],[
                    {input, [{type,file},{name,"fname"},{width,"50"},{value,"Upload"}]},
                    {input, [{type,submit},{value,"Upload"}]}           
                ]}
            ]};
        _ ->
            {ehtml, [
                {h2, [], "Unvalid Action. Please insure you are Admin Enabled"},
                {hr}
            ]}
    end, 
    [Css, Body, bot(), break].


%%% Process POST data from client, state=#upload
%%% returns Ehtml | {get_more, Continuation, NewState}
uploadpost(A) ->
CAdmen = getadmen(A),
case {yaws_api:queryvar(A,"action"),CAdmen} of
    {{ok, Action},true} -> Action;
    _ -> Action = ""  
end,
case Action of    
    "addf" ->
        State = case A#arg.state of
            undefined -> #upload{};
        _    -> A#arg.state
        end,
        multipart(A, State);
    "delf" ->
        case {yaws_api:queryvar(A, "fid"),yaws_api:queryvar(A, "fname"),CAdmen} of
    {{ok,LFid},{ok,LFname},true} ->
                {NFid,_} = string:to_integer(LFid),
                Fname = string:strip(LFname),
                SQL = "delete from files where fid=?",
                Ref=dbconnect(),
                odbc:param_query(Ref,SQL,[{sql_integer, [NFid]}]),
                odbc:disconnect(Ref),
                case file:delete(concat(?DIR,Fname)) of
                    ok ->
                        upload(A,"File Delete sucessfull.");
                    _ ->     upload(A,"File Delete Failed.")
                end;               
            _ -> upload(A,"You performed an invalid Action.")
        end;       
    _ -> upload(A,"You performed an invalid Action.")
end.   

err() -> "error".


multipart(A, State) ->
Admen = getadmen(A),
Parse = yaws_api:parse_multipart_post(A),
case {Parse,Admen} of
    {{cont, Cont, Res},true} ->
        case addFileChunk(A, Res, State) of
            {done, Result} ->
         upload(A,Result);
            {cont, NewState} ->
                {get_more, Cont, NewState}
        end;
    {{result, Res},true} ->
        case addFileChunk(A, Res, State#upload{last=true}) of
            {done, Result} ->
                upload(A,Result);
            {cont, _} ->
                upload(A,"Upload failed")
        end;
    _ ->
        upload(A,"Upload failed")
end.

addFileChunk(A, [{part_body, Data}|Res], State) ->
addFileChunk(A, [{body, Data}|Res], State);
addFileChunk(_A, [], State) when State#upload.last==true,State#upload.filename /=   undefined,State#upload.fd /= undefined ->
file:close(State#upload.fd),
SQL = "insert into files (filename) values ( ?)",
Ref=dbconnect(),
odbc:param_query(Ref,SQL,[{{sql_varchar, 50}, [State#upload.filename]}]),
odbc:disconnect(Ref),
{done,"Upload Completed Sucessfully."};
addFileChunk(_A, [], State) when State#upload.last==true ->
{done, err()};
addFileChunk(_A, [], State) ->
{cont, State};
addFileChunk(A, [{head, {_Name, Opts}}|Res], State ) ->
case lists:keysearch(filename, 1, Opts) of
  {value, {_, Fname0}} ->
    Fname = yaws_api:sanitize_file_name(filename:basename(Fname0)),
        %file:make_dir(?DIR),
    case file:open([?DIR, Fname] ,[write]) of
            {ok, Fd} ->
                 S2 = State#upload{filename = Fname,fd = Fd},
                addFileChunk(A, Res, S2);
            _ ->
                {done, err()}
    end;
    false -> addFileChunk(A,Res,State)
end;
addFileChunk(A, [{body, Data}|Res], State) when State#upload.filename /= undefined ->
case file:write(State#upload.fd, Data) of
  ok ->
      addFileChunk(A, Res, State);
  _ ->
      {done, err()}
end.`

_________ Данные о сбое _________________ Внутренняя ошибка, код рыскания упал

ERROR erlang code threw an uncaught exception:
File: /var/lib/yaws/www/dpagepost.yaws:1
Class: error
Exception: function_clause
Req: {http_request,'POST',{abs_path,"/dpagepost.yaws?action=addf"},{1,1}}
Stack: [{cwpage,addFileChunk,
        [{arg,
             {ssl,
                 {sslsocket,
                     {gen_tcp,#Port<0.1480>,tls_connection},
                     <0.73.0>}},
             {{192,168,0,133},54630},
             {headers,"keep-alive",
                 "text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8",
                 "192.168.0.190",undefined,undefined,undefined,undefined,
                 undefined,undefined,"https://192.168.0.190/upload.yaws",
                 "Mozilla/5.0 (X11; Linux x86_64; rv:26.0) Gecko/20100101 Firefox/26.0",
                 undefined,
                 ["__atuvc=30%7C35; cwhoa_sid=nonode@nohost-211833414978628805947952202420298501124"],
                 undefined,undefined,"229",
                 "multipart/form-data;  boundary=---------------------------501916758553745487488260262",
                 undefined,undefined,undefined,undefined,
                 [{http_header,10,'Accept-Encoding',undefined,
                      "gzip, deflate"},
                  {http_header,11,'Accept-Language',undefined,
                      "en-US,en;q=0.5"}]},
             {http_request,'POST',
                 {abs_path,"/dpagepost.yaws?action=addf"},
                 {1,1}},
             {http_request,'POST',
                 {abs_path,"/dpagepost.yaws?action=addf"},
                 {1,1}},
             <<"-----------------------------501916758553745487488260262\r\nContent-Disposition: form-data; name=\"fname\"; filename=\"Hello.txt\"\r\nContent-Type: text/plain\r\n\r\nHello, World\n\r\n-----------------------------501916758553745487488260262--\r\n">>,
             "/dpagepost.yaws","action=addf",undefined,
             "/var/lib/yaws/www","/","/var/lib/yaws/www/dpagepost.yaws",
             undefined,undefined,<0.72.0>,[],undefined,"/",undefined},
         [{body,"Hello, World\n"}],
         {upload,undefined,undefined,true}],
        [{file,"cwpage.erl"},{line,239}]},
    {cwpage,multipart,2,[{file,"cwpage.erl"},{line,209}]},
    {yaws_server,deliver_dyn_part,8,
        [{file,"yaws_server.erl"},{line,2801}]},
    {yaws_server,aloop,4,[{file,"yaws_server.erl"},{line,1215}]},
    {yaws_server,acceptor0,2,[{file,"yaws_server.erl"},{line,1052}]},
    {proc_lib,init_p_do_apply,3,[{file,"proc_lib.erl"},{line,239}]}]

1 ответ

Решение

Прошу прощения только за частичный ответ, но это слишком долго для комментария.

Ошибка function_clause означает, что ни одно из предложений не соответствует заданным аргументам.

addFileChunk(A, [{part_body, Data}|Res], State) -> ...
addFileChunk(_A, [], State) when State#upload.last==true,State#upload.filename /=   undefined,State#upload.fd /= undefined -> ...
addFileChunk(_A, [], State) when State#upload.last==true -> ...
addFileChunk(_A, [], State) -> ...
addFileChunk(A, [{head, {_Name, Opts}}|Res], State ) -> ...
addFileChunk(A, [{body, Data}|Res], State) when State#upload.filename /= undefined -> ...

Первый аргумент не используется или соответствует всему, поэтому давайте посмотрим на два других.

[{body,"Hello, World\n"}],
{upload,undefined,undefined,true}

Может соответствовать последнему предложению, если в upload запись. Так в uploadpost/1:

case Action of    
"addf" ->
    State = case A#arg.state of
        undefined -> #upload{};
    _    -> A#arg.state
    end,

Вы можете, например, извлечь имя файла из arg.clidata и добавить его в upload государство. Это должно решить проблему, но я понятия не имею, почему это работает без SSL.

Другие вопросы по тегам