javascript - 如何通过react在express上向mailchimp发送post请求

标签 javascript reactjs express mailchimp-api-v3.0

我正在尝试从表单发送新成员(member)资格以对我的 express 服务器使用react,以添加到 mailchimp 成员(member)列表中,但我收到了 cors 错误,并且我不知道是否缺少任何代理。我希望用户能够在 React 中注册,然后将其发送到 mailchimp 数据库

我已经能够获取成员列表,但不允许我向其中发帖:

这是我的 Express 后端:

const express = require('express');
const Mailchimp = require('mailchimp-api-v3');
require('dotenv').config();

var request = require('superagent');
var mc_api_key = process.env.REACT_APP_MAILCHIMP_API;
var list_id = process.env.REACT_APP_LIST_ID;

const app = express();

const mailchimp = new Mailchimp(mc_api_key);
const port = process.env.PORT || 5000;

// console.log that your server is up and running
app.listen(port, () => console.log(`Listening on port ${port}`));

app.use((request, response, next) => {
response.header("Access-Control-Allow-Origin", "*");
response.header("Access-Control-Allow-Headers", "Content-Type");
next();
});

// Routes
app.post('/signup', function (req, res) {
request
    .post('https://' + 'us20' + '.api.mailchimp.com/3.0/lists/' + list_id + '/members/')
    .set('Content-Type', 'application/json;charset=utf-8')
    .set('Authorization', 'Basic ' + new Buffer('any:' + mc_api_key ).toString('base64'))
    .send({
      'email_address': req.body.email,
      'status': 'subscribed',
      'merge_fields': {
        'FNAME': req.body.firstName,
        'LNAME': req.body.lastName
      }
    })
        .end(function(err, response) {
          if (response.status < 300 || (response.status === 400 && response.body.title === "Member Exists")) {
            res.send('Signed Up!');
          } else {
            res.send('Sign Up Failed :(');
              }
          });
});

这是我尝试在 app.js 文件中获取 React 的位置:

onSubmit = (e,email) => {
  e.preventDefault()
  this.setState({user:email})
  fetch('http://localhost:5000/signup',{
    method: 'POST',
    headers: {
      'Accept':'application/json',
      'Content-type':'application/json'
      },
    body: JSON.stringify({email_address: email, status: 'subscribed'})
  }).then(console.log)
};

当点击提交时,我希望将成员(member)电子邮件地址发送到 mailchimp API,但我收到此错误:

Access to fetch at 'http://localhost:5000/signup' from origin 'http://localhost:3000' has been blocked by CORS policy: Response to preflight request doesn't pass access control check: No 'Access- Control-Allow-Origin' header is present on the requested resource. If an opaque response serves your needs, set the request's mode to 'no-cors' to fetch the resource with CORS disabled.

最佳答案

试试这个。

app.use((request, response, next) => {
   response.header("Access-Control-Allow-Origin", "*");
   response.header("Access-Control-Allow-Headers", "Content-Type");
   next();
});

app.use(function(req, res, next) {
  res.header("Access-Control-Allow-Origin", "http://localhost:5000");
  next();
});

关于javascript - 如何通过react在express上向mailchimp发送post请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57415145/

相关文章:

javascript - 如何在 JavaScript 中实现 DOM 数据绑定(bind)

javascript - 如何使用 Jest/React 测试 Router.push

express - 使用 mongoose.createConnection() 与 mongoose.connect() 时查询挂起

node.js - Express-session - session 的并发修改

node.js - 当我更改中间件中的 url 时,即使该中间件匹配模式路径,它也不会跳转到下一个中​​间件

javascript - 用于检测屏幕尺寸的脚本,并根据屏幕尺寸更改css

javascript - Shinydashboard:使侧边栏在主体上方打开而不是挤压主体

javascript - 使用 Vue Router 设置页面标题

css - 如何使用 hooks 覆盖 Material ui 样式

reactjs - 在 React 中,如何使用多个状态属性设置 img src?