正在 server.js (Express/NextJS) 中获取 301 重定向数据

Fetching 301 Redirect Data In server.js (Express/NextJS)

我正在使用 express 和 next js 开发一个项目,我找到了一个很好的示例,说明如何在 server.js 文件中为重定向设置数据数组。但是,如果可能的话,我想在 WordPress 中构建一个插件,允许用户提交数据进行重定向,以便它可以由没有技术知识的人管理。我的问题是,是否可以在我的 server.js 文件中获取数据以替换此示例中的数据?

const express = require('express')
const next = require('next')
const { join } = require('path')

const dev = process.env.NODE_ENV !== 'production'
const app = next({ dev })
const handle = app.getRequestHandler()

//This is the data I want to fetch through the WP Rest API
const redirects = [
  { from: '/old-link-1', to: '/new-link-1' },
  { from: '/old-link-2', to: 'https://externalsite.com/new-link-2' },
]

app.prepare().then(() => {
  const server = express()

  redirects.forEach(({ from, to, type = 301, method = 'get' }) => {
    server[method](from, (req, res) => {
      res.redirect(type, to)
    })
  })

  server.get('*', (req, res) => {
    return handle(req, res)
  })

  server.listen(3000, err => {
    if (err) throw err
    console.log('> Ready on http://localhost:3000')
  })
})

是的,我相信这样做是可能的。

此库允许您在 express 中发出 API 请求:https://github.com/request/request

这样执行:

 var request = require('request');
 request('http://www.google.com', function (error, response, body) {
   if (!error && response.statusCode == 200) {
     console.log(body) // Print the google web page.
   }
 })

下一步是在 wordpress 中创建一个端点,其中包含您要创建的所有 301:

function my_custom_endpoint(){
  return 'Hey look, its some data';
}

// Register the rest route here.
add_action( 'rest_api_init', function () {
register_rest_route( 'yournamespace/v1', 'my_custom_endpoint',array(
    'methods'  => 'GET',
    'callback' => 'my_custom_endpoint'
  ));
});

祝你好运,编码愉快!

因此,以防万一其他人偶然发现以编程方式添加源自 WordPress 安装的重定向的问题,这就是如何完成的。我的技术堆栈是 React,Next.js 有一个 Express 服务器从位于网络其他地方的 WordPress 安装中提取数据。

WordPress:

1) 创建一个空白的 WordPress 插件(Google 是你的朋友)

2) 在您的插件中创建一个激活挂钩以创建一个数据库(同样,Google 每个条目都有 'to_url' 和 'from_url'。

3) 在插件中注册一个休息路线(就像上面 Tanner 的回答所描述的那样)

  • 这条休息路线应该从数据库中提取您的信息并将其作为数组以这种格式返回:

    [ { 'from': '/about', 'to': '/about-us' }, { 'from': '/test3', 'to': '/banks/testing-page' }, ]

4) 创建一个带有表单的插件管理页面,允许用户向该数据库添加条目。随着您的数据库的增长,来自其他 api 的响应也会增长,并且您的重定向将无缝地包含在您的项目中。

5) 在您的 React server.js 中,您将需要以下设置

const request = require("request");
let redirects;
request('https://yourwebsite.com/wp-json/YOUR-ROUTE/v2/redirects', function (error, response, body) {
   if (!error && response.statusCode == 200) {
      redirects = JSON.parse(body);
   }
 })
redirects.forEach(({ from, to, type = 301, method = 'get' }) => {
          server[method](from, (req, res) => {
            res.redirect(type, to)
          })
        });

注意事项:确保在使用 php 中的表单处理数据时,您采取了适当的预防措施来清理和转义所有内容。