我已经构建了一个处理某种类型请求(html和图像文件)的服务器 当我使用浏览器请求文件时,我能够查看html文件或请求的图像。
我还试图构建一个请求文件的客户端脚本。当我要求html文件时,我会正确收到它 但是当我申请图片文件时,它正在收到,但我无法查看该图片。
如何将图像作为文件接收?
服务器的相关路径:
const server = http.createServer((req, res) => {
console.log(`${req.method} request for ${req.url}`);
console.log(`From: ${req.connection.remoteAddress}`);
let fileName = req.url;
if (utils.isFileExistsInDirectory(__dirname, fileName)) {
if (_.includes(fileName, '.html')) {
fs.readFile(`${__dirname}/${fileName}`, (err, data) => {
if (err) {
res.writeHead(400, {'Content-type':'text/html'});
res.end('A trouble occurred with the file.');
} else {
res.writeHead(200, {'Content-Type': 'text/html'});
res.end(data);
}
});
} else if (fileName.match(/.png$/)) {
fs.readFile(path.join(__dirname, 'images', fileName), (err, data) => {
if (err) {
res.writeHead(400, {'Content-type':'text/html'});
res.end('A trouble occurred with the file.');
} else {
res.writeHead(200, {'Content-Type': 'image/png'});
res.end(data);
}
});
} else {
fs.readFile(`${__dirname}/${fileName}`, (err, data) => {
if (err) {
res.writeHead(400, {'Content-type':'text/html'});
res.end('A trouble occurred with the file.');
} else {
res.writeHead(200, {'Content-Type': 'text/plain'});
res.end(data);
}
});
}
} else {
res.writeHead(404, {'Content-type':'text/html'});
res.end('File not found.');
}
});
客户的相关部分:
const req = http.request(options, res => {
let responseBody = '';
res.on('data', chunk => {
responseBody += chunk;
});
res.on('end', () => {
if (!fs.existsSync(`${__dirname}/${dir}`)){
fs.mkdirSync(`${__dirname}/${dir}`);
}
fs.writeFile(`${__dirname}/${dir}/${path}`, responseBody, err => {
if (err) {
throw err;
}
});
});
});
req.on('error', err => {
console.log(`problem with request: ${err}`);
});
req.end();
答案 0 :(得分:0)
尝试在base64字符串中编码图像
my.get("/getimg", function(req, res)
{
var img = new Buffer(data, 'base64');
res.writeHead(200, {
'Content-Type': 'image/png',
'Content-Length': img.length
});
res.end(img);
});