Как установить 'X-Robots-Tag' моего sitemap.xml с помощью Express - PullRequest
0 голосов
/ 13 февраля 2019

Как мне установить HTTP-заголовок «X-Robots-Tag» моего sitemap.xml (и только этот файл) на «noindex, follow» с помощью express?

Файл sitemap.xml находитсякорень моего приложения.

Вот фрагмент моей конфигурации exress:

express / development.js

const express = require('express')
const webpack = require('webpack')
const cors = require('cors')
const webpackDevMiddleware = require('webpack-dev-middleware')
const webpackHotMiddleware = require('webpack-hot-middleware')
const webpackHotServerMiddleware = require('webpack-hot-server-middleware')
const config = require('./../webpack/webpack.development.config.js')

const app = express()
const compiler = webpack(config)
const PORT = process.env.PORT || 3000

app.use(cors())
app.use(express.static('build'))
app.use(express.static('public'))

...

Я пробовал это:

... 

app.get('/sitemap.xml', res => {
  res.setHeader('X-Robots-Tag', 'noindex, follow')
})

и это:

app.get('/sitemap.xml', res => {
  res.set('X-Robots-Tag', 'noindex, follow')
})

Кроме того, как узнать, обновлен ли заголовок.

Я пробовал: $curl -v localhost:3000/sitemap.xml

Но в заголовке нет тега X-Robots-Tag, поэтому я предполагаю, что он не работает.

Ответы [ 2 ]

0 голосов
/ 13 февраля 2019

Как указано в документах , статическое промежуточное ПО принимает аргумент параметров, в котором вы можете установить функцию setHeaders для изменения заголовков ответов на основе пути:

const fs = require('fs');
const path = require('path');
const http = require('http');

const express = require('express');

const publicDirectoryPath = path.join(__dirname, './public');

// the following creates and a public directory in the script directory and populates it with some files (for the sake of this demo).

// create the public directory if it doesn't exist
if (!fs.existsSync(publicDirectoryPath)) {
  fs.mkdirSync(publicDirectoryPath);
}

// create a sample sitemap.xml (for the sake of this demo)
const siteMapXml = `<?xml version="1.0" encoding="UTF-8"?>
<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">
   <url>
      <loc>http://www.example.com/</loc>
      <lastmod>2005-01-01</lastmod>
      <changefreq>monthly</changefreq>
      <priority>0.8</priority>
   </url>
</urlset>`;
fs.writeFileSync(path.join(publicDirectoryPath, './sitemap.xml'), siteMapXml);

// create a sample index.html
const indexHtml = `<!DOCTYPE html>
<html lang="en">
  <meta charset="utf-8">
  <title>Demo</title>

  <p>It works!</p>
</html>`;
fs.writeFileSync(path.join(publicDirectoryPath, './index.html'), indexHtml);

// setup and start the express server

const app = express();
const PORT = process.env.PORT || 3000;

app.use(
  express.static(path.join(__dirname, "public"), {
    setHeaders: (res, path) => {
      if (path.endsWith("sitemap.xml")) {
        res.setHeader("X-Robots-Tag", "noindex, follow");
      }
    }
  })
);

app.listen(PORT);

// check response headers

const makeGetRequestAndPrintHeaders = (path) => {
  const options = {
    hostname: 'localhost',
    port: PORT,
    path,
    method: 'GET'
  };

  const req = http.request(options, (res) => {
    console.log(`GET ${path}`);
    console.log(JSON.stringify(res.headers, null, 2));
  });

  req.end();
}

makeGetRequestAndPrintHeaders('/index.html');
makeGetRequestAndPrintHeaders('/sitemap.xml');

// example output
/*
GET /index.html                                     
{                                                   
  "x-powered-by": "Express",                        
  "accept-ranges": "bytes",                         
  "cache-control": "public, max-age=0",             
  "last-modified": "Wed, 13 Feb 2019 14:28:26 GMT", 
  "etag": "W/\"6b-168e74243aa\"",                   
  "content-type": "text/html; charset=UTF-8",       
  "content-length": "107",                          
  "date": "Wed, 13 Feb 2019 14:28:26 GMT",          
  "connection": "close"                             
}                                                   
GET /sitemap.xml                                    
{                                                   
  "x-powered-by": "Express",                        
  "x-robots-tag": "noindex, follow",                
  "accept-ranges": "bytes",                         
  "cache-control": "public, max-age=0",             
  "last-modified": "Wed, 13 Feb 2019 14:28:26 GMT", 
  "etag": "W/\"113-168e74243a9\"",                  
  "content-type": "text/xml; charset=UTF-8",        
  "content-length": "275",                          
  "date": "Wed, 13 Feb 2019 14:28:26 GMT",          
  "connection": "close"                             
}
*/
0 голосов
/ 13 февраля 2019

TLDR

Вы фактически устанавливаете заголовки для запроса, следующий код должен работать:

app.get('/sitemap.xml', (req, res) => {
  res.setHeader('X-Robots-Tag', 'noindex, follow')
  res.sendFile(`${__dirname}/sitemap.xml`)
})

для app.get, функция обратного вызова имеет три аргумента:

app.get('/sitemap.xml', (request, response, nextHandler) => {})

request - это объект запроса, исходящий от клиента.

response - это ответ, который вы отправите с сервера, и это то, что вы на самом деле хотите изменить.

nextHandler передает все вашему следующему обработчику запросов, вызывая его (nextHandler())

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...