diff --git a/shell/browser/net/atom_url_loader_factory.cc b/shell/browser/net/atom_url_loader_factory.cc index fb6e1a627ef0..a864270044a8 100644 --- a/shell/browser/net/atom_url_loader_factory.cc +++ b/shell/browser/net/atom_url_loader_factory.cc @@ -123,9 +123,8 @@ network::ResourceResponseHead ToResponseHead(const mate::Dictionary& dict) { } // Some apps are passing content-type via headers, which is not accepted // in NetworkService. - if (base::ToLowerASCII(iter.first) == "content-type" && - iter.second.is_string()) { - head.mime_type = iter.second.GetString(); + if (base::ToLowerASCII(iter.first) == "content-type") { + head.headers->GetMimeTypeAndCharset(&head.mime_type, &head.charset); has_content_type = true; } } diff --git a/spec-main/api-protocol-spec.ts b/spec-main/api-protocol-spec.ts index 525c90848af5..67c38936aaae 100644 --- a/spec-main/api-protocol-spec.ts +++ b/spec-main/api-protocol-spec.ts @@ -469,6 +469,18 @@ describe('protocol module', () => { expect(r.data).to.have.property('value').that.is.equal(1) }) + it('can set content-type with charset', async () => { + await interceptStringProtocol('http', (request, callback) => { + callback({ + mimeType: 'application/json; charset=UTF-8', + data: '{"value": 1}' + }) + }) + const r = await ajax('http://fake-host') + expect(r.data).to.be.an('object') + expect(r.data).to.have.property('value').that.is.equal(1) + }) + it('can receive post data', async () => { await interceptStringProtocol('http', (request, callback) => { const uploadData = request.uploadData[0].bytes.toString()