在我的Ruby on Rails应用程序中,我试图通过Base64格式的POSTMAN REST客户端上传一张图像。当我张贴图像时,我得到了406不可接受的响应。当我检查我的数据库,图像在那里,并成功保存。

这个错误的原因是什么,我需要在我的头文件中指定什么吗?

我的要求:

URL——http://localhost:3000/exercises.json

标题:

Content-Type  -  application/json

原始数据:

{
    "exercise": {
        "subbodypart_ids": [
            "1",
            "2"
        ],
        "name": "Exercise14"
    },
    "image_file_name": "Pressurebar Above.jpg",
    "image":"******base64 Format*******"
}

当前回答

“有时”这可能意味着服务器有一个内部错误,并希望响应一个错误消息(例如:500与JSON有效负载),但由于请求头没有说它接受JSON,它返回一个406。图。(在本例中为spring boot webapp)。

这样的话,你的行动确实失败了。但失败的信息被另一条信息掩盖了。

其他回答

const request = require('request');

const headers = {
    'Accept': '*/*',
    'User-Agent': 'request',
};

const options = {
    url: "https://example.com/users/6",
    headers:  headers
};

request.get(options, (error, response, body) => {
    console.log(response.body);
});

就我而言,我补充说:

Content-Type: application/x-www-form-urlencoded

完全解决了我的问题。

当浏览器中存储或引用无效的cookie时,您也可以收到406响应—例如,在本地以Dev模式运行Rails服务器时。

如果碰巧在同一个端口上运行两个不同的项目,浏览器可能会引用来自不同localhost会话的cookie。

这种事就发生在我身上……让我一时糊涂。在浏览器> Developer Mode > Network中显示。

将报头更改为接受:*/*解决了我的问题,并确保您没有任何其他接受报头

这也可能是由于防火墙阻止了请求。在我的例子中,请求有效负载包含字符串属性-“像%abc%”和&符号“&”-这导致防火墙认为这是一个安全风险(例如。一个SQL注入攻击),它阻止了请求。请注意,这里的请求并不实际发送到服务器,而是在防火墙级别本身返回。

在我的例子中,没有生成应用服务器日志,因此我知道请求实际上没有到达服务器,并且在此之前被阻止了。帮助我的日志是Web应用程序防火墙(WAF)日志。