erlang http

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_34376435/article/details/89308504

http协议基础
erlang的httpc模块提供了HTTP的API,在使用之前记得启动inets,如果要使用https,需要启动ssl。
使用request函数来向制定地址发送HTTP消息。

request(Method, Request, HTTPOptions, Options, Profile) -> {ok,Result}|{ok,saved_to_fle}|{error,Reason}
httpc:request(get,{"http://127.0.0.1:8080?a=b&c=d",[{"content-type","application/x-www-form-urlencoded"}]},[],[]).
httpc:request(post,{"http://127.0.0.1:8080",[],"application/json",jsx:encode(#{a=>b,c=>d})},[],[]).

发送消息后,根据双方约定的content-type取出内容进行解析就可以了
如果有某些信息带有特殊字符而导致无法传输的时候,可以考虑进行编码后再传输percent-encoding

httpc:request(get,{"http://127.0.0.1:8080?"++http_uri:encode("key=!@#$%^^&*("),[{"content-type","application/x-www-format-urlencoded"}]},[],[]).

再http_option()字段可以填写参数url_encode来进行编码,不过我试了下报错了,不知道实际该怎么使用
我们可以使用cowboy来搭建http服务器

start(_Type, _Args) ->
	Dispatch = cowboy_router:compile([
		{'_', [{"/", hello_handler, []}]}
]),
	{ok, _} = cowboy:start_clear(my_http_listener,[{port, 8000}], #{env => #{dispatch => Dispatch}}),
	hello_erlang_sup:start_link().

接下来我们就需要实现hello_handler来处理收到的消息就可以了
对于get方法,我们可以使用cowboy:parse_qs/1来获取url后面的字符串
对于未编码的字符串,cowboy:parse_qs直接返回proplists,使用proplists:get_value就可以取得相应的键值。而编码过的字符串需要自己解码后自行处理
对于post方法,我们一般是使用jsx:encode编码过后的字符串当做content来传输,使用coboy_req:read_body来取得内容。如果是<<“a=b&c=d”>>这种形式的内容(即application/x-www-format-urlencoded类型),使用cowboy_req:read_urlencoded_body来取得内容,返回的是proplists
处理完之后我们就可以使用cowboy_req:reply来返回消息了。

猜你喜欢

转载自blog.csdn.net/qq_34376435/article/details/89308504