Erlang cowboy 处理不规范的client

Erlang cowboy 处理不规范的client

Cowboy 1.0 參考

本章:

Dealing with broken clients

存在很多HTTP协议的实现版本号。

很多广泛使用的client,如浏览器。十分符合规范。可是也有一些特殊的client很糟糕,不遵守规范。

Cowboy尽可能地遵守规范,可是仍然无法处理所有可能的情形。Cowboy关注真是 web下的自然例子。

假设client不遵守HTTP规范可能会无法理解Cowboy的响应。有一些变通的方法,本章就说明这个问题。

小写的消息头 Lowercase headers

Cowboy 将所有接收到的消息头转换成小写,同一时候返回的消息头也所有是小写。

一些不按HTTP规范的client可能会报错。一个简单的解决的方法是创建一个onresponse回调方法,用于对返回的头按client的要求格式化。

capitalize_hook(Status, Headers, Body, Req) ->
    Headers2 = [{cowboy_bstr:capitalize_token(N), V}
        || {N, V} <- Headers],
    {ok, Req2} = cowboy_req:reply(Status, Headers2, Body, Req),
    Req2.

注意SPDYclient不会存在此类问题,由于规范声明所有的头都是小写,与HTTP不一样,HTTP同意大写和小写。确依照大写和小写不敏感的方式处理。

骆驼命名法消息头 Camel-case headers

经常由于易读的原因,保留这样的方式的大写和小写。没有简单的方式处理这样的情况,除非直接更改 cowboy_protocol 文件。

Chunked transfer-encoding

经常一个HTTPclient声明HTTP/1.1,可是不支持块编码传输chunked transfer-encoding。

依照HTTP/1.1client的规范要求。这是不对的。

这有一个简单的变通解决的方法。通过改变Req对象的response 状态为waiting_stream, Cowboy 就能依照HTTP/1.0client所理解的方式处理(标记为transfer-encoding而不是chunked transfer-encoding)。

Req2 = cowboy_req:set(resp_state, waiting_stream).
时间: 2024-10-24 16:00:14

Erlang cowboy 处理不规范的client的相关文章

Erlang cowboy 处理不规范的客户端

Erlang cowboy 处理不规范的客户端 Cowboy 1.0 参考 本章: Dealing with broken clients 存在许多HTTP协议的实现版本.许多广泛使用的客户端,如浏览器,十分符合规范.但是也有一些特殊的客户端非常糟糕,不遵守规范. Cowboy尽可能地遵守规范,但是仍然无法处理全部可能的情形.Cowboy关注真是 web下的自然样例.如果客户端不遵守HTTP规范可能会无法理解Cowboy的响应.有一些变通的方法,本章就说明这个问题. 小写的消息头 Lowerca

Erlang cowboy 入门参考

Erlang cowboy 入门参考 cheungmine,2014-10-28 本文翻译自: http://ninenines.eu/docs/en/cowboy/HEAD/guide/getting_started/ 我没有按原文逐句翻译.仅仅是我自己的理解,力求简单明了.本文程序在RHEL6.4上写成并运行,参考下面的文章,安装Erlang: erlang在redhat上的安装 1 引言 Erlang不仅仅是一门语言,更是一个操作平台.Erlang开发者很少写单独的模块,而是写库和程序,然

Erlang cowboy websocket 服务器

Erlang cowboy websocket 服务器 原文见于: http://marcelog.github.io/articles/erlang_websocket_server_cowboy_tutorial.html 本文不是原文的简单翻译,是参考原文,根据我的理解和实践写出来的.本文的源码见于: https://github.com/marcelog/erws 1 引言 Erlang可以用来实现一个websocket服务器.cowboy这样框架可以完成这个任务,是我们不必关注webs

Erlang cowboy 架构

Erlang cowboy Architecture架构 Erlang cowboy参考: http://ninenines.eu/docs/en/cowboy/1.0/guide/ 本章Architecture: http://ninenines.eu/docs/en/cowboy/1.0/guide/architecture/ Architecture Cowboy 是轻量的HTTP server. 它构建在Ranch之上,请参考Ranch. 每个连接一个进程 cowboy每个连接使用一个进

Erlang cowboy http request生命周期

Erlang cowboy http request生命周期 翻译自: http://ninenines.eu/docs/en/cowboy/1.0/guide/http_req_life/ request的生命周期 本章解释服务器response之前的http request的步骤,以及cowboy实现的细节. Request/response 正如你了解到的,HTTP客户端连接到服务器,发送资源请求(request),服务器发送响应(response),其中包含可以获取到的资源. 在服务器发

Erlang cowboy 入门参考之现代Web的发展历史

Erlang cowboy 入门参考之现代Web发展史 原文: http://ninenines.eu/docs/en/cowboy/1.0/guide/modern_web/ 让我回顾一下web技术的发展历史,并可预见一下未来的发展.除了HTTP/2.0这个还未正式纳入规范的技术,Cowboy与所有这些技术都是兼容的. 早期的Web 起初的HTTP就是用来对GET请求返回HTML页面的.最初的版本是HTTP/0.9.HTTP/1.0定义了GET,HEAD和POST方法,能通过POST请求发送数

[erlang]cowboy handler模块的使用

关于Cowboy Cowboy是基于Erlang实现的一个轻量级.快速.模块化的http web服务器. Handlers,用于处理HTTP请求的程序处理模块. Plain HTTP Handlers(常规Handlers) Cowboy里面的handler最基础的事情就是实现 init/2 回调函数,处理请求,发送客户端响应(可选),最后返回. Cowboy根据 router configuration (路由配置)接收请求并初始化State. 下面是一个不做任何处理的handler: ini

erlang 一个高性能web框架 Cowboy 的使用笔记

环境:ubuntu_server 1210 目的:构建web版hello world程序 参考链接:http://roberto-aloi.com/blog/2013/07/13/create-deploy-erlang-cowboy-application-heroku/ 1.使用rebar 构建一个项目的基础目录 首先获取rebar工具 $ git clone https://github.com/rebar/rebar.git $ cd rebar $ ./bootstrap $ cd .

Erlang HTTP client:ibrowse

ibrowse: https://github.com/cmullaparthi/ibrowse