Рендеринг ссылки на Facebook не получил правильные мета

Когда я перешел по ссылке на Facebook "www.testurl.com/profile", я не получил правильные метас. Я использую компонент реагирующего шлема, и я пытался добавить {og:title и og:decription}, он не работал. И что же мне делать?

1 ответ

Решение

Вы должны отображать сайт на сервере, потому что Facebook Bots не отображает ваше приложение React. Они просто видят ваше пустое приложение, поэтому вы должны отобразить свое приложение и отправить строку, когда бот социальной сети посетил ваш сайт. Мы делаем это с некоторыми конфигами nginx и пакетом prerender. Ты можешь попробовать.

По умолчанию prerender использовать порт 4201

server {
    listen 80;
    listen 443 ssl;
    server_name yourservername.com;

    root /var/www/build;
    index index.html;

    location / {
        try_files $uri @prerender;
    }

    location @prerender {

        set $prerender 0;
        if ($http_user_agent ~* "googlebot|bingbot|yandex|baiduspider|twitterbot|facebookexternalhit|rogerbot|linkedinbot|embedly|quora link preview|showyoubot|outbrain|pinterest|slackbot|vkShare|W3C_Validator") {
            set $prerender 1;
        }
        if ($args ~ "_escaped_fragment_") {
            set $prerender 1;
        }
        if ($http_user_agent ~ "Prerender") {
            set $prerender 0;
        }
        if ($uri ~* "\.(js|css|xml|less|png|jpg|jpeg|gif|pdf|doc|txt|ico|rss|zip|mp3|rar|exe|wmv|doc|avi|ppt|mpg|mpeg|tif|wav|mov|psd|ai|xls|mp4|m4a|swf|dat|dmg|iso|flv|m4v|torrent|ttf|woff|svg|eot)") {
            set $prerender 0;
        }

        #resolve using Google's DNS server to force DNS resolution and prevent caching of IPs
        resolver 8.8.8.8;

        if ($prerender = 1) {
            proxy_pass http://127.0.0.1:4201/render?url=https://www.yourwebsite.com$request_uri;
        }
        if ($prerender = 0) {
            rewrite .* /index.html break;
        }
    }
}
Другие вопросы по тегам